/* Whisperin — Components */

/* ===== Buttons (pill) ===== */
/* ABGCMO two-tier: flat glass nav CTA (8x22) is the base; .btn-lg is the tall textured hero CTA (12.8x48) */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;font-size:.875rem;padding:6px 22px;border-radius:var(--r-pill);transition:transform var(--dur-fast) var(--ease-spring),box-shadow var(--dur-base) var(--ease-standard),background var(--dur-base) var(--ease-standard),border-color var(--dur-base),filter var(--dur-base);white-space:nowrap;will-change:transform}
.btn-lg{padding:13px 48px;font-size:1.0625rem;font-weight:600}
/* Hero/section primary = bg.jpeg-textured pill, flat (no glow) */
.btn-primary{background:#3a0a18 url("../img/bg.jpeg") center/cover;color:#fff;border:1px solid rgba(255,255,255,.16);box-shadow:inset 0 1px 0 rgba(255,255,255,.14)}
.btn-primary:hover{transform:translateY(-1px);filter:brightness(1.08)}
.btn-primary:active{transform:translateY(0) scale(.99)}
/* Header nav CTA = flat white glass */
.btn-glass{background:var(--wi-glass-btn-bg);border:1px solid var(--wi-glass-btn-border);color:rgba(255,255,255,.96);backdrop-filter:blur(10px);box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 10px 24px rgba(0,0,0,.18)}
.btn-glass:hover{border-color:rgba(255,255,255,.32);transform:translateY(-1px);background:rgba(255,255,255,.12)}
.btn-ghost{color:var(--wi-text);border:1px solid transparent}
.btn-ghost:hover{color:var(--wi-accent)}
.btn-block{display:flex;width:100%}

/* ===== Proof chips ===== */
.chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-micro);color:var(--wi-text-muted);padding:6px 12px;border:1px solid var(--wi-border);border-radius:var(--r-pill);background:var(--wi-glass-btn-bg)}
.chip svg{width:13px;height:13px;color:var(--wi-accent)}
.status-chip{min-width:170px;justify-content:center;text-align:center}

/* ===== Header / nav ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:var(--z-header);background:transparent;border-bottom:0;backdrop-filter:none}
.site-header.scrolled{background:transparent;border-bottom:0;backdrop-filter:none}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.0625rem;letter-spacing:-.02em}
.brand .logo{width:26px;height:26px}
.nav-links{display:flex;align-items:center;gap:var(--s8)}
.nav-links a{font-size:var(--fs-sm);color:var(--wi-text-muted);transition:color var(--dur-fast)}
.nav-links a:hover,.nav-links a[aria-current]{color:var(--wi-text)}
.nav-actions{display:flex;align-items:center;gap:var(--s3)}
.nav-toggle{display:none;width:42px;height:42px;border-radius:10px;align-items:center;justify-content:center;border:1px solid var(--wi-border)}
.mobile-menu{display:none}
@media (max-width:860px){
  .nav-links,.nav-actions .btn-ghost{display:none}
  .nav-toggle{display:flex}
  .mobile-menu{display:block;position:fixed;inset:68px 0 auto 0;z-index:var(--z-dropdown);background:var(--wi-glass-strong);backdrop-filter:var(--wi-blur);border-bottom:1px solid var(--wi-border);padding:var(--s5) clamp(20px,5vw,40px);transform:translateY(-12px);opacity:0;pointer-events:none;transition:opacity var(--dur-base),transform var(--dur-base) var(--ease-decelerate)}
  .mobile-menu.open{opacity:1;transform:none;pointer-events:auto}
  .mobile-menu a{display:block;padding:14px 0;font-size:1.05rem;border-bottom:1px solid var(--wi-border)}
}

/* ===== Cards / glass ===== */
/* ABGCMO card: light-white glass, 20px radius, flat (no blur, no heavy shadow) */
.card{background:var(--wi-glass-bg);border:1px solid var(--wi-glass-border);border-radius:var(--r-card);padding:var(--s8);box-shadow:none;transition:transform var(--dur-base) var(--ease-emphasized),border-color var(--dur-base)}
.card:hover{transform:translateY(-2px);border-color:var(--wi-border-strong)}
.card .icon{width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(240,176,200,.18),rgba(232,145,178,.06));border:1px solid var(--wi-border-strong);color:var(--wi-accent);margin-bottom:var(--s5)}
.card h3{margin-bottom:var(--s4)}

