*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes popIn{from{transform:scale(.88) translateY(10px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
@keyframes shimmer{0%{background-position:-300% 0}100%{background-position:300% 0}}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes glowPulse{0%,100%{box-shadow:0 0 40px rgba(var(--accent-rgb,0,255,136),.15),0 4px 24px rgba(var(--accent-rgb,0,255,136),.2)}50%{box-shadow:0 0 70px rgba(var(--accent-rgb,0,255,136),.3),0 4px 36px rgba(var(--accent-rgb,0,255,136),.35)}}

body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body,'Inter',sans-serif);
  min-height:100vh;
  overflow-x:hidden;
}

/* ── Ambient orbs ── */
.bg-orb{position:fixed;border-radius:50%;pointer-events:none;z-index:0;filter:blur(130px)}
.bg-orb1{width:700px;height:700px;background:rgba(var(--accent-rgb,0,255,136),.04);top:-200px;right:-150px}
.bg-orb2{width:500px;height:500px;background:rgba(var(--accent-rgb,0,255,136),.03);bottom:-150px;left:-100px}
.bg-orb3{width:400px;height:400px;background:rgba(var(--accent-rgb,0,255,136),.025);top:50%;left:50%;transform:translate(-50%,-50%)}

/* ── Page loader ── */
.page-loader{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .45s}
.page-loader.gone{opacity:0;pointer-events:none}
.pl-inner{text-align:center}
.pl-logo{font-family:var(--font-heading,'Space Grotesk',sans-serif);font-size:28px;font-weight:800;margin-bottom:20px}
.pl-logo span{color:var(--accent)}
.pl-spin{width:32px;height:32px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto}

/* ── Header ── */
header{
  position:sticky;top:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 32px;
  background:rgba(var(--bg-raw,7,12,9),.9);
  border-bottom:1px solid var(--border);
  backdrop-filter:blur(20px);
}
.logo{font-family:var(--font-heading,'Space Grotesk',sans-serif);font-size:18px;font-weight:700;cursor:pointer;user-select:none;text-decoration:none;color:var(--text)}
.logo span{color:var(--accent)}
.btn-ghost{
  background:none;border:1px solid var(--border);color:var(--muted);
  border-radius:var(--radius-md,10px);padding:8px 14px;
  font-family:var(--font-body,'Inter',sans-serif);font-size:13px;cursor:pointer;
  transition:all .2s;display:inline-flex;align-items:center;gap:6px;
}
.btn-ghost:hover{border-color:var(--accent2);color:var(--text)}

/* ── Main ── */
main{position:relative;z-index:1;max-width:1020px;margin:0 auto;padding:60px 24px 100px}

/* ── Hero ── */
.hero{text-align:center;margin-bottom:52px;animation:fadeUp .55s ease both}
.hero-pill{
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(var(--accent-rgb,0,255,136),.08);
  border:1px solid rgba(var(--accent-rgb,0,255,136),.2);
  border-radius:999px;padding:6px 16px;
  font-size:11px;font-weight:700;color:var(--accent2);
  text-transform:uppercase;letter-spacing:1px;margin-bottom:22px;
}
.hero h1{
  font-family:var(--font-heading,'Space Grotesk',sans-serif);
  font-size:50px;font-weight:800;
  line-height:1.1;letter-spacing:-.5px;margin-bottom:16px;
}
.hero h1 .hl{
  color:var(--accent);
  text-shadow:0 0 60px rgba(var(--accent-rgb,0,255,136),.4);
}
.hero p{font-size:16px;color:var(--muted);line-height:1.7;max-width:480px;margin:0 auto 20px}

/* Social proof strip */
.social-proof{
  display:inline-flex;align-items:center;gap:16px;
  background:rgba(var(--accent-rgb,0,255,136),.04);
  border:1px solid rgba(var(--accent-rgb,0,255,136),.1);
  border-radius:999px;padding:8px 20px;font-size:12px;color:var(--muted);
  flex-wrap:wrap;justify-content:center;
}
.sp-item{display:flex;align-items:center;gap:6px}
.sp-item i{color:var(--accent2);font-size:11px}
.sp-sep{opacity:.2}

@media(max-width:640px){.hero h1{font-size:34px}}

/* ── Current plan strip ── */
.plan-strip{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:var(--panel);border:1px solid var(--border);
  border-radius:var(--radius-xl,20px);padding:16px 22px;
  margin-bottom:36px;flex-wrap:wrap;
  animation:fadeUp .55s .1s ease both;
}
.ps-left{display:flex;align-items:center;gap:12px}
.ps-icon{width:40px;height:40px;border-radius:var(--radius-lg,14px);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.ps-icon.free{background:rgba(143,163,154,.1);color:var(--muted)}
.ps-icon.pro{background:rgba(var(--accent-rgb,0,255,136),.12);color:var(--accent2)}
.ps-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.7px;margin-bottom:3px}
.ps-val{font-family:var(--font-heading,'Space Grotesk',sans-serif);font-size:16px;font-weight:700}
.ps-val.pro{color:var(--accent2)}
.ps-meta{font-size:13px;color:var(--muted)}
.ps-meta.warn{color:var(--amber,#f59e0b)}
.ps-meta.danger{color:var(--red,#ff5f6d)}
.manage-btn{
  background:none;border:1px solid rgba(var(--accent-rgb,0,255,136),.3);color:var(--accent2);
  border-radius:var(--radius-md,10px);padding:8px 14px;
  font-family:var(--font-body,'Inter',sans-serif);font-size:12px;
  font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:5px;
}
.manage-btn:hover{background:rgba(var(--accent-rgb,0,255,136),.08)}

/* ── Days bar ── */
.days-bar-wrap{
  margin-bottom:28px;padding:14px 18px;
  background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-xl,20px);
  animation:fadeUp .55s .12s ease both;
}
.days-bar-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-bottom:8px}
.days-bar-track{height:5px;background:var(--border);border-radius:3px;overflow:hidden}
.days-bar-fill{height:100%;border-radius:3px;transition:width .6s ease,background .3s}

/* ── Billing toggle ── */
.billing-toggle{
  display:flex;align-items:center;justify-content:center;
  background:var(--panel);border:1px solid var(--border);
  border-radius:999px;padding:4px;
  margin:0 auto 40px;width:fit-content;
  animation:fadeUp .55s .15s ease both;
}
.btog-btn{
  padding:10px 26px;border:none;border-radius:999px;
  font-family:var(--font-heading,'Space Grotesk',sans-serif);font-size:13px;font-weight:600;
  cursor:pointer;transition:all .25s;color:var(--muted);background:none;
  display:flex;align-items:center;gap:8px;white-space:nowrap;
}
.btog-btn.active{background:var(--accent);color:var(--bg);box-shadow:0 2px 20px rgba(var(--accent-rgb,0,255,136),.35)}

/* Annual badge */
.annual-badge{
  background:rgba(245,158,11,.15);
  border:1px solid rgba(245,158,11,.35);
  color:#fbbf24;
  border-radius:999px;padding:3px 10px;font-size:10px;font-weight:800;
  text-transform:uppercase;letter-spacing:.6px;
}

/* ── Plans grid ── */
.plans{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
  margin-bottom:60px;animation:fadeUp .55s .2s ease both;
}
@media(max-width:660px){.plans{grid-template-columns:1fr}}

.plan-card{
  background:var(--panel);border:1px solid var(--border);
  border-radius:var(--radius-xl,20px);padding:32px;position:relative;
  transition:transform .25s,box-shadow .25s;
}
.plan-card:hover{transform:translateY(-3px)}

/* Pro card */
.plan-card.pro{
  border-color:transparent;
  background:linear-gradient(var(--panel),var(--panel)) padding-box,
             linear-gradient(135deg,rgba(var(--accent-rgb,0,255,136),.4),rgba(var(--accent-rgb,0,255,136),.1) 50%,rgba(var(--accent-rgb,0,255,136),.3)) border-box;
  box-shadow:0 0 60px rgba(var(--accent-rgb,0,255,136),.08),0 20px 60px rgba(0,0,0,.4);
  animation:glowPulse 3s ease-in-out infinite;
}
.plan-card.pro:hover{transform:translateY(-5px);box-shadow:0 0 80px rgba(var(--accent-rgb,0,255,136),.15),0 24px 70px rgba(0,0,0,.45)}

.popular-tag{
  position:absolute;top:-15px;left:50%;transform:translateX(-50%);
  background:linear-gradient(90deg,var(--accent),var(--accent2));
  color:var(--bg);font-family:var(--font-heading,'Space Grotesk',sans-serif);
  font-size:10px;font-weight:800;
  padding:5px 20px;border-radius:999px;
  text-transform:uppercase;letter-spacing:1px;white-space:nowrap;
  box-shadow:0 4px 20px rgba(var(--accent-rgb,0,255,136),.4);
}

.plan-tier{
  font-family:var(--font-heading,'Space Grotesk',sans-serif);font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:1.2px;color:var(--muted);margin-bottom:18px;
}
.plan-tier.pro{color:var(--accent2)}

/* Pricing */
.price-wrap{margin-bottom:12px}
.price-annual-stack{display:flex;align-items:baseline;gap:10px;margin-bottom:4px;flex-wrap:wrap}
.price-old{font-family:var(--font-heading,'Space Grotesk',sans-serif);font-size:28px;font-weight:700;color:var(--muted);text-decoration:line-through;opacity:.5}
.price-row{display:flex;align-items:baseline;gap:3px}
.price-currency{font-family:var(--font-heading,'Space Grotesk',sans-serif);font-size:22px;font-weight:700;color:var(--muted)}
.price-currency.pro{color:var(--accent2)}
.price-amt{font-family:var(--font-heading,'Space Grotesk',sans-serif);font-size:58px;font-weight:800;line-height:1;letter-spacing:-2px}
.price-amt.pro{
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent2) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.price-period{font-size:14px;color:var(--muted);margin-left:4px}
.price-billed-note{font-size:12px;color:var(--muted);margin-top:6px;min-height:18px}
.price-billed-note .save-amt{
  color:#fbbf24;font-weight:700;
  background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.25);
  border-radius:4px;padding:1px 6px;font-size:11px;
}

.plan-desc{font-size:13px;color:var(--muted);line-height:1.7;margin:16px 0 20px}
hr.pdiv{border:none;border-top:1px solid var(--border);margin:18px 0}

.feat-list{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:28px}
.feat-list li{display:flex;align-items:flex-start;gap:10px;font-size:13px;line-height:1.5}
.feat-list li .ico{font-size:11px;margin-top:2px;flex-shrink:0}
.feat-list li .ico.y{color:var(--accent2)}
.feat-list li .ico.n{color:var(--muted);opacity:.3}
.feat-list li.dim{color:var(--muted)}
.feat-note{display:block;font-size:11px;color:var(--muted);margin-top:2px;line-height:1.4}

/* Plan buttons */
.plan-btn{
  display:block;width:100%;padding:15px;text-align:center;
  border-radius:var(--radius-lg,14px);font-family:var(--font-heading,'Space Grotesk',sans-serif);
  font-size:14px;font-weight:700;cursor:pointer;
  transition:all .22s;border:none;letter-spacing:.2px;
}
.plan-btn.ghost{background:none;border:1px solid var(--border);color:var(--muted);cursor:default}
.plan-btn.cta{
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent2) 100%);
  background-size:200% auto;
  color:var(--bg);
  box-shadow:0 6px 28px rgba(var(--accent-rgb,0,255,136),.35);
  animation:shimmer 3s linear infinite;
  position:relative;overflow:hidden;
}
.plan-btn.cta::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);
  transform:translateX(-100%);transition:transform .4s;
}
.plan-btn.cta:hover:not(:disabled)::after{transform:translateX(100%)}
.plan-btn.cta:hover:not(:disabled){
  box-shadow:0 8px 40px rgba(var(--accent-rgb,0,255,136),.55);transform:translateY(-2px);
}
.plan-btn:disabled{opacity:.5;cursor:default;transform:none!important;animation:none}
.plan-btn.current{
  background:rgba(var(--accent-rgb,0,255,136),.08);
  border:1px solid rgba(var(--accent-rgb,0,255,136),.2);
  color:var(--accent2);cursor:default;
}

