/* ===== PLUGIN PAGE ===== */
.plugin-hero{background:var(--bk);padding:64px 5% 56px;text-align:center;position:relative;overflow:hidden;border-bottom:4px solid var(--y)}
.plugin-hero::before{content:'PLUGIN';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-family:'Black Han Sans',sans-serif;font-size:160px;color:rgba(245,200,0,0.05);pointer-events:none;white-space:nowrap}
.plugin-hero-tag{display:inline-block;background:rgba(245,200,0,0.15);color:var(--y);font-size:11px;font-weight:700;padding:4px 14px;border-radius:20px;letter-spacing:1px;text-transform:uppercase;margin-bottom:16px;border:1px solid rgba(245,200,0,0.3)}
.plugin-hero h1{font-family:'Black Han Sans',sans-serif;font-size:clamp(24px,4vw,44px);color:var(--wh);letter-spacing:1px;margin-bottom:12px;line-height:1.2}
.plugin-hero h1 em{color:var(--y);font-style:normal}
.plugin-hero p{font-size:14px;color:rgba(255,255,255,0.55);max-width:520px;margin:0 auto}

/* Plan selector */
.plan-selector{background:var(--gr);padding:56px 5%;text-align:center}
.plan-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:960px;margin:0 auto 16px}
.plan-card{background:var(--wh);border:2px solid var(--bd);border-radius:10px;padding:28px 24px;cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .15s;text-align:left;position:relative}
.plan-card:hover{border-color:var(--y);transform:translateY(-2px)}
.plan-card.active{border-color:var(--y);box-shadow:0 0 0 3px rgba(245,200,0,0.15)}
.plan-card.featured-plan{border-color:var(--bk)}
.plan-card.featured-plan.active{border-color:var(--y)}
.plan-recommend{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--bk);color:var(--y);font-size:11px;font-weight:700;padding:3px 14px;border-radius:20px;white-space:nowrap}
.plan-card-name{font-size:12px;font-weight:700;color:var(--sub);letter-spacing:.5px;text-transform:uppercase;margin-bottom:6px}
.plan-card-price{font-family:'Black Han Sans',sans-serif;font-size:34px;color:var(--bk);line-height:1;margin-bottom:4px}
.plan-card-price span{font-size:14px;font-weight:400;color:var(--sub);font-family:'Noto Sans JP',sans-serif}
.plan-card-desc{font-size:13px;color:var(--sub);margin:10px 0 14px;padding-top:12px;border-top:1px solid var(--bd)}
.plan-card-features{list-style:none;display:flex;flex-direction:column;gap:7px}
.plan-card-features li{font-size:13px;color:var(--tx);display:flex;align-items:center;gap:8px}
.plan-card-features li::before{content:'';width:15px;height:15px;min-width:15px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Crect width='16' height='16' fill='%23F5C800' rx='2'/%3E%3Cpath d='M4 8l3 3 5-5' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat;display:block}
.plan-note{font-size:12px;color:var(--sub);margin-top:10px}
.plan-card-btn{-webkit-appearance:none;appearance:none;display:block;width:100%;margin-top:18px;padding:11px 16px;background:var(--bk);color:var(--wh);border:2px solid var(--bk);border-radius:6px;font-size:13px;font-weight:700;cursor:pointer;font-family:'Noto Sans JP',sans-serif;transition:background .2s,border-color .2s;text-align:center;line-height:1.4}
.plan-card-btn:hover{background:#333;border-color:#333}
.plan-card-btn-featured{background:var(--y);color:var(--bk);border-color:var(--y)}
.plan-card-btn-featured:hover{background:var(--yd);border-color:var(--yd)}

/* Plugin section */
.plugin-section{padding:56px 5%}
.plugin-section:nth-child(even){background:var(--gr)}
.plugin-section:nth-child(odd){background:var(--wh)}
.plugin-zone-header{display:flex;align-items:center;gap:14px;margin-bottom:28px;padding-bottom:16px;border-bottom:2px solid var(--y)}
.pzh-icon{width:44px;height:44px;background:var(--y);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.pzh-text h3{font-family:'Black Han Sans',sans-serif;font-size:20px;color:var(--bk);letter-spacing:.5px}
.pzh-text p{font-size:12px;color:var(--sub);margin-top:2px}
.pzh-plan-badge{margin-left:auto;background:var(--bk);color:var(--y);font-size:11px;font-weight:700;padding:4px 12px;border-radius:20px;white-space:nowrap;flex-shrink:0}
.plugin-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.plugin-card{background:var(--wh);border:1.5px solid var(--bd);border-radius:10px;padding:20px 16px;cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .15s;display:flex;flex-direction:column;gap:10px;position:relative}
.plugin-card:hover{border-color:var(--y);box-shadow:0 4px 16px rgba(245,200,0,0.15);transform:translateY(-3px)}
.plugin-card.locked{opacity:.55;cursor:not-allowed}
.plugin-card.locked:hover{border-color:var(--bd);box-shadow:none;transform:none}
.plugin-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.plugin-name{font-size:14px;font-weight:700;color:var(--bk);line-height:1.35}
.plugin-short{font-size:12px;color:var(--sub);line-height:1.5}
.plugin-tag{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;margin-top:auto}
.lock-overlay{position:absolute;top:8px;right:8px;background:var(--bd);border-radius:20px;padding:2px 8px;font-size:10px;font-weight:700;color:var(--sub)}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.55);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .25s}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--wh);border-radius:14px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,0.2);transform:translateY(20px);transition:transform .25s}
.modal-overlay.open .modal{transform:translateY(0)}
.modal-header{padding:24px 24px 0;display:flex;align-items:flex-start;gap:14px}
.modal-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}
.modal-title-area{flex:1}
.modal-title{font-size:18px;font-weight:700;color:var(--bk);margin-bottom:4px}
.modal-subtitle{font-size:12px;color:var(--sub)}
.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--sub);padding:4px;line-height:1;flex-shrink:0}
.modal-close:hover{color:var(--bk)}
.modal-body{padding:20px 24px}
.modal-section{margin-bottom:18px}
.modal-section h4{font-size:13px;font-weight:700;color:var(--bk);margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--bd)}
.modal-section p,.modal-section li{font-size:13px;color:var(--sub);line-height:1.75}
.modal-section ul{list-style:none;display:flex;flex-direction:column;gap:5px;padding:0}
.modal-section ul li::before{content:'✓ ';color:var(--yd);font-weight:700}
.modal-footer{padding:0 24px 24px;display:flex;flex-direction:column;gap:10px}
.modal-plan-note{background:var(--yp);border:1px solid rgba(245,200,0,0.4);border-radius:8px;padding:10px 14px;font-size:12px;color:var(--yd);font-weight:600;text-align:center}
.btn-stripe{background:var(--bk);color:var(--wh);width:100%;padding:14px;border:none;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;font-family:'Noto Sans JP',sans-serif;display:flex;align-items:center;justify-content:center;gap:10px;transition:background .2s}
.btn-stripe:hover{background:#333}
.btn-stripe-sub{background:transparent;color:var(--sub);width:100%;padding:10px;border:1.5px solid var(--bd);border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:'Noto Sans JP',sans-serif;transition:border-color .2s}
.btn-stripe-sub:hover{border-color:var(--bk);color:var(--bk)}
.stripe-badge{display:flex;align-items:center;justify-content:center;gap:6px;font-size:11px;color:var(--sub);margin-top:6px}

.plugin-card-featured{border-color:var(--y) !important;box-shadow:0 0 0 2px rgba(245,200,0,0.2)}
.plugin-card-new-badge{position:absolute;top:-10px;left:16px;background:var(--y);color:var(--bk);font-size:10px;font-weight:700;padding:2px 10px;border-radius:20px;letter-spacing:.5px}

@media(max-width:640px){.plan-cards{grid-template-columns:1fr}}