/* ===== Faux-macOS window (product mockups) ===== */
.window{border-radius:var(--r-card-lg);border:1px solid var(--wi-glass-border);background:var(--wi-glass-strong);backdrop-filter:var(--wi-blur);overflow:hidden;box-shadow:0 16px 48px rgba(0,0,0,.35)}
.window-bar{display:flex;align-items:center;gap:7px;padding:13px 16px;border-bottom:1px solid var(--wi-glass-border);background:rgba(255,255,255,.04)}
.window-bar .tl{width:12px;height:12px;border-radius:50%}
.tl.red{background:var(--wi-tl-red)}.tl.yellow{background:var(--wi-tl-yellow)}.tl.green{background:var(--wi-tl-green)}
.window-bar .title{margin-left:10px;font-size:var(--fs-micro);color:var(--wi-text-subtle)}
.window-body{padding:var(--s6)}

/* ===== Stats ===== */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6);text-align:center}
.stat-num{font-size:var(--fs-stat);font-weight:700;line-height:1;color:#fff;text-shadow:0 2px 16px rgba(0,0,0,.4)}
.stat-label{font-size:var(--fs-sm);color:var(--wi-text-subtle);margin-top:var(--s3)}
@media (max-width:640px){.stats{grid-template-columns:1fr;gap:var(--s8)}}

/* ===== Output gallery (9:16) ===== */
.gallery{display:flex;gap:var(--s4);overflow-x:auto;padding:var(--s2) clamp(20px,5vw,40px);scroll-snap-type:x mandatory;-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);scrollbar-width:none}
.gallery::-webkit-scrollbar{display:none}
.gallery-card{position:relative;flex:0 0 auto;width:clamp(170px,22vw,230px);aspect-ratio:9/16;border-radius:var(--r-card);overflow:hidden;border:1px solid var(--wi-border);scroll-snap-align:center;background:linear-gradient(160deg,#3a1226,#1c0710)}
.gallery-card video,.gallery-card img{width:100%;height:100%;object-fit:cover}
.gallery-card .label{position:absolute;top:10px;left:10px;font-size:var(--fs-micro);font-weight:600;padding:4px 10px;border-radius:var(--r-pill);background:rgba(20,8,14,.6);backdrop-filter:blur(8px);border:1px solid var(--wi-glass-border)}
.gallery-card .ai-tag{position:absolute;bottom:10px;right:10px;font-size:10px;letter-spacing:.05em;padding:3px 8px;border-radius:var(--r-pill);background:rgba(0,0,0,.5);color:var(--wi-text-subtle);border:1px solid var(--wi-glass-border)}

/* ===== Feature blocks (2-col alternating) ===== */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:center}
.feature.reverse .feature-media{order:-1}
.feature-text h2{margin-bottom:var(--s6)}
.feature-text p{margin-top:var(--s5)}
.feature ul{margin-top:var(--s8);display:grid;gap:var(--s4)}
/* ABGCMO quiet bullet: flat 6px white dot, no glow */
.feature ul li{display:flex;align-items:center;gap:10px;font-size:.875rem;color:var(--wi-text-muted)}
.feature ul li::before{content:"";flex:0 0 auto;width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.3);box-shadow:none}
@media (max-width:900px){.feature{grid-template-columns:1fr;gap:var(--s8)}.feature.reverse .feature-media{order:0}}

/* ===== Steps ===== */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s8);counter-reset:step}
.step{position:relative;text-align:center;display:flex;flex-direction:column;align-items:center}
.step .num{counter-increment:step;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;background:rgba(255,255,255,.1);color:rgba(255,255,255,.8);margin:0 auto var(--s4)}
.step .num::before{content:counter(step)}
.step h3,.step p{width:100%}
.step h3{margin-bottom:var(--s3)}
@media (max-width:760px){.steps{grid-template-columns:1fr}}

/* ===== Testimonials ===== */
.testimonials{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;max-width:960px;margin-inline:auto;justify-items:center}
.testimonials .card{width:100%;max-width:292px;aspect-ratio:1/1;padding:28px 24px;border-radius:18px;display:flex;flex-direction:column}
.quote{font-size:1.125rem;color:rgba(255,255,255,.9);line-height:1.5}
.byline{margin-top:auto;padding-top:20px;font-size:var(--fs-sm);font-weight:600;color:rgba(255,255,255,.42);line-height:1.2}
.testimonials .metric-badge{margin-bottom:18px;align-self:flex-start;display:inline-flex;justify-content:flex-start;text-align:left;padding:8px 16px;min-height:34px;max-width:180px;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;color:rgba(255,255,255,.6);background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.18);border-radius:999px;white-space:normal;line-height:1.15}
@media (max-width:860px){
  .testimonials{grid-template-columns:1fr;max-width:320px}
  .testimonials .card{max-width:none}
}