/* Urgency nudge */
.cta-nudge{
  display:flex;align-items:center;justify-content:center;gap:6px;
  font-size:11px;color:var(--muted);margin-top:10px;
}
.cta-nudge i{color:var(--accent2);font-size:10px}

/* ── Comparison table ── */
.cmp-sec{margin-bottom:60px;animation:fadeUp .55s .25s ease both}
.sec-title{font-family:var(--font-heading,'Space Grotesk',sans-serif);font-size:22px;font-weight:700;text-align:center;margin-bottom:24px}
.cmp-wrap{border:1px solid var(--border);border-radius:var(--radius-xl,20px);overflow:hidden}
.cmp-table{width:100%;border-collapse:collapse}
.cmp-table th{
  padding:14px 20px;font-size:10px;font-weight:700;text-align:left;
  color:var(--muted);background:var(--panel);
  border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.9px;
}
.cmp-table th.pro{color:var(--accent2);background:rgba(var(--accent-rgb,0,255,136),.04)}
.cmp-table td{padding:13px 20px;font-size:13px;border-bottom:1px solid var(--border);background:var(--bg)}
.cmp-table tr:last-child td{border-bottom:none}
.cmp-table td.pro{background:rgba(var(--accent-rgb,0,255,136),.025);color:var(--accent2);font-weight:600}
.cmp-table td.no{color:var(--muted)}
.cmp-table .cat td{
  background:var(--panel);font-family:var(--font-heading,'Space Grotesk',sans-serif);font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.9px;color:var(--muted);
  padding:8px 20px;border-bottom:1px solid var(--border);
}
.cmp-table .cat td.pro{background:rgba(var(--accent-rgb,0,255,136),.04)}
.cmp-table i.y{color:var(--accent2)}.cmp-table i.n{color:var(--muted);opacity:.3}