/* ===== Pricing ===== */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6);align-items:stretch}
.plan{display:flex;flex-direction:column;position:relative}
.plan.popular{border-color:var(--wi-border-strong);box-shadow:var(--wi-shadow-card),0 0 0 1px var(--wi-accent) inset,var(--wi-glow)}
.plan .tag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);font-size:var(--fs-micro);font-weight:700;padding:5px 14px;border-radius:var(--r-pill);background:var(--wi-cta);color:#2a0a18}
.plan .price{font-size:2.75rem;font-weight:900;margin:var(--s3) 0}
.plan .price span{font-size:1rem;font-weight:500;color:var(--wi-text-muted)}
.plan .desc{color:var(--wi-text-muted);min-height:2.6em}
.plan ul{margin:var(--s6) 0;display:grid;gap:12px;flex:1}
.plan ul li{display:flex;gap:10px;font-size:var(--fs-sm);color:var(--wi-text-muted)}
.plan ul li svg{width:17px;height:17px;color:var(--wi-accent);flex:0 0 auto;margin-top:3px}
@media (max-width:860px){.pricing{grid-template-columns:1fr;max-width:420px;margin-inline:auto}}

/* ===== Toggle ===== */
.toggle{display:inline-flex;align-items:center;gap:4px;padding:5px;border-radius:var(--r-pill);border:1px solid var(--wi-border);background:var(--wi-glass-btn-bg);margin-inline:auto}
.toggle button{padding:8px 18px;border-radius:var(--r-pill);font-size:var(--fs-sm);font-weight:600;color:var(--wi-text-muted);transition:all var(--dur-base)}
.toggle button[aria-pressed=true]{background:var(--wi-cta);color:#2a0a18}
.save-badge{font-size:var(--fs-micro);color:var(--wi-success);font-weight:600}

/* ===== Accordion (FAQ) ===== */
.accordion{max-width:var(--reading);margin-inline:auto}
.acc-item{border-bottom:1px solid var(--wi-border)}
.acc-q{display:flex;justify-content:space-between;align-items:center;gap:16px;width:100%;text-align:left;padding:var(--s5) 0;font-weight:600;font-size:1.0625rem}
.acc-q .pm{flex:0 0 auto;transition:transform var(--dur-base) var(--ease-emphasized);color:var(--wi-accent)}
.acc-q[aria-expanded=true] .pm{transform:rotate(45deg)}
.acc-a{overflow:hidden;max-height:0;transition:max-height var(--dur-slow) var(--ease-standard)}
.acc-a p{padding-bottom:var(--s5);color:var(--wi-text-muted)}

/* ===== Trust band ===== */
.trust-band{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s6)}
.trust-item{display:flex;gap:12px;align-items:flex-start}
.trust-item svg{width:22px;height:22px;color:var(--wi-accent);flex:0 0 auto}
.trust-item h4{font-size:var(--fs-sm);font-weight:700;margin-bottom:4px}
.trust-item p{font-size:var(--fs-sm)}
@media (max-width:860px){.trust-band{grid-template-columns:1fr 1fr;gap:var(--s8)}}
@media (max-width:480px){.trust-band{grid-template-columns:1fr}}

/* ===== Final CTA ===== */
.cta-panel{text-align:center;padding:clamp(48px,8vw,96px) var(--s6);border-radius:var(--r-card-lg);border:1px solid var(--wi-border-strong);background:var(--wi-bg-glow);box-shadow:var(--wi-shadow-pop);position:relative;overflow:hidden}
.cta-panel h2{margin-bottom:var(--s4)}
.cta-plain{padding:clamp(36px,6vw,72px) 0}
.cta-plain h2{margin-bottom:var(--s4)}