/* ── FAQ ── */
.faq-sec{margin-bottom:52px;animation:fadeUp .55s .3s ease both}
.faq-item{border:1px solid var(--border);border-radius:var(--radius-lg,14px);margin-bottom:8px;overflow:hidden;transition:border-color .2s}
.faq-item.open{border-color:rgba(var(--accent-rgb,0,255,136),.25)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;cursor:pointer;font-size:14px;font-weight:500;user-select:none;gap:12px;background:var(--panel)}
.faq-q i{color:var(--muted);font-size:11px;transition:transform .25s,color .2s;flex-shrink:0}
.faq-item.open .faq-q i{transform:rotate(180deg);color:var(--accent2)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s;font-size:13px;color:var(--muted);line-height:1.8;padding:0 20px;background:var(--bg)}
.faq-item.open .faq-a{max-height:220px;padding:14px 20px 18px}

/* ── Footer ── */
.footer-note{
  text-align:center;font-size:12px;color:var(--muted);
  display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;
  animation:fadeUp .55s .35s ease both;
}
.footer-note a{color:var(--muted);text-decoration:underline;text-underline-offset:2px}
.footer-note a:hover{color:var(--text)}
.footer-sep{opacity:.3}

/* ══════════════════════════════════════════
   PRO SUBSCRIPTION CELEBRATION MODAL
   (Ported exactly from profile.html reward modal)
═══════════════════════════════════════════ */
@keyframes rewardOverlayIn{from{opacity:0}to{opacity:1}}
@keyframes rewardCardIn{0%{opacity:0;transform:scale(.82) translateY(24px)}65%{transform:scale(1.03) translateY(-4px)}100%{opacity:1;transform:scale(1) translateY(0)}}
@keyframes rewardBadgePop{0%{transform:scale(0) rotate(-18deg)}60%{transform:scale(1.18) rotate(4deg)}80%{transform:scale(.94) rotate(-2deg)}100%{transform:scale(1) rotate(0deg)}}
@keyframes rewardPulseGlow{0%,100%{box-shadow:0 0 0 0 rgba(var(--accent-rgb,0,255,136),.35),0 24px 64px rgba(0,0,0,.7)}50%{box-shadow:0 0 0 18px rgba(var(--accent-rgb,0,255,136),0),0 24px 64px rgba(0,0,0,.7)}}
@keyframes rewardStarSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes rewardFloatUp{0%{opacity:1;transform:translateY(0) scale(1)}100%{opacity:0;transform:translateY(-90px) scale(.4)}}
@keyframes rewardShimmerBar{0%{background-position:-400px 0}100%{background-position:400px 0}}
@keyframes goldShimmer{0%{background-position:200% center}100%{background-position:-200% center}}
@keyframes goldGlare{0%{left:-80%;opacity:0}10%{opacity:1}50%{left:110%;opacity:1}51%{opacity:0}100%{left:110%;opacity:0}}

#rewardOverlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.82);z-index:10000;align-items:center;justify-content:center;padding:20px;animation:rewardOverlayIn .3s ease;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
#rewardOverlay.open{display:flex}

#rewardCard{background:var(--panel);border:1px solid rgba(var(--accent-rgb,0,255,136),.28);border-radius:24px;width:100%;max-width:420px;padding:0;overflow:hidden;animation:rewardCardIn .55s cubic-bezier(.34,1.56,.64,1) both,rewardPulseGlow 2.4s ease 1s infinite;position:relative}

#rewardConfettiCanvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;border-radius:24px;z-index:0}

.reward-hdr{background:linear-gradient(135deg,rgba(var(--accent-rgb,0,255,136),.15) 0%,rgba(var(--accent-rgb,0,255,136),.04) 100%);border-bottom:1px solid rgba(var(--accent-rgb,0,255,136),.18);padding:32px 28px 24px;text-align:center;position:relative;z-index:1}

.reward-icon-wrap{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,rgba(var(--accent-rgb,0,255,136),.22),rgba(var(--accent-rgb,0,255,136),.06));border:2px solid rgba(var(--accent-rgb,0,255,136),.4);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:34px;animation:rewardBadgePop .6s cubic-bezier(.34,1.56,.64,1) .25s both;position:relative}
.reward-icon-wrap::after{content:'';position:absolute;inset:-6px;border-radius:50%;border:1.5px dashed rgba(var(--accent-rgb,0,255,136),.3);animation:rewardStarSpin 8s linear infinite}