/* ===== Footer ===== */
.site-footer{border-top:1px solid var(--wi-border);padding-block:var(--s16) var(--s10);margin-top:var(--s16)}
.footer-grid{display:grid;grid-template-columns:1.5fr repeat(4,1fr);gap:var(--s8)}
.footer-col h5{font-size:var(--fs-micro);text-transform:uppercase;letter-spacing:.08em;color:var(--wi-text-subtle);margin-bottom:var(--s4)}
.footer-col a{display:block;font-size:var(--fs-sm);color:var(--wi-text-muted);padding:5px 0;transition:color var(--dur-fast)}
.footer-col a:hover{color:var(--wi-text)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-top:var(--s12);padding-top:var(--s6);border-top:1px solid var(--wi-border);font-size:var(--fs-micro);color:var(--wi-text-subtle)}
@media (max-width:860px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.footer-grid{grid-template-columns:1fr}}

/* ===== Forms (onboarding/app) ===== */
.field{display:block;margin-bottom:var(--s5)}
.field label{display:block;font-size:var(--fs-sm);font-weight:600;margin-bottom:8px}
.field input,.field textarea,.field select{width:100%;padding:13px 16px;border-radius:14px;border:1px solid var(--wi-border-strong);background:rgba(0,0,0,.25);color:var(--wi-text);font:inherit;transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}
.field input:focus,.field textarea:focus{border-color:var(--wi-accent);box-shadow:0 0 0 3px rgba(240,176,200,.18)}
.option{display:flex;align-items:center;gap:14px;padding:18px 20px;border:1px solid var(--wi-border);border-radius:16px;background:var(--wi-glass-btn-bg);cursor:pointer;transition:all var(--dur-base) var(--ease-standard);margin-bottom:12px}
.option:hover{border-color:var(--wi-border-strong);transform:translateX(2px)}
.option.selected{border-color:var(--wi-accent);background:rgba(240,176,200,.10);box-shadow:var(--wi-glow)}
.option .radio{width:22px;height:22px;border-radius:50%;border:2px solid var(--wi-border-strong);flex:0 0 auto;display:flex;align-items:center;justify-content:center}
.option.selected .radio{border-color:var(--wi-accent)}
.option.selected .radio::after{content:"";width:11px;height:11px;border-radius:50%;background:var(--wi-cta)}

/* ===== Onboarding flow (ABGCMO glass system, Whisperin brand) ===== */
.ob-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:clamp(88px,12vh,128px) 20px 64px}
.ob-progress{width:100%;max-width:560px;height:4px;border-radius:99px;background:rgba(255,255,255,.1);margin-bottom:var(--s8);overflow:hidden}
.ob-progress>span{display:block;height:100%;width:25%;background:rgba(255,255,255,.7);border-radius:99px;transition:width var(--dur-slow) var(--ease-emphasized)}
.ob-card{width:100%;max-width:560px;background:var(--wi-glass-bg);border:1px solid var(--wi-glass-border);border-radius:var(--r-card-lg);padding:clamp(24px,4vw,40px);backdrop-filter:blur(16px)}
.ob-step{display:none}
.ob-step.active{display:block}
.ob-eyebrow{font-size:var(--fs-micro);text-transform:uppercase;letter-spacing:.04em;color:var(--wi-text-subtle);margin-bottom:var(--s2)}
.ob-card h1{font-size:clamp(1.5rem,3vw,2rem);margin-bottom:var(--s2)}
.ob-card .sub{color:var(--wi-text-muted);font-size:var(--fs-sm);margin-bottom:var(--s6)}
.ob-actions{display:flex;justify-content:space-between;align-items:center;gap:var(--s4);margin-top:var(--s8)}

/* ===== App shell (same ABGCMO glass system; NOT the noir app theme) ===== */
.app-shell{display:grid;grid-template-columns:var(--app-sidebar) 1fr;min-height:100vh}
.app-sidebar{border-right:1px solid var(--wi-glass-border);background:rgba(255,255,255,.03);padding:var(--s5) var(--s4);display:flex;flex-direction:column;gap:4px;position:sticky;top:0;height:100vh}
.app-sidebar .brand{margin-bottom:var(--s6);padding:0 8px}
.app-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;font-size:var(--fs-sm);color:var(--wi-text-muted);cursor:pointer;border:1px solid transparent;width:100%;text-align:left;transition:background var(--dur-fast),color var(--dur-fast)}
.app-nav-item:hover{background:rgba(255,255,255,.05);color:var(--wi-text)}
.app-nav-item[aria-current="true"]{background:rgba(255,255,255,.08);color:var(--wi-text);border-color:var(--wi-glass-border)}
.app-main{padding:clamp(20px,3vw,40px);width:100%;max-width:1080px}
.app-topbar{display:flex;align-items:center;justify-content:space-between;gap:var(--s4);margin-bottom:var(--s8)}
.app-view{display:none}
.app-view.active{display:block}
.gen-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--s4);margin-top:var(--s6)}
.gen-grid img{width:100%;aspect-ratio:9/16;object-fit:cover;border-radius:var(--r-card);border:1px solid var(--wi-glass-border)}
.app-textarea{width:100%;min-height:120px;padding:16px;border-radius:16px;border:1px solid var(--wi-glass-border);background:rgba(255,255,255,.04);color:var(--wi-text);font:inherit;resize:vertical}
.app-textarea:focus{border-color:var(--wi-border-strong);outline:none}
@media (max-width:760px){
  .app-shell{grid-template-columns:1fr}
  .app-sidebar{flex-direction:row;overflow-x:auto;border-right:none;border-bottom:1px solid var(--wi-glass-border);position:static;height:auto}
  .app-sidebar .brand{display:none}
}