.reward-days-badge{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(105deg,#7a5a00 0%,#c9973a 18%,#f5c842 35%,#ffe17a 50%,#f5c842 65%,#c9973a 82%,#7a5a00 100%);background-size:200% auto;color:#3a2800;border:1px solid #c9973a;text-shadow:0 1px 0 rgba(255,230,100,.5);box-shadow:0 2px 8px rgba(0,0,0,.4),0 0 0 1px rgba(255,220,80,.2) inset;animation:rewardShimmerBar 3s linear infinite;border-radius:999px;padding:6px 16px;font-family:var(--font-heading,'Space Grotesk',sans-serif);font-size:13px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;margin-bottom:14px}

.reward-title{font-family:var(--font-heading,'Space Grotesk',sans-serif);font-size:22px;font-weight:800;color:var(--text);margin-bottom:6px;line-height:1.2}
.reward-subtitle{font-size:13px;color:var(--muted);line-height:1.6}
.reward-subtitle strong{color:var(--accent2)}

.reward-body{padding:22px 28px 26px;position:relative;z-index:1}

.reward-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}
.reward-info-cell{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:13px 14px;text-align:center}
.reward-info-cell .ric-val{font-family:var(--font-heading,'Space Grotesk',sans-serif);font-size:20px;font-weight:800;color:var(--accent2);margin-bottom:2px;line-height:1}
.reward-info-cell .ric-lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}

.reward-particles{position:absolute;top:0;left:0;right:0;pointer-events:none;overflow:hidden;height:100%;border-radius:24px;z-index:0}
.reward-particle{position:absolute;font-size:18px;animation:rewardFloatUp 2s ease forwards;opacity:0}