/* ===================================================================
   v3 source-faithful (abgcmo) additions
   =================================================================== */

/* Hero: thin white headline + bold brand word (source h1 = 400 wt, ~56px, -0.5px) */
.hero-title{font-weight:400;font-size:clamp(2rem,4.2vw,3rem);letter-spacing:-.01em;line-height:1.07}
.hero-title strong{font-weight:700;color:var(--wi-text)}
.hero .lead{color:var(--wi-text-muted)}
.fw-semi{font-weight:600}
.fw-bold{font-weight:700}
.fw-standard{font-weight:400}

/* White-glass eyebrow (source eyebrow is white-tint, not rose) */
.eyebrow--glass{color:var(--wi-text-muted);background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.14)}
.eyebrow--glass .dot{background:rgba(255,255,255,.65);box-shadow:none}

/* Reel marquee (heading-less auto-scroll of 9:16 cards) */
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.marquee-track{display:flex;gap:var(--s4);width:max-content;will-change:transform;animation:reel-marquee 57.6s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.reel-card{flex:0 0 auto;width:clamp(247px,33.8vw,390px);aspect-ratio:9/16;border-radius:var(--r-card);border:1px solid var(--wi-glass-border);overflow:hidden;box-shadow:0 12px 30px rgba(0,0,0,.3);object-fit:cover;background:rgba(255,255,255,.04);display:block}
@keyframes reel-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Step media — ABGCMO 1:1 square, cover */
.step-media{aspect-ratio:1/1;border-radius:var(--r-card);overflow:hidden;border:1px solid var(--wi-glass-border);margin-bottom:var(--s5);background:rgba(255,255,255,.04)}
.step-media img{width:100%;height:100%;object-fit:cover}

/* Metric/proof badges (recreated; replaces source performance screenshots) */
.badge-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s3)}
.metric-badge{display:inline-flex;align-items:center;justify-content:center;padding:13px 14px;border-radius:var(--r-sm);background:var(--wi-glass-bg);border:1px solid var(--wi-border);font-weight:700;font-size:var(--fs-sm);color:var(--wi-text);backdrop-filter:var(--wi-blur)}
.testimonials .metric-badge{margin-bottom:var(--s4)}
.platform-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}

/* AI workflow media frame (holds workflow.jpg) */
.media-frame{border-radius:var(--r-card-lg);border:1px solid var(--wi-glass-border);background:rgba(255,255,255,.04);overflow:hidden;box-shadow:0 16px 48px rgba(0,0,0,.35)}
.media-frame img{width:100%;height:auto;object-fit:cover;display:block}

/* Performance proof — organic cluster of result screenshots (ABGCMO scatter) */
.perf-scatter{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;max-width:520px;margin-inline:auto}
.perf-scatter img{width:clamp(74px,9vw,104px);height:auto;border-radius:12px;border:1px solid var(--wi-glass-border);box-shadow:0 8px 20px rgba(0,0,0,.32);background:rgba(255,255,255,.04);transition:transform var(--dur-base) var(--ease-emphasized)}
.perf-scatter img:nth-child(3n){transform:rotate(-3deg)}
.perf-scatter img:nth-child(3n+1){transform:rotate(2.5deg)}
.perf-scatter img:nth-child(4n){transform:rotate(-1.5deg)}
.perf-scatter img:hover{transform:scale(1.07) rotate(0);position:relative;z-index:2}

/* Metric cards — source wraps each stat in a bordered glass card */
.stats>div{background:var(--wi-glass-bg);border:1px solid var(--wi-border);border-radius:var(--r-card);padding:var(--s10) var(--s6);backdrop-filter:var(--wi-blur)}

/* Minimal footer (source = © + Guides/Terms/Privacy on one row) */
.site-footer--minimal{padding-block:var(--s10)}
.footer-min{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--s4)}
.footer-copy{font-size:var(--fs-sm);color:var(--wi-text-subtle)}
.footer-links{display:flex;gap:var(--s6)}
.footer-links a{font-size:var(--fs-sm);color:var(--wi-text-muted);transition:color var(--dur-fast)}
.footer-links a:hover{color:var(--wi-text)}

@media (prefers-reduced-motion:reduce){
  .marquee-track{animation:none}
}

/* ===================================================================
   v5 journey-system components (modal, toast, studio workflow, paywall)
   Wine-glass idiom; existing tokens only; NO token changes (D1).
   Naming canonical: .modal-backdrop (scrim) + .modal-card (dialog).
   =================================================================== */

/* C1 — Modal + backdrop */
.modal-backdrop{position:fixed;inset:0;z-index:var(--z-modal);display:none;place-items:center;padding:20px;background:rgba(0,0,0,.62);backdrop-filter:blur(4px)}
.modal-backdrop.open{display:grid}
.modal-card{width:min(540px,100%);max-height:90vh;overflow:auto;background:var(--wi-glass-strong);backdrop-filter:var(--wi-blur);border:1px solid var(--wi-glass-border);border-radius:var(--r-card-lg);padding:clamp(24px,4vw,36px);box-shadow:var(--wi-shadow-pop)}
.modal-card h2{font-size:clamp(1.35rem,2.6vw,1.75rem);margin-bottom:var(--s3)}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--s4);margin-bottom:var(--s4)}
.modal-close{flex:0 0 auto;width:34px;height:34px;border-radius:50%;border:1px solid var(--wi-glass-border);color:var(--wi-text-muted);display:flex;align-items:center;justify-content:center;font-size:1.1rem;line-height:1}
.modal-close:hover{color:var(--wi-text);border-color:var(--wi-border-strong)}

/* C2 — Toast */
.toast-wrap{position:fixed;left:50%;bottom:28px;transform:translateX(-50%);z-index:var(--z-toast);display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}
.toast{pointer-events:auto;padding:11px 18px;border-radius:var(--r-pill);background:var(--wi-glass-strong);backdrop-filter:var(--wi-blur);border:1px solid var(--wi-glass-border);color:var(--wi-text);font-size:var(--fs-sm);box-shadow:var(--wi-shadow-card)}
.toast.error{border-color:var(--wi-danger);color:#ffd9d9}

/* C3 — Credit-meter pill */
.credit-pill{display:inline-flex;align-items:center;gap:7px;font-size:var(--fs-sm);font-weight:600;color:var(--wi-text-muted);padding:6px 14px;border:1px solid var(--wi-glass-border);border-radius:var(--r-pill);background:var(--wi-glass-btn-bg)}
.credit-pill::before{content:"◆";color:var(--wi-accent);font-size:.7em}
.credit-pill.low{color:var(--wi-warning);border-color:rgba(255,189,46,.4)}

/* C4 — Generation pipeline tracker */
.pipeline{display:flex;gap:8px;margin:var(--s5) 0}
.pipeline-step{flex:1;text-align:center;font-size:var(--fs-micro);color:var(--wi-text-subtle);padding:10px 4px;border:1px solid var(--wi-glass-border);border-radius:12px;background:var(--wi-glass-bg);transition:color var(--dur-base),border-color var(--dur-base),background var(--dur-base)}
.pipeline-step.is-active{color:var(--wi-text);border-color:var(--wi-border-strong);background:rgba(240,176,200,.08)}
.pipeline-step.is-done{color:var(--wi-accent);border-color:rgba(240,176,200,.3)}
.pipeline-step .pl-num{display:block;font-weight:700;font-size:.95rem;margin-bottom:2px}

/* C5 — Status chip variants (extend .chip) */
.chip.is-draft{color:var(--wi-text-subtle)}
.chip.is-ready{color:var(--wi-accent);border-color:rgba(240,176,200,.3)}
.chip.is-scheduled{color:#9ecbff;border-color:rgba(120,170,255,.3)}
.chip.is-published{color:var(--wi-success);border-color:rgba(34,197,94,.3)}
.chip.is-exported{color:var(--wi-text-muted)}
.chip.is-failed{color:#ffb4b4;border-color:rgba(239,68,68,.35)}

/* C6 — Persona tile */
.persona-tile{position:relative;border:1px solid var(--wi-glass-border);border-radius:var(--r-card);overflow:hidden;background:rgba(255,255,255,.04);cursor:pointer;transition:transform var(--dur-base) var(--ease-emphasized),border-color var(--dur-base)}
.persona-tile:hover{transform:translateY(-2px);border-color:var(--wi-border-strong)}
.persona-tile img{width:100%;aspect-ratio:1/1;object-fit:cover}
.persona-tile .pt-meta{padding:12px 14px}
.persona-tile .pt-name{font-weight:600;font-size:var(--fs-sm)}
.persona-tile .pt-niche{font-size:var(--fs-micro);color:var(--wi-text-subtle)}
.persona-tile.is-locked{opacity:.5}
.persona-tile.is-locked::after{content:"Upgrade to unlock";position:absolute;inset:auto 0 0 0;padding:8px;text-align:center;font-size:var(--fs-micro);background:rgba(0,0,0,.6)}

/* C7 — Review layout */
.review-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);gap:clamp(20px,4vw,40px);align-items:start}
.review-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:var(--s6)}
@media (max-width:760px){.review-grid{grid-template-columns:1fr}}