.reward-cta{width:100%;background:var(--accent);color:#0b0f0c;border:none;border-radius:12px;padding:13px 20px;font-family:var(--font-heading,'Space Grotesk',sans-serif);font-size:14px;font-weight:800;cursor:pointer;transition:opacity .2s,transform .15s;display:flex;align-items:center;justify-content:center;gap:8px;letter-spacing:.2px}
.reward-cta:hover{opacity:.88;transform:translateY(-1px)}
.reward-cta:active{transform:translateY(0)}

.reward-dismiss{display:block;text-align:center;margin-top:14px;font-size:12px;color:var(--muted);cursor:pointer;transition:color .15s}
.reward-dismiss:hover{color:var(--text)}

/* ── Confetti canvas (page-level, for the old showCel path) ── */
#confettiCanvas{position:fixed;inset:0;pointer-events:none;z-index:99998}

/* ── Toast ── */
#toast{position:fixed;top:20px;left:50%;transform:translateX(-50%) translateY(-20px);background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg,14px);padding:11px 18px;font-size:13px;color:var(--text);box-shadow:0 8px 32px rgba(0,0,0,.5);z-index:99999;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;white-space:nowrap;display:flex;align-items:center;gap:8px;max-width:92vw}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast.g{border-color:rgba(var(--accent-rgb,0,255,136),.4);background:rgba(var(--accent-rgb,0,255,136),.08)}
#toast.r{border-color:rgba(255,95,109,.4);background:rgba(255,95,109,.08)}

/* ── Test toggle button ── */
.test-toggle-btn{display:inline-flex;align-items:center;gap:6px;background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.35);color:#fbbf24;border-radius:8px;padding:6px 12px;font-family:var(--font-body,'Inter',sans-serif);font-size:11px;font-weight:600;cursor:pointer;transition:all .2s;position:fixed;bottom:20px;right:20px;z-index:9990}
.test-toggle-btn:hover{background:rgba(245,158,11,.18)}

/* ── Payment Gateway Modal ── */
@keyframes pgwSlideUp{from{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}

.pgw-overlay{
  position:fixed;inset:0;z-index:10000;
  background:rgba(0,0,0,.7);
  backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .2s;
}
.pgw-overlay.open{opacity:1;pointer-events:all}

.pgw-modal{
  position:relative;
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:var(--radius-xl,20px);
  padding:36px 32px 28px;
  width:100%;max-width:440px;
  box-shadow:0 24px 80px rgba(0,0,0,.6);
  animation:pgwSlideUp .25s ease both;
}

.pgw-close{
  position:absolute;top:16px;right:16px;
  background:var(--surface,rgba(255,255,255,.06));
  border:1px solid var(--border);color:var(--muted);
  border-radius:var(--radius-md,10px);
  width:32px;height:32px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;transition:all .2s;
}
.pgw-close:hover{color:var(--text);border-color:var(--accent2)}

.pgw-eyebrow{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.9px;color:var(--accent2);
  display:flex;align-items:center;gap:6px;margin-bottom:10px;
}
.pgw-title{
  font-family:var(--font-heading,'Space Grotesk',sans-serif);
  font-size:22px;font-weight:800;margin-bottom:18px;
}

.pgw-plan-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(var(--accent-rgb,0,255,136),.08);
  border:1px solid rgba(var(--accent-rgb,0,255,136),.2);
  border-radius:999px;padding:7px 16px;
  font-size:12px;font-weight:600;color:var(--accent2);
  margin-bottom:24px;
}

.pgw-cards{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}

.pgw-card{
  width:100%;background:var(--surface,rgba(255,255,255,.04));
  border:1px solid var(--border);border-radius:var(--radius-lg,14px);
  cursor:pointer;text-align:left;
  transition:all .2s;overflow:hidden;
}
.pgw-card:hover:not(:disabled){
  border-color:var(--accent2);
  background:rgba(var(--accent-rgb,0,255,136),.05);
  transform:translateY(-1px);
}
.pgw-card:disabled{opacity:.55;cursor:not-allowed}

.pgw-card-inner{
  display:flex;align-items:center;gap:14px;
  padding:16px 18px;
}
.pgw-card-icon{
  width:48px;height:48px;border-radius:var(--radius-md,10px);
  background:rgba(255,255,255,.06);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.pgw-card-body{flex:1}
.pgw-card-title{font-size:14px;font-weight:700;margin-bottom:3px}
.pgw-card-desc{font-size:12px;color:var(--muted)}
.pgw-arrow{font-size:12px;color:var(--muted)}

.pgw-card-paypal .pgw-card-inner{padding:20px 18px}
.pgw-paypal-logo{
  height:28px;width:auto;
  object-fit:contain;
  flex-shrink:0;
  filter:brightness(0) invert(1);
  opacity:.9;
}

.pgw-card-loader{
  display:flex;align-items:center;justify-content:center;
  gap:10px;padding:16px 18px;
  font-size:13px;color:var(--muted);
}

.pgw-trust{
  display:flex;align-items:center;justify-content:center;
  gap:10px;flex-wrap:wrap;
  font-size:11px;color:var(--muted);
}
.pgw-trust i{color:var(--accent2);margin-right:3px}
.pgw-trust-sep{opacity:.3}

@media(max-width:600px){
  header{padding:12px 16px}
  main{padding:36px 16px 80px}
  .plan-card{padding:24px}
  .price-amt{font-size:44px}
  .pgw-modal{padding:28px 20px 22px;margin:16px}
  .pgw-title{font-size:19px}
}