/* C8 — 9:16 video player */
.video-player{position:relative;aspect-ratio:9/16;width:100%;max-width:300px;margin-inline:auto;border-radius:var(--r-card);overflow:hidden;border:1px solid var(--wi-glass-border);background:linear-gradient(160deg,#3a1226,#1c0710)}
.video-player img,.video-player video{width:100%;height:100%;object-fit:cover}
.video-player .vp-play{position:absolute;inset:0;margin:auto;width:56px;height:56px;border-radius:50%;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);border:1px solid var(--wi-glass-border);display:flex;align-items:center;justify-content:center;color:#fff}
.video-player .ai-label{position:absolute;top:10px;left:10px;font-size:10px;letter-spacing:.04em;padding:4px 9px;border-radius:var(--r-pill);background:rgba(0,0,0,.55);color:var(--wi-text-muted);border:1px solid var(--wi-glass-border)}
.video-player .wm-badge{position:absolute;bottom:10px;right:10px;font-size:10px;padding:4px 9px;border-radius:var(--r-pill);background:rgba(0,0,0,.55);color:var(--wi-text-subtle);border:1px solid var(--wi-glass-border)}

/* Pricing / paywall helpers (reuse .plan, .toggle) */
.plan .period{font-size:1rem;font-weight:500;color:var(--wi-text-muted)}
.guarantee-band{display:flex;flex-wrap:wrap;gap:var(--s5) var(--s8);justify-content:center;margin-top:var(--s8);color:var(--wi-text-muted);font-size:var(--fs-sm)}
.guarantee-band .gi{display:flex;align-items:center;gap:8px}
.guarantee-band svg{width:16px;height:16px;color:var(--wi-accent);flex:0 0 auto}
.paywall-thumb{display:flex;align-items:center;gap:14px;padding:14px;border:1px solid var(--wi-glass-border);border-radius:var(--r-card);background:var(--wi-glass-bg);margin-bottom:var(--s6)}
.paywall-thumb .video-player{max-width:64px;margin:0}

/* Credit-depletion upgrade banner */
.upgrade-banner{display:flex;align-items:center;justify-content:space-between;gap:var(--s4);flex-wrap:wrap;padding:16px 20px;border:1px solid rgba(240,176,200,.3);border-radius:var(--r-card);background:rgba(240,176,200,.07);margin-bottom:var(--s6)}

/* Topbar plan badge + right cluster */
.plan-badge{font-size:var(--fs-micro);font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--wi-text-subtle);padding:5px 12px;border:1px solid var(--wi-glass-border);border-radius:var(--r-pill)}
.topbar-right{display:flex;align-items:center;gap:var(--s3);flex-wrap:wrap;justify-content:flex-end}

/* Consent / disclosure note (D10) */
.note-consent{font-size:var(--fs-micro);color:var(--wi-text-subtle);display:flex;gap:8px;align-items:flex-start;margin-top:var(--s4);padding:10px 12px;border:1px dashed var(--wi-glass-border);border-radius:12px}
