/* ============ NAZZEL APP DESIGN SYSTEM ============ */
:root{
  --paper:#F5F4EF; --paper-2:#EFEDE6; --card:#FFFFFF;
  --ink:#15140F; --ink-2:#4A4840; --muted:#8C887B;
  --line:rgba(20,19,15,.10); --line-2:rgba(20,19,15,.06);
  --accent:#7A2BFF; --accent-press:#6620D6; --accent-soft:rgba(122,43,255,.10);
  --lime:#DDF94F; --dark:#121211; --dark-2:#1B1A18; --on-dark:#F3F1EA; --on-dark-muted:#9C988B;
  /* status colors mapped to the 4-color palette: lime=success, purple=working, ink=stopped */
  --green:#5A6310; --green-soft:rgba(221,249,79,.42); --amber:#7A2BFF; --amber-soft:rgba(122,43,255,.10);
  --red:#15140F; --red-soft:rgba(20,19,15,.07);
  --radius:16px; --radius-sm:11px; --radius-lg:22px;
  --shadow-sm:0 1px 2px rgba(20,19,15,.06),0 2px 8px rgba(20,19,15,.04);
  --shadow:0 4px 14px rgba(20,19,15,.07),0 18px 50px -20px rgba(20,19,15,.18);
  --shadow-lg:0 30px 80px -28px rgba(20,19,15,.34);
  --font:'Sora',-apple-system,BlinkMacSystemFont,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --sidebar:248px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
html{scrollbar-gutter:stable}
body{font-family:var(--font);background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.5}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:#fff}
.mono{font-family:var(--mono)}
#root{height:100%}
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:rgba(20,19,15,.16);border-radius:10px;border:3px solid transparent;background-clip:content-box}
*::-webkit-scrollbar-thumb:hover{background:rgba(20,19,15,.28);background-clip:content-box}
.eyebrow{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.13em;text-transform:uppercase;color:var(--muted)}

/* ===== buttons ===== */
.btn{font-weight:700;font-size:14.5px;letter-spacing:-.01em;border:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;border-radius:11px;transition:transform .15s cubic-bezier(.2,.8,.2,1),background .15s,box-shadow .15s,color .15s,border-color .15s;white-space:nowrap}
.btn:active{transform:translateY(1px) scale(.99)}
.btn svg{flex:0 0 auto}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 1px 0 rgba(255,255,255,.25) inset,0 8px 20px -8px var(--accent)}
.btn-primary:hover{background:var(--accent-press);transform:translateY(-1px)}
.btn-ink{background:var(--ink);color:var(--paper)}
.btn-ink:hover{background:#000;transform:translateY(-1px)}
.btn-ghost{background:var(--card);color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{background:var(--paper-2);border-color:rgba(20,19,15,.2)}
.btn-soft{background:var(--accent-soft);color:var(--accent)}
.btn-soft:hover{background:rgba(122,43,255,.16)}
.btn-lime{background:var(--lime);color:#15140f}
.btn-lime:hover{filter:brightness(.97);transform:translateY(-1px)}
.btn-danger{background:#d33e1b;color:#fff}
.btn-danger:hover{background:#b8330f;transform:translateY(-1px)}
.btn:disabled{opacity:.55;pointer-events:none}
.iconbtn:disabled{opacity:.32;pointer-events:none}
/* transient toast */
.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%);z-index:120;background:var(--dark);color:var(--on-dark);font-family:var(--font);font-size:13.5px;font-weight:600;padding:11px 18px;border-radius:999px;box-shadow:var(--shadow-lg);animation:fade .2s ease}
.btn-lg{padding:14px 22px;font-size:15.5px;border-radius:12px}
.btn-sm{padding:8px 13px;font-size:13px;border-radius:9px}
.btn-block{width:100%}
.btn[disabled]{opacity:.45;pointer-events:none}

/* ===== inputs ===== */
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:13px;font-weight:600;color:var(--ink-2)}
.input{background:var(--card);border:1px solid var(--line);border-radius:11px;padding:12px 14px;font-size:14.5px;color:var(--ink);transition:border-color .15s,box-shadow .15s;width:100%}
.input::placeholder{color:var(--muted)}
.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238C887B' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.input-wrap{position:relative;display:flex;align-items:center}
.input-wrap .ic{position:absolute;left:13px;color:var(--muted);display:flex;pointer-events:none}
.input-wrap .input{padding-left:40px}
.help{font-size:12.5px;color:var(--muted);line-height:1.45}

/* ===== generic ===== */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:5px 10px;border-radius:999px;white-space:nowrap}
.pill.green{background:var(--green-soft);color:var(--green)}
.pill.amber{background:var(--amber-soft);color:var(--amber)}
.pill.blue{background:var(--accent-soft);color:var(--accent)}
.pill.gray{background:var(--paper-2);color:var(--ink-2)}
.pill.red{background:var(--red-soft);color:var(--red)}
.pill.lime{background:rgba(221,249,79,.4);color:#5a6310}
.pill .d{width:6px;height:6px;border-radius:50%;background:currentColor}
.spin{animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.fade-in{animation:fade .18s ease-out both}
@keyframes fade{from{opacity:.6;transform:translateY(5px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.fade-in{animation:none}}
.brandmark{width:30px;height:30px;border-radius:9px;background:var(--accent);display:grid;place-items:center;flex:0 0 auto;box-shadow:0 4px 12px -3px var(--accent)}
.brandmark svg{width:14px;height:14px}
.wordmark{font-weight:800;font-size:20px;letter-spacing:-.03em;display:flex;align-items:center;gap:10px}
/* logo: keep native 1203x239 (≈5.03:1) ratio EXACTLY — fixed height, width:auto, never
   stretched/squeezed. object-fit:contain guards against any flex container squashing it.
   crisp downscale on HiDPI screens. */
.app-logo{height:30px;width:auto;max-width:100%;object-fit:contain;display:block;image-rendering:-webkit-optimize-contrast;flex:0 0 auto}
.app-logo.inv{filter:brightness(0) invert(1)}
.auth-brand .app-logo{height:32px}

/* ===== AUTH ===== */
.auth{display:grid;grid-template-columns:1fr 1fr;height:100%}
.auth-brand{background:var(--dark);color:var(--on-dark);padding:48px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.auth-brand .wordmark{color:#fff}
.auth-brand .blob{position:absolute;border-radius:50%;filter:blur(70px)}
.auth-brand .blob.a{width:300px;height:300px;background:rgba(122,43,255,.55);top:-60px;right:-40px}
.auth-brand .blob.b{width:240px;height:240px;background:rgba(221,249,79,.18);bottom:-60px;left:-40px}
.auth-brand h1{font-size:34px;font-weight:800;letter-spacing:-.025em;line-height:1.08;position:relative;max-width:380px}
.auth-brand .lede{color:var(--on-dark-muted);font-size:15.5px;margin-top:16px;position:relative;max-width:360px}
.auth-reels{display:flex;gap:12px;position:relative;margin-top:30px}
.auth-reel{flex:1;aspect-ratio:9/15;border-radius:14px;position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}
.auth-reel .cap{position:absolute;left:9px;right:9px;bottom:9px;font-size:11px;font-weight:700;color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.6)}
.auth-proof{display:flex;align-items:center;gap:10px;position:relative;color:var(--on-dark-muted);font-size:13px}
.auth-form-wrap{display:flex;align-items:center;justify-content:center;padding:48px}
.auth-form{width:100%;max-width:360px}
.auth-form h2{font-size:26px;font-weight:800;letter-spacing:-.02em}
.auth-form .sub{color:var(--ink-2);font-size:14.5px;margin-top:6px}
.auth-google{margin-top:24px}
.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--muted);font-size:12px}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:1px;background:var(--line)}
.auth-fields{display:flex;flex-direction:column;gap:14px}
.auth-toggle{text-align:center;margin-top:20px;font-size:13.5px;color:var(--ink-2)}
.auth-toggle b{color:var(--accent);cursor:pointer;font-weight:700}

/* ===== ONBOARDING ===== */
/* height:100dvh (not %) so the wizard always fills the viewport even if an ancestor's height
   resolves to auto — otherwise .ob collapses, the sticky footer renders below the fold, and the
   Continue button becomes unreachable. min-height keeps it filling; the column scrolls internally. */
.ob{height:100dvh;min-height:100dvh;overflow-y:auto;display:flex;flex-direction:column;background:var(--paper)}
.ob-top{position:sticky;top:0;z-index:20;background:rgba(245,244,239,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.ob-top-inner{max-width:860px;margin:0 auto;padding:16px 28px;display:flex;align-items:center;gap:18px}
.ob-prog{flex:1;height:7px;background:var(--paper-2);border-radius:999px;overflow:hidden;border:1px solid var(--line-2)}
.ob-prog i{display:block;height:100%;background:var(--accent);border-radius:999px;transition:width .4s cubic-bezier(.2,.8,.2,1)}
.ob-step-lbl{font-family:var(--mono);font-size:12px;color:var(--muted);white-space:nowrap}
.ob-exit{font-size:13px;color:var(--muted);font-weight:600}
.ob-exit:hover{color:var(--ink)}
.ob-body{flex:1;max-width:860px;width:100%;margin:0 auto;padding:44px 28px 48px}
.ob-head{margin-bottom:30px}
.ob-head .eyebrow{color:var(--accent)}
.ob-head h2{font-size:30px;font-weight:800;letter-spacing:-.02em;margin:10px 0 8px}
.ob-head p{color:var(--ink-2);font-size:15.5px;max-width:560px}
.ob-foot{position:sticky;bottom:0;z-index:20;margin-top:auto;background:rgba(245,244,239,.92);backdrop-filter:blur(12px);border-top:1px solid var(--line)}
.ob-foot-inner{max-width:860px;margin:0 auto;padding:16px 28px;display:flex;align-items:center;justify-content:space-between;gap:14px}
.ob-foot .sel-note{font-size:13px;color:var(--muted)}

/* step 1 tabs + presets + custom */
.ob-title-row{display:flex;align-items:center;flex-wrap:wrap;gap:0}
.badge-step{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);padding:5px 10px;border-radius:999px;margin-left:14px;align-self:center}
.badge-opt{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#5a6310;background:rgba(221,249,79,.5);padding:3px 8px;border-radius:999px;margin-left:8px}
.ob-tabs{display:inline-flex;background:var(--paper-2);border:1px solid var(--line);border-radius:12px;padding:4px;gap:4px;margin-bottom:24px}
.ob-tabs button{border:none;background:none;font-family:var(--font);font-weight:700;font-size:14px;color:var(--ink-2);padding:9px 22px;border-radius:9px;cursor:pointer;transition:background .15s,color .15s,box-shadow .15s}
.ob-tabs button.on{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}
.preset-list{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.preset{display:flex;align-items:center;gap:13px;background:var(--card);border:2px solid var(--line);border-radius:13px;padding:15px 17px;cursor:pointer;transition:border-color .15s,box-shadow .15s,background .15s}
.preset:hover{border-color:rgba(20,19,15,.2)}
.preset.on{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 3px var(--accent-soft)}
.preset .pt{flex:1;min-width:0}
.preset .pt b{font-size:15px;font-weight:700;display:block}
.preset .pt span{font-size:12.5px;color:var(--muted);line-height:1.4}
.preset .pck{width:24px;height:24px;border-radius:50%;border:2px solid var(--line);flex:0 0 auto;display:grid;place-items:center;color:#fff;transition:background .15s,border-color .15s}
.preset .pck svg{opacity:0;transition:opacity .15s}
.preset.on .pck{background:var(--accent);border-color:var(--accent)}
.preset.on .pck svg{opacity:1}
.ob-textarea{width:100%;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:13px 14px;font-size:14.5px;font-family:var(--font);color:var(--ink);line-height:1.5;resize:vertical}
.ob-textarea::placeholder{color:var(--muted)}
.ob-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}

/* onboarding misc — music check, badges, note */
.voice .mck{width:24px;height:24px;border-radius:50%;border:2px solid var(--line);display:grid;place-items:center;color:#fff;flex:0 0 auto}
/* branded language dropdown */
.lang-dd{position:relative}
.lang-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--card);border:1px solid var(--line);border-radius:11px;padding:12px 14px;font-size:14.5px;font-weight:600;color:var(--ink);cursor:pointer;font-family:var(--font);transition:border-color .15s,box-shadow .15s}
.lang-trigger:hover{border-color:rgba(20,19,15,.2)}
.lang-trigger .chev{color:var(--muted);transition:transform .18s}
.lang-trigger .chev.up{transform:rotate(180deg)}
.lang-backdrop{position:fixed;inset:0;z-index:30}
.lang-menu{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:31;background:var(--card);border:1px solid var(--line);border-radius:13px;box-shadow:var(--shadow-lg);padding:6px;max-height:320px;overflow-y:auto}
.lang-item{width:100%;display:flex;align-items:center;gap:9px;background:none;border:none;font-family:var(--font);font-size:14px;font-weight:500;color:var(--ink-2);padding:10px 10px;border-radius:9px;cursor:pointer;text-align:left;transition:background .12s,color .12s}
.lang-item:hover{background:var(--paper-2);color:var(--ink)}
.lang-item.on{background:var(--accent-soft);color:var(--accent);font-weight:700}
.lang-item .lchk{width:16px;display:inline-flex;justify-content:center;flex:0 0 auto;color:var(--accent)}
/* step 3 custom music */
.music-custom{display:flex;flex-direction:column}
.cm-label{font-size:14px;font-weight:700;color:var(--ink);margin-bottom:8px}
.cm-label span{font-weight:500;color:var(--muted);font-size:12.5px}
.dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;text-align:center;border:1.5px dashed var(--line);border-radius:13px;padding:30px 20px;cursor:pointer;color:var(--muted);transition:border-color .15s,background .15s}
.dropzone:hover{border-color:var(--accent);background:var(--accent-soft)}
.dropzone b{color:var(--ink);font-size:14px;font-weight:600}
.dropzone span{font-size:12px;color:var(--muted)}
.cm-files{display:flex;flex-direction:column;gap:7px;margin-top:12px}
.cm-file{display:flex;align-items:center;gap:9px;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:9px 12px;font-size:13.5px;color:var(--ink)}
.cm-file span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cm-file button{background:none;border:none;color:var(--muted);cursor:pointer;display:flex;padding:2px}
.cm-file button:hover{color:var(--accent)}
.req{font-size:10px;font-weight:700;color:var(--accent);background:var(--accent-soft);padding:2px 8px;border-radius:999px;margin-left:8px;letter-spacing:.02em}
.voice-empty{padding:18px;border:1px dashed var(--line);border-radius:12px;color:var(--muted);font-size:13.5px;background:var(--paper-2)}
.voice.skel{pointer-events:none}
.skel-c,.skel-b,.skel-s{display:block;background:linear-gradient(90deg,var(--paper-2) 25%,rgba(0,0,0,.05) 37%,var(--paper-2) 63%);background-size:400% 100%;animation:shim 1.3s ease infinite;border-radius:6px}
.skel-c{width:34px;height:34px;border-radius:50%}
.skel-b{width:120px;height:11px;margin-bottom:7px}
.skel-s{width:200px;height:9px}
@keyframes shim{0%{background-position:100% 0}100%{background-position:-100% 0}}
.vg{font-size:10px;font-weight:700;padding:2px 7px;border-radius:999px;margin-left:8px;vertical-align:middle;border:1px solid}
.vg.m{color:#2a5fd6;background:rgba(42,95,214,.1);border-color:rgba(42,95,214,.25)}
.vg.f{color:#d6357a;background:rgba(214,53,122,.1);border-color:rgba(214,53,122,.25)}
.voice.on .mck{background:var(--accent);border-color:var(--accent)}
.badge-opt2{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#5a6310;background:rgba(221,249,79,.5);padding:5px 10px;border-radius:999px;margin-left:12px;align-self:center}
.fxbadge{font-family:var(--mono);font-size:8.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:2px 7px;border-radius:999px;margin-left:8px;vertical-align:middle}
.fxbadge.new{color:var(--accent);background:var(--accent-soft)}
.fxbadge.prem{color:#E8820C;background:rgba(232,130,12,.13)}
.note-box{margin-top:18px;background:var(--paper-2);border:1px solid var(--line);border-radius:12px;padding:14px 16px;font-size:13px;color:var(--ink-2);line-height:1.5}
.note-box b{color:var(--ink)}

/* step 4 — visual style preview cards */
.style-grid{display:flex;gap:16px;overflow-x:auto;padding:4px 2px 12px;scrollbar-width:none;-ms-overflow-style:none;scroll-snap-type:x proximity}
.style-grid::-webkit-scrollbar{display:none}
.style-item{flex:0 0 auto;width:200px;cursor:pointer;scroll-snap-align:start}
.stylecard{position:relative;aspect-ratio:9/16;border-radius:15px;overflow:hidden;border:2px solid transparent;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s,border-color .15s}
.style-item:hover .stylecard{transform:translateY(-4px);box-shadow:var(--shadow)}
.stylecard.on{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft),var(--shadow)}
.stylecard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.stylecard .nz{position:absolute;inset:0}
.stylecard .grain{position:absolute;inset:0;opacity:.4;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.stylecard .vig{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.68),transparent 55%)}
.stylecard .motif{position:absolute;top:14%;left:0;right:0;text-align:center;font-size:42px;line-height:1;filter:drop-shadow(0 6px 14px rgba(0,0,0,.5))}
.stylecard .play{position:absolute;top:43%;left:50%;transform:translate(-50%,-50%);width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.28);border:1.5px solid rgba(255,255,255,.5);display:grid;place-items:center}
.stylecard .scap{position:absolute;left:10px;right:10px;bottom:11px;color:#fff;font-weight:700;font-size:11px;line-height:1.12;text-shadow:0 2px 8px rgba(0,0,0,.6)}
.stylecard .sck{position:absolute;top:8px;right:8px;width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;display:none;place-items:center;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.stylecard.on .sck{display:grid}
.sname{text-align:center;font-size:13px;font-weight:700;margin-top:9px;color:var(--ink)}

/* step 5 — caption preview cards */
.cap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cap-card{cursor:pointer}
.cap-prev{aspect-ratio:16/9;background:linear-gradient(to bottom,#444,#777);border:2px solid var(--line);border-radius:14px;position:relative;overflow:hidden;transition:border-color .15s,box-shadow .15s}
.cap-card:hover .cap-prev{border-color:rgba(20,19,15,.25)}
.cap-card.on .cap-prev{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.cap-ck{position:absolute;top:8px;right:8px;width:22px;height:22px;border-radius:50%;background:var(--accent);display:none;place-items:center;color:#fff;z-index:2}
.cap-card.on .cap-ck{display:grid}
.cap-name{text-align:left;font-size:14.5px;font-weight:600;margin-top:10px;color:var(--ink)}
/* self-hosted caption fonts (exact competitor) */
@font-face{font-family:'The Bold Font';src:url('../fonts/theboldfont.woff') format('woff');font-weight:700;font-display:swap}
@font-face{font-family:'Komika Axis';src:url('../fonts/komikaxis.woff') format('woff');font-weight:400 900;font-display:swap}
/* render caption full-size then scale 0.25 (exact competitor technique) */
.cap-scale{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;overflow:hidden}
.cap-full{transform:scale(.35);transform-origin:center center;white-space:nowrap;line-height:1.08;display:flex;flex-wrap:nowrap;gap:0 .25em;align-items:center;justify-content:center;text-align:center}
/* no bounce — styles switch instantly. Sleek = continuous orbit (outer) + horizontal flip per word (inner) */
.cap-orbit{display:flex;align-items:center;justify-content:center;transform-origin:center center;animation:capOrbit 1.6s linear infinite}
@keyframes capOrbit{0%{transform:scale(.35) translate(9px,0)}25%{transform:scale(.35) translate(0,9px)}50%{transform:scale(.35) translate(-9px,0)}75%{transform:scale(.35) translate(0,-9px)}100%{transform:scale(.35) translate(9px,0)}}
.cap-line{white-space:nowrap;line-height:1.08;display:flex;flex-wrap:nowrap;gap:0 .25em;align-items:center;justify-content:center;text-align:center}
.cap-stack{flex-direction:column;gap:0}
@keyframes capFlip2{0%{transform:scaleX(.12);opacity:.35}55%{transform:scaleX(1.04);opacity:1}100%{transform:scaleX(1);opacity:1}}
.cap-flip2{animation:capFlip2 .45s ease-out}

/* step 6 — effects toggle cards */
.fxcard{display:flex;align-items:flex-start;gap:14px;background:var(--card);border:2px solid var(--line);border-radius:13px;padding:16px 18px;cursor:pointer;transition:border-color .15s,background .15s}
.fxcard.on{border-color:var(--accent);background:var(--accent-soft)}
.fxcard .fxic{width:42px;height:42px;border-radius:11px;background:var(--paper-2);color:var(--ink-2);display:grid;place-items:center;flex:0 0 auto;margin-top:1px}
.fxcard.on .fxic{background:var(--accent);color:#fff}
.fxcard .ct b{font-size:15px;font-weight:700}
.fxrow{display:flex;align-items:flex-start;gap:14px}
.fxhead{display:flex;align-items:center;gap:8px}
.fxhead .fxbadge{margin-left:0}
.fxdesc{display:block;margin-top:3px;font-size:13px;color:var(--muted);line-height:1.4}
.fxmodel{margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.fxmodel-lbl{font-size:12.5px;font-weight:600;color:var(--muted);margin-bottom:8px}
.cred{color:var(--muted);font-weight:500;font-size:13px;margin-left:8px}
.tk-toggle2{width:44px;height:25px;border-radius:999px;background:var(--line);position:relative;flex:0 0 auto;transition:background .15s}
.tk-toggle2.on{background:var(--accent)}
.tk-toggle2::after{content:"";position:absolute;top:3px;left:3px;width:19px;height:19px;border-radius:50%;background:#fff;transition:transform .15s}
.tk-toggle2.on::after{transform:translateX(19px)}

/* selection grids */
.sel-grid{display:grid;gap:14px}
.sel-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.sel-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.sel-grid.cols-2{grid-template-columns:repeat(2,1fr)}

/* visual niche/style card */
.vcard{position:relative;border-radius:14px;overflow:hidden;cursor:pointer;aspect-ratio:1/1;border:2px solid transparent;transition:transform .18s,box-shadow .18s;box-shadow:var(--shadow-sm)}
.vcard .nz{position:absolute;inset:0}
.vcard .grain{position:absolute;inset:0;opacity:.4;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.vcard .shade{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.62),transparent 55%)}
.vcard .lbl{position:absolute;left:12px;right:12px;bottom:11px;color:#fff;font-weight:800;font-size:14.5px;line-height:1.1;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.vcard:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.vcard.on{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft),var(--shadow)}
.vcard .ck{position:absolute;top:9px;right:9px;width:24px;height:24px;border-radius:50%;background:var(--accent);color:#fff;display:none;place-items:center;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.vcard.on .ck{display:grid}
.vcard.dashed{background:var(--card);border:2px dashed var(--line);box-shadow:none;display:grid;place-items:center;text-align:center}
.vcard.dashed:hover{border-color:var(--accent)}
.vcard.dashed.on{border-style:solid;border-color:var(--accent)}
.vcard.dashed .ic{width:38px;height:38px;border-radius:11px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;margin:0 auto 8px}
.vcard.dashed .cl{font-weight:800;font-size:13.5px}

/* option list card (format/voice/etc) */
.opt{display:flex;align-items:flex-start;gap:14px;background:var(--card);border:2px solid var(--line);border-radius:13px;padding:16px 18px;cursor:pointer;transition:border-color .15s,box-shadow .15s,background .15s}
.opt:hover{border-color:rgba(20,19,15,.2)}
.opt.on{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 3px var(--accent-soft)}
.opt .oic{width:40px;height:40px;border-radius:11px;background:var(--paper-2);color:var(--ink-2);display:grid;place-items:center;flex:0 0 auto}
.opt.on .oic{background:var(--accent);color:#fff}
.opt .otx{flex:1;min-width:0}
.opt .otx b{font-size:15px;font-weight:700;display:block}
.opt .otx span{font-size:13px;color:var(--muted);line-height:1.45}
.opt .oradio{width:22px;height:22px;border-radius:50%;border:2px solid var(--line);flex:0 0 auto;display:grid;place-items:center;margin-top:8px}
.opt.on .oradio{border-color:var(--accent)}
.opt.on .oradio::after{content:"";width:11px;height:11px;border-radius:50%;background:var(--accent)}

/* sub-section block (step 5/6) */
.ob-block{margin-bottom:30px}
.ob-block .bh{display:flex;align-items:center;gap:9px;font-size:15px;font-weight:800;margin-bottom:5px}
.ob-block .bh .bn{width:24px;height:24px;border-radius:7px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;flex:0 0 auto}
.ob-block .bhelp{font-size:13px;color:var(--muted);margin-bottom:14px}

/* voice row with preview */
.voice-list{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.voice{display:flex;align-items:center;gap:12px;background:var(--card);border:2px solid var(--line);border-radius:12px;padding:12px 14px;cursor:pointer;transition:border-color .15s,background .15s}
.voice.on{border-color:var(--accent);background:var(--accent-soft)}
.voice .play{width:34px;height:34px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;flex:0 0 auto;border:none}
.voice.playing .play{background:var(--accent)}
.voice .vt{flex:1;min-width:0}
.voice .vt b{font-size:14px;font-weight:700;display:block}
.voice .vt span{font-size:12px;color:var(--muted)}
.voice .wave{display:flex;align-items:center;gap:2px;height:18px}
.voice .wave i{width:2.5px;background:var(--muted);border-radius:2px;height:30%}
.voice.playing .wave i{background:var(--accent);animation:wv .7s ease-in-out infinite alternate}
.voice.playing .wave i:nth-child(2){animation-delay:.1s}.voice.playing .wave i:nth-child(3){animation-delay:.2s}.voice.playing .wave i:nth-child(4){animation-delay:.3s}.voice.playing .wave i:nth-child(5){animation-delay:.15s}
@keyframes wv{to{height:100%}}

/* connect (step 7) */
.acct-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center;border:1.5px dashed var(--line);border-radius:14px;padding:40px 24px}
.acct-empty p{color:var(--muted);font-size:14.5px;margin:0}
.acct-empty .btn{display:inline-flex;align-items:center;gap:7px}
.connect-list{display:flex;flex-direction:column;gap:12px}
.conn{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:13px;padding:16px 18px}
.conn .cic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;color:#fff;flex:0 0 auto}
.conn .ct{flex:1;min-width:0}
.conn .ct b{font-size:15px;font-weight:700;display:block}
.conn .ct span{font-size:13px;color:var(--muted)}
.manual-opt{display:flex;align-items:center;gap:14px;border:2px dashed var(--line);border-radius:13px;padding:16px 18px;cursor:pointer;margin-top:6px;transition:border-color .15s,background .15s}
.manual-opt.on{border-style:solid;border-color:var(--accent);background:var(--accent-soft)}
.manual-opt .mic{width:42px;height:42px;border-radius:11px;background:var(--paper-2);color:var(--ink-2);display:grid;place-items:center;flex:0 0 auto}
.manual-opt.on .mic{background:var(--accent);color:#fff}

/* ===== BUILDING SCREEN ===== */
.build{min-height:100%;display:grid;place-items:center;padding:40px 24px;background:var(--paper)}
.build-inner{display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:center;max-width:760px;width:100%}
.build-phone{width:230px;aspect-ratio:9/17;border-radius:30px;background:var(--dark);padding:7px;box-shadow:var(--shadow-lg);position:relative}
.build-screen{width:100%;height:100%;border-radius:24px;overflow:hidden;position:relative}
.build-screen .grain{position:absolute;inset:0;opacity:.4;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='90' height='90'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.build-screen .shimmer{position:absolute;inset:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.14) 50%,transparent 70%);background-size:220% 100%;animation:shim 1.6s linear infinite}
@keyframes shim{from{background-position:200% 0}to{background-position:-120% 0}}
.build-screen .bcap{position:absolute;left:12px;right:12px;bottom:42px;color:#fff;font-weight:800;font-size:16px;line-height:1.05;text-shadow:0 2px 10px rgba(0,0,0,.5)}
.build-screen .bcap em{font-style:normal;color:var(--lime)}
.build-screen .bbadge{position:absolute;top:12px;left:12px}
.build-txt{max-width:380px}
.build-txt .eyebrow{color:var(--accent)}
.build-txt h2{font-size:27px;font-weight:800;letter-spacing:-.02em;margin:10px 0 6px}
.build-txt p{color:var(--ink-2);font-size:14.5px}
.build-bar{height:8px;background:var(--paper-2);border-radius:999px;overflow:hidden;margin:22px 0;border:1px solid var(--line-2)}
.build-bar i{display:block;height:100%;background:var(--accent);border-radius:999px;transition:width .5s ease}
.build-list{display:flex;flex-direction:column;gap:13px}
.build-list .bi{display:flex;align-items:center;gap:12px;font-size:14.5px;font-weight:600;color:var(--muted);transition:color .3s}
.build-list .bi.active{color:var(--ink)}
.build-list .bi.done{color:var(--ink)}
.build-list .bdot{width:24px;height:24px;border-radius:50%;border:2px solid var(--line);display:grid;place-items:center;flex:0 0 auto;background:var(--card)}
.build-list .bi.done .bdot{background:var(--green);border-color:var(--green);color:#fff}
.build-list .bi.active .bdot{border-color:var(--accent);color:var(--accent)}

/* ===== DASHBOARD SHELL ===== */
.shell{display:grid;grid-template-columns:var(--sidebar) 1fr;height:100%}
.side{background:var(--card);border-right:1px solid var(--line);display:flex;flex-direction:column;height:100%;overflow:hidden}
.side-top{padding:18px 16px 14px;display:flex;align-items:center;justify-content:center}
.side-top .app-logo{height:30px}
.side-new{margin:0 14px 12px}
.side-nav{flex:1;overflow-y:auto;padding:4px 12px}
.side-sec{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:14px 12px 7px}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;font-size:14px;font-weight:600;color:var(--ink-2);cursor:pointer;transition:background .12s,color .12s;border:none;background:none;width:100%;text-align:left}
.nav-item svg{flex:0 0 auto;opacity:.8}
.nav-item:hover{background:var(--paper-2);color:var(--ink)}
.nav-item.on{background:var(--accent);color:#fff}
.nav-item.on svg{opacity:1}
.nav-item .badge{margin-left:auto;font-size:11px;font-weight:700;background:var(--paper-2);color:var(--ink-2);padding:2px 7px;border-radius:999px}
.nav-item.on .badge{background:rgba(255,255,255,.22);color:#fff}
.side-wallet{margin:12px;border:1px solid var(--line);border-radius:14px;padding:14px;background:linear-gradient(160deg,var(--paper),var(--paper-2))}
.side-wallet .wrow{display:flex;align-items:center;justify-content:space-between;font-size:12.5px;color:var(--ink-2)}
.side-wallet .wrow b{font-size:14px;color:var(--ink);font-weight:800}
.side-wallet .wrow+.wrow{margin-top:7px}

/* main */
.main{display:flex;flex-direction:column;height:100%;overflow:hidden}
.topbar{height:64px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 26px;background:rgba(245,244,239,.7);backdrop-filter:blur(10px);flex:0 0 auto}
.topbar .tb-title{font-size:18px;font-weight:800;letter-spacing:-.02em}
.topbar .tb-right{display:flex;align-items:center;gap:14px}
.nav-toggle{display:none;align-items:center;justify-content:center;background:transparent;border:none;color:var(--ink);cursor:pointer;padding:6px;border-radius:9px}
.nav-toggle:hover{background:var(--paper-2)}
.wallet-chip{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:7px 8px 7px 14px}
.wallet-chip .wc{font-size:12px;color:var(--muted);line-height:1.1}
.wallet-chip .wc b{display:block;font-size:14px;font-weight:800;color:var(--ink)}
.wallet-chip .sepv{width:1px;height:26px;background:var(--line)}
.uava{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#7A2BFF,#B23DFF);color:#fff;display:grid;place-items:center;font-weight:800;font-size:14px;flex:0 0 auto}
.content{flex:1;overflow-y:auto;padding:30px 36px 60px}
.content-inner{max-width:1080px;margin:0 auto}

/* page head */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.page-head h1{font-size:25px;font-weight:800;letter-spacing:-.02em}
.page-head p{color:var(--ink-2);font-size:14px;margin-top:3px}
.page-actions{display:flex;gap:10px}

/* overview */
.greet{font-size:24px;font-weight:800;letter-spacing:-.02em}
.greet span{color:var(--muted);font-weight:600}
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:22px 0}
.scard{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:var(--shadow-sm)}
.scard .sl{font-size:12.5px;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:7px}
.scard .sl svg{color:var(--accent)}
.scard .sv{font-size:28px;font-weight:800;letter-spacing:-.02em;margin-top:8px}
.scard .ss{font-size:12px;color:var(--muted);margin-top:3px}
.next-action{display:flex;align-items:center;gap:18px;background:var(--ink);color:var(--on-dark);border-radius:16px;padding:22px 24px;margin-bottom:22px}
.next-action .nic{width:48px;height:48px;border-radius:13px;background:rgba(221,249,79,.16);color:var(--lime);display:grid;place-items:center;flex:0 0 auto}
.next-action .nt{flex:1}
.next-action .nt b{font-size:16px;font-weight:800;color:#fff;display:block}
.next-action .nt span{font-size:13.5px;color:var(--on-dark-muted)}
.grid-2{display:grid;grid-template-columns:1.4fr 1fr;gap:20px}
.panel{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:var(--shadow-sm)}
.panel .ph{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.panel .ph h3{font-size:16px;font-weight:800}
.panel .ph a{font-size:13px;color:var(--accent);font-weight:700;cursor:pointer}

/* series cards */
.series-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(max-width:760px){.series-grid{grid-template-columns:1fr}}
/* compact creator-style series card: 64px tile + content, light (no heavy shadow) */
.scard3{display:flex;gap:14px;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px;cursor:pointer;transition:border-color .15s,transform .15s}
.scard3:hover{transform:translateY(-2px);border-color:rgba(122,43,255,.35)}
.sc-tile{width:64px;height:64px;border-radius:12px;flex:0 0 auto;overflow:hidden;display:grid;place-items:center;color:rgba(255,255,255,.92)}
.sc-tile img{width:100%;height:100%;object-fit:cover;display:block}
.sc-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px}
.sc-row1{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.sc-name{font-size:16px;font-weight:800;letter-spacing:-.01em;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sc-sub{font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.sc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}
.sc-next{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;margin-top:3px}
.sc-next.ok{color:var(--ink-2)}
.sc-next.warn{color:#c2410c}
.sc-next.muted{color:var(--muted)}
.sc-next svg{flex:0 0 auto}
.sc-plats{display:inline-flex;gap:5px;margin-left:6px}
.sc-plats svg{width:14px;height:14px;opacity:.65}
/* 3-dot menu */
.sc-menu-wrap{position:relative;flex:0 0 auto}
.sc-dots{width:30px;height:30px}
.sc-menu-bd{position:fixed;inset:0;z-index:30}
.sc-menu{position:absolute;top:calc(100% + 4px);right:0;z-index:31;background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);padding:5px;min-width:178px}
.sc-menu button{width:100%;display:flex;align-items:center;gap:9px;background:none;border:0;font-family:var(--font);font-size:13.5px;font-weight:600;color:var(--ink-2);padding:9px 10px;border-radius:8px;cursor:pointer;text-align:left}
.sc-menu button:hover{background:var(--paper-2);color:var(--ink)}
.sc-menu button.danger{color:#d23b2b}
.sc-menu button.danger:hover{background:rgba(210,59,43,.08)}

/* mini reel list */
.vlist{display:flex;flex-direction:column;gap:11px}
.vrow{display:flex;align-items:center;gap:13px}
.vrow .vthumb{width:40px;height:54px;border-radius:8px;flex:0 0 auto;position:relative;overflow:hidden}
.vrow .vmeta{flex:1;min-width:0}
.vrow .vmeta b{font-size:13.5px;font-weight:700;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vrow .vmeta span{font-size:12px;color:var(--muted)}

/* table (videos) */
.tbl-wrap{background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm)}
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:500;padding:14px 16px;border-bottom:1px solid var(--line);background:var(--paper)}
.tbl td{padding:12px 16px;border-bottom:1px solid var(--line-2);font-size:13.5px;vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:var(--paper)}
.tbl .vt-cell{display:flex;align-items:center;gap:11px}
.tbl .vt-cell .th{width:34px;height:46px;border-radius:7px;flex:0 0 auto;position:relative;overflow:hidden}
.tbl .vt-cell b{font-weight:700}
.tbl .acts{display:flex;gap:4px;justify-content:flex-end}
.iconbtn{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:var(--card);display:grid;place-items:center;color:var(--ink-2);transition:background .12s,color .12s,border-color .12s}
.iconbtn:hover{background:var(--paper-2);color:var(--ink);border-color:rgba(20,19,15,.2)}

/* filter chips */
.next-banner{display:flex;align-items:center;gap:10px;background:var(--accent-soft);border:1px solid var(--accent-soft);border-radius:12px;padding:12px 16px;margin-bottom:16px;font-size:13.5px;color:var(--ink);line-height:1.4}
.next-banner .nb-ic{display:grid;place-items:center;width:28px;height:28px;border-radius:8px;background:var(--accent);color:#fff;flex:0 0 auto}
.next-banner b{font-weight:700}
.next-banner.paused{background:var(--paper-2);border-color:var(--line);color:var(--ink-2)}
.next-banner.paused .nb-ic{background:var(--ink-2)}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.fchip{font-size:13px;font-weight:600;padding:7px 14px;border-radius:999px;border:1px solid var(--line);background:var(--card);color:var(--ink-2)}
.fchip:hover{border-color:rgba(20,19,15,.2)}
.fchip.on{background:var(--ink);color:#fff;border-color:var(--ink)}

/* series detail */
.sd-hero{display:flex;gap:22px;align-items:flex-start;margin-bottom:24px}
.sd-cover{width:120px;height:160px;border-radius:16px;flex:0 0 auto;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.sd-info{flex:1}
.sd-info h1{font-size:26px;font-weight:800;letter-spacing:-.02em}
.sd-info .sub{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:4px}
.sd-info .tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px}
.sd-info .acts{display:flex;gap:9px;margin-top:16px;flex-wrap:wrap}
.sd-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;margin-bottom:24px}
.kv{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px}
.kv .k{font-size:11.5px;color:var(--muted);font-weight:600}
.kv .v{font-size:15px;font-weight:800;margin-top:5px;display:flex;align-items:center;gap:7px}

/* billing */
.bill-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:20px}
.balance-card{background:var(--ink);color:var(--on-dark);border-radius:18px;padding:26px;position:relative;overflow:hidden}
.balance-card .blob{position:absolute;width:200px;height:200px;border-radius:50%;background:rgba(122,43,255,.45);filter:blur(60px);top:-60px;right:-30px}
.balance-card .bl{font-size:13px;color:var(--on-dark-muted);position:relative}
.balance-card .bv{font-size:40px;font-weight:800;letter-spacing:-.03em;margin-top:6px;position:relative}
.balance-card .bsub{display:flex;gap:24px;margin-top:18px;position:relative}
.balance-card .bsub .bi{font-size:12.5px;color:var(--on-dark-muted)}
.balance-card .bsub .bi b{display:block;font-size:18px;color:#fff;font-weight:800;margin-top:2px}
.topup-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.topup{border:2px solid var(--line);border-radius:14px;padding:18px;text-align:center;cursor:pointer;transition:border-color .15s,box-shadow .15s;background:var(--card);position:relative}
.topup:hover{border-color:rgba(20,19,15,.2)}
.topup.on{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.topup.best{border-color:var(--accent)}
.topup .tag{position:absolute;top:-10px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:var(--lime);color:#15140f;padding:3px 9px;border-radius:999px;white-space:nowrap}
.topup .amt{font-size:24px;font-weight:800;letter-spacing:-.02em}
.topup .cr{font-size:13px;color:var(--accent);font-weight:700;margin-top:3px}
.topup .pr{font-size:12.5px;color:var(--muted);margin-top:6px}
.pay-method{display:flex;align-items:center;gap:13px;border:2px solid var(--line);border-radius:12px;padding:14px 16px;cursor:pointer;transition:border-color .15s,background .15s}
.pay-method.on{border-color:var(--accent);background:var(--accent-soft)}
.pay-method .pmic{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:var(--paper-2);flex:0 0 auto;font-weight:800;color:var(--ink-2)}
.pay-method .pmt{flex:1}
.pay-method .pmt b{font-size:14px;font-weight:700;display:block}
.pay-method .pmt span{font-size:12.5px;color:var(--muted)}
.upload-zone{border:2px dashed var(--line);border-radius:13px;padding:26px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s}
.upload-zone:hover{border-color:var(--accent);background:var(--accent-soft)}
.upload-zone.has{border-style:solid;border-color:var(--green);background:var(--green-soft)}
.upload-zone .uic{width:44px;height:44px;border-radius:12px;background:var(--paper-2);color:var(--ink-2);display:grid;place-items:center;margin:0 auto 10px}

/* guides */
.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.guide{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px;cursor:pointer;transition:transform .18s,box-shadow .18s}
.guide:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.guide .gic{width:42px;height:42px;border-radius:11px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;margin-bottom:14px}
.guide h3{font-size:15.5px;font-weight:800}
.guide p{font-size:13px;color:var(--ink-2);margin-top:5px;line-height:1.5}

/* calendar */
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.cal .cd{background:var(--card);border:1px solid var(--line);border-radius:11px;min-height:96px;padding:9px}
.cal .cd .dn{font-family:var(--mono);font-size:11px;color:var(--muted)}
.cal .cd.dim{opacity:.4}
.cal .cev{font-size:10.5px;font-weight:700;color:#fff;border-radius:6px;padding:4px 6px;margin-top:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-head{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:8px}
.cal-head span{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);text-align:center}

/* analytics */
.an-graph{height:200px;display:flex;align-items:flex-end;gap:10px;padding:0 4px}
.an-graph i{flex:1;background:linear-gradient(to top,var(--accent),rgba(122,43,255,.35));border-radius:6px 6px 0 0;position:relative}
.demo-tag{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--amber);background:var(--amber-soft);padding:3px 8px;border-radius:6px}

/* accounts */
.acct-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.acct{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px;text-align:center}
.acct .aic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;color:#fff;margin:0 auto 14px}
.acct h3{font-size:15px;font-weight:800}
.acct .ah{font-size:12.5px;color:var(--muted);margin-top:3px}

/* empty state */
.empty{text-align:center;padding:60px 20px}
.empty .eic{width:64px;height:64px;border-radius:18px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;margin:0 auto 18px}
.empty h3{font-size:19px;font-weight:800}
.empty p{color:var(--ink-2);font-size:14px;margin:8px auto 20px;max-width:380px}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(20,19,15,.45);backdrop-filter:blur(4px);z-index:100;display:grid;place-items:center;padding:24px}
.modal{background:var(--card);border-radius:20px;box-shadow:var(--shadow-lg);width:100%;max-width:460px;padding:26px;max-height:90vh;overflow-y:auto}
.modal h3{font-size:20px;font-weight:800;letter-spacing:-.02em}
.modal .mclose{float:right;width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:none;display:grid;place-items:center;color:var(--ink-2)}

/* responsive */
@media(max-width:1080px){
  .stat-row{grid-template-columns:repeat(2,1fr)}
  .grid-2,.bill-grid{grid-template-columns:1fr}
  .sd-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:840px){
  .shell{grid-template-columns:1fr}
  /* sidebar becomes an off-canvas drawer toggled by the topbar hamburger */
  .side{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar);max-width:84vw;z-index:60;transform:translateX(-100%);transition:transform .25s ease}
  .side.open{transform:translateX(0);box-shadow:0 10px 50px rgba(0,0,0,.35)}
  .nav-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:55}
  .nav-toggle{display:inline-flex}
  .auth{grid-template-columns:1fr}
  .auth-brand{display:none}
  .sel-grid.cols-4,.sel-grid.cols-3{grid-template-columns:repeat(2,1fr)}
  .voice-list,.series-grid,.topup-grid,.guide-grid,.acct-grid,.preset-list,.cap-grid{grid-template-columns:1fr}
  .style-item{width:62vw}
  .build-inner{grid-template-columns:1fr;text-align:center;gap:28px}
  .build-phone{margin:0 auto}
}

/* tooltip — brand floating bubble (info icons, etc.) */
.tip{position:relative}
.tip::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 9px);left:50%;transform:translateX(-50%) translateY(4px);background:var(--dark);color:var(--on-dark);font-family:var(--font);font-size:12px;font-weight:500;line-height:1.4;letter-spacing:.01em;padding:8px 12px;border-radius:var(--radius-sm);white-space:nowrap;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:opacity .14s ease,transform .14s ease;z-index:60}
.tip::before{content:'';position:absolute;bottom:calc(100% + 3px);left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--dark);opacity:0;transition:opacity .14s ease;z-index:60}
.tip:hover::after{opacity:1;transform:translateX(-50%) translateY(0)}
.tip:hover::before{opacity:1}

/* monetizable badge (duration dropdown) */
.dur-badge{display:inline-flex;align-items:center;gap:4px;background:var(--accent-soft);color:var(--accent);font-size:11px;font-weight:700;line-height:1;padding:4px 8px;border-radius:999px;white-space:nowrap}
.dur-badge svg{flex:none}
.lang-item .dur-badge{margin-left:auto}

/* ── per-video editor ── */
.veditor{display:flex;flex-direction:column;gap:18px}
.ve-main{display:grid;grid-template-columns:300px 1fr;gap:20px;align-items:start}
@media(max-width:760px){.ve-main{grid-template-columns:1fr}}
.ve-preview{border-radius:14px;overflow:hidden}
.ve-noprev{width:100%;aspect-ratio:9/16;display:grid;place-items:center;color:var(--muted);background:var(--line-2);border-radius:12px;font-size:13px}
.ve-side{display:flex;flex-direction:column;gap:6px}
.ve-lbl{font-size:12.5px;font-weight:700;color:var(--ink-2);margin-top:6px}
.ve-locked{margin-top:10px;font-size:13px;color:var(--ink-2);background:var(--accent-soft);padding:8px 12px;border-radius:10px}
.ve-scene{border:1px solid var(--line);border-radius:14px;padding:16px;background:var(--card)}
.ve-scene-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px;font-size:15px}
.ve-scene-body{display:grid;grid-template-columns:110px 1fr;gap:14px}
.ve-scimg img{display:block}
.ve-timeline{display:flex;gap:8px;overflow-x:auto;margin-top:14px;padding-bottom:4px}
.ve-tl{flex:none;width:44px;height:78px;border-radius:8px;border:2px solid var(--line);overflow:hidden;background:var(--line-2);display:grid;place-items:center;color:var(--muted);font-size:13px;cursor:pointer;padding:0}
.ve-tl.on{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}
.ve-tl img{width:100%;height:100%;object-fit:cover}
.ve-actions{display:flex;gap:10px;align-items:center;border-top:1px solid var(--line);padding-top:16px}

/* ── series detail (tabbed) ── */
.sd-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.sd-crumb{font-size:14px;color:var(--muted);display:flex;align-items:center;gap:7px}
.sd-crumb a{color:var(--muted);cursor:pointer}.sd-crumb a:hover{color:var(--ink)}
.sd-crumb b{color:var(--ink);font-weight:700;font-size:17px}
.sd-bar-actions{display:flex;align-items:center;gap:8px}
.sd-meta{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:18px}
.tabs{display:flex;gap:6px;border-bottom:1px solid var(--line);margin-bottom:20px}
.tab{display:inline-flex;align-items:center;gap:7px;padding:10px 16px;border:0;background:none;color:var(--muted);font-size:14px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}
.tab:hover{color:var(--ink)}
.tab.on{color:var(--accent);border-bottom-color:var(--accent)}
.sd-tab{margin-bottom:24px}
.sd-sech{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.sd-sech h3{font-size:17px;font-weight:800;letter-spacing:-.01em}

/* ── video thumbnails (grid + slider) ── */
.vgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:16px}
.vslider{display:flex;gap:14px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x mandatory}
.vslider .vthumb{flex:0 0 176px;scroll-snap-align:start}
/* full-bleed card: thumbnail only, title appears on hover */
.vthumb{border-radius:16px;overflow:hidden;transition:transform .15s,box-shadow .15s;position:relative}
.vthumb.clickable{cursor:pointer}
.vthumb.clickable:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.vthumb-img{position:relative;aspect-ratio:9/16;background:var(--line-2);overflow:hidden;border:1px solid var(--line);border-radius:16px}
.vthumb-img img{width:100%;height:100%;object-fit:cover;display:block}
.vthumb-fallback{width:100%;height:100%}
.vthumb-badge{position:absolute;top:9px;left:9px;z-index:2}
.vthumb-badge .pill{font-size:10px;padding:3px 8px;box-shadow:0 1px 4px rgba(0,0,0,.25)}
.vthumb-del{position:absolute;top:9px;right:9px;z-index:3;width:28px;height:28px;border-radius:9px;border:0;background:rgba(20,19,15,.6);color:#fff;display:grid;place-items:center;cursor:pointer;opacity:0;transition:opacity .15s;backdrop-filter:blur(2px)}
.vthumb:hover .vthumb-del{opacity:1}
.vthumb-del:hover{background:#d23b2b}
/* hover overlay — title + timestamp over a bottom gradient scrim (ref image) */
.vthumb-over{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:46px 14px 14px 14px;background:linear-gradient(to top,rgba(10,9,7,.92) 0%,rgba(10,9,7,.72) 40%,rgba(10,9,7,0) 100%);opacity:0;transition:opacity .18s;pointer-events:none}
.vthumb.clickable:hover .vthumb-over{opacity:1}
.vthumb-over-title{color:#fff;font-size:15px;font-weight:700;line-height:1.3;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-shadow:0 1px 3px rgba(0,0,0,.5)}
.vthumb-over-ago{color:rgba(255,255,255,.7);font-size:12px;margin-top:5px}
.vthumb-play{position:absolute;inset:0;display:grid;place-items:center;opacity:0;transition:opacity .15s;z-index:1}
.vthumb-play svg{filter:drop-shadow(0 2px 8px rgba(0,0,0,.6))}
.vthumb.clickable:hover .vthumb-play{opacity:.95}
.vthumb-spin{position:absolute;inset:0;display:grid;place-items:center;color:var(--accent);background:rgba(255,255,255,.6);z-index:2}
.vthumb.failed{cursor:pointer}
.vthumb-fail{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;padding:14px;color:#fff;background:rgba(120,20,20,.62);backdrop-filter:blur(2px);z-index:2}
.vthumb-fail span{font-size:12px;font-weight:600;line-height:1.35;text-shadow:0 1px 4px rgba(0,0,0,.6)}
.vthumb.failed:hover .vthumb-fail{background:rgba(150,28,28,.72)}

/* ── publish page ── */
.pub-grid{display:grid;grid-template-columns:340px 1fr;gap:30px;align-items:start}
@media(max-width:820px){.pub-grid{grid-template-columns:1fr}}
.pub-left{display:flex;flex-direction:column;gap:10px}
.pub-player{border-radius:14px;overflow:hidden;background:#000;aspect-ratio:9/16;display:grid;place-items:center}
.pub-player video{width:100%;height:100%;object-fit:contain}
.pub-dl{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:none;border:0;color:var(--accent);font-weight:700;font-size:14px;cursor:pointer;padding:6px}
.pub-note{font-size:12.5px;color:var(--muted);text-align:center;line-height:1.45;margin:2px 4px}
.pub-status{margin-top:6px;padding:14px}
.pubst-row{display:flex;align-items:center;gap:11px;padding:9px 0}
.pubst-row+.pubst-row{border-top:1px solid var(--line-2)}
.acct-ic.sm{width:32px;height:32px;border-radius:9px}
.pub-right{display:flex;flex-direction:column;gap:5px;max-width:680px}
.lbl-hint{font-weight:500;color:var(--muted);font-size:12px}
.fld-hint{font-size:12px;color:var(--muted);margin:2px 0 6px}
.fld-err{font-size:12.5px;color:#d23b2b;margin:4px 0 2px;font-weight:600}
.pub-when{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pub-actions{display:flex;align-items:center;gap:10px;margin-top:22px}

/* ── upcoming schedule cards ── */
.sched-row{display:flex;gap:14px;overflow-x:auto;padding-bottom:8px}
.sched-card{flex:0 0 230px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:15px;display:flex;flex-direction:column;gap:10px;min-height:120px;position:relative}
.sched-card[draggable=true]{cursor:grab}
.sched-card[draggable=true]:active{cursor:grabbing}
.sched-card.dragging{opacity:.5;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}
.sched-grip{position:absolute;top:10px;right:12px;color:var(--muted);font-size:14px;line-height:1;letter-spacing:-1px;user-select:none}
.sched-card.more{align-items:center;justify-content:center;text-align:center;color:var(--muted);font-size:13px;border-style:dashed;background:transparent}
.sched-title{font-size:14px;font-weight:700;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sched-date{align-self:flex-start}
.sched-acts{display:flex;gap:6px;margin-top:auto}

/* ── per-series connected accounts ── */
.sd-accts{margin-top:4px}
.ph-sub{font-size:13px;color:var(--muted);font-weight:500}
.acct-list{display:flex;flex-direction:column;gap:10px}
.acct-row{display:flex;align-items:center;gap:13px;padding:12px;border:1px solid var(--line);border-radius:13px}
.acct-ic{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;color:#fff;flex:0 0 auto}
.acct-meta{flex:1;display:flex;flex-direction:column;gap:2px}
.acct-meta b{font-size:14px}
.acct-meta span{font-size:12.5px;color:var(--muted)}
/* toggle switch */
.sw{position:relative;display:inline-block;width:42px;height:24px;flex:0 0 auto;cursor:pointer}
.sw input{opacity:0;width:0;height:0}
.sw-track{position:absolute;inset:0;background:var(--line);border-radius:999px;transition:background .15s}
.sw-track:before{content:"";position:absolute;left:3px;top:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .15s;box-shadow:0 1px 3px rgba(0,0,0,.25)}
.sw input:checked + .sw-track{background:var(--accent)}
.sw input:checked + .sw-track:before{transform:translateX(18px)}

/* misc */
.sel-sm{width:auto;min-width:160px;padding:8px 12px;font-size:13.5px}
.empty.sm{padding:32px 20px}
.empty.sm .eic{width:46px;height:46px}

/* ── custom video player (app-blended controls) ── */
.np{position:relative;width:100%;background:#000;border-radius:14px;overflow:hidden;line-height:0}
.np video{width:100%;display:block;aspect-ratio:9/16;object-fit:contain;background:#000;cursor:pointer}
.pub-player .np,.pub-player .np video{aspect-ratio:auto;height:100%}
.np-big{position:absolute;inset:0;margin:auto;width:64px;height:64px;border-radius:50%;border:0;background:rgba(122,43,255,.92);color:#fff;display:grid;place-items:center;cursor:pointer;box-shadow:0 8px 24px -6px rgba(0,0,0,.5);transition:transform .15s,background .15s}
.np-big:hover{transform:scale(1.06);background:var(--accent)}
.np-big svg{margin-left:3px}
.np-bar{position:absolute;left:0;right:0;bottom:0;display:flex;align-items:center;gap:10px;padding:10px 12px;background:linear-gradient(to top,rgba(10,9,7,.85),rgba(10,9,7,0));opacity:0;transition:opacity .18s;line-height:1}
.np:hover .np-bar,.np video:not([playing]) + .np-bar{opacity:1}
.np:hover .np-bar{opacity:1}
.np-btn{width:30px;height:30px;border:0;background:rgba(255,255,255,.12);color:#fff;border-radius:9px;display:grid;place-items:center;cursor:pointer;flex:0 0 auto;transition:background .15s}
.np-btn:hover{background:rgba(255,255,255,.25)}
.np-time{color:rgba(255,255,255,.85);font-size:11.5px;font-variant-numeric:tabular-nums;flex:0 0 auto;min-width:30px;text-align:center}
.np-track{flex:1;height:5px;background:rgba(255,255,255,.25);border-radius:999px;cursor:pointer;position:relative;overflow:hidden}
.np-fill{position:absolute;left:0;top:0;bottom:0;background:var(--accent);border-radius:999px}

/* compact series-filter dropdown on the Videos page (reuses .lang-dd styling) */
.sel-dd{min-width:190px}
.sel-dd .lang-trigger{padding:9px 13px;font-size:13.5px;font-weight:600}
.sel-dd .lang-trigger > span{display:inline-flex;align-items:center;gap:8px;color:var(--ink)}
.sel-dd .lang-trigger svg:first-child{color:var(--muted);flex:0 0 auto}
.sel-dd .lang-menu{min-width:220px;left:auto;right:0}

/* ── Subscription plans (billing) ── */
.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:900px){.plan-grid{grid-template-columns:1fr}}
.plan-card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:22px 20px 20px;display:flex;flex-direction:column}
.plan-card.best{border-color:var(--accent);box-shadow:0 8px 30px rgba(122,43,255,.12)}
.plan-card.current{border-color:var(--green)}
.plan-flag{position:absolute;top:-11px;left:20px;background:var(--accent);color:#fff;font-size:11px;font-weight:700;letter-spacing:.02em;padding:4px 10px;border-radius:999px}
.plan-name{font-size:15px;font-weight:700;color:var(--muted)}
.plan-price{margin-top:6px;display:flex;align-items:baseline;gap:4px}
.plan-price b{font-size:38px;font-weight:800;letter-spacing:-.02em}
.plan-price span{font-size:15px;color:var(--muted);font-weight:600}
.plan-was{font-size:13px;color:var(--muted);text-decoration:line-through;margin-top:2px}
.plan-blurb{font-size:13px;color:var(--muted);margin:10px 0 16px;line-height:1.4}
.plan-feats{display:flex;flex-direction:column;gap:9px;margin-bottom:18px;flex:1}
.plan-mult{font-size:12px;color:var(--ink-2);margin-top:-2px;margin-bottom:2px}
.series-stepper{display:flex;align-items:center;gap:4px;background:var(--paper-2);border:1px solid var(--line);border-radius:12px;padding:5px}
.series-stepper .step-btn{width:34px;height:34px;border-radius:9px;border:none;background:var(--card);color:var(--ink);display:grid;place-items:center;cursor:pointer}
.series-stepper .step-btn:hover:not(:disabled){background:var(--accent);color:#fff}
.series-stepper .step-btn:disabled{opacity:.35;cursor:default}
.series-stepper .step-val{min-width:64px;text-align:center;display:flex;flex-direction:column;line-height:1.05}
.series-stepper .step-val b{font-size:20px;font-weight:800}
.series-stepper .step-val span{font-size:11px;color:var(--ink-2)}
.plan-videos{display:flex;align-items:center;gap:8px;font-size:14.5px;color:var(--accent);margin-bottom:8px}
.plan-videos svg{color:var(--accent);flex:0 0 auto}
.plan-cadence{display:flex;align-items:center;gap:8px;font-size:13.5px;padding-bottom:10px;border-bottom:1px solid var(--line);margin-bottom:3px}
.plan-cadence svg{color:var(--accent)}
/* FAQ accordion */
.faq-list{display:flex;flex-direction:column;gap:8px;max-width:760px}
.faq-item{border:1px solid var(--line);border-radius:12px;background:var(--card);overflow:hidden}
.faq-item.open{border-color:var(--accent-soft)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;font-size:14.5px;font-weight:650;color:var(--ink);background:none;border:none;cursor:pointer;text-align:left}
.faq-q .chev{transition:transform .18s;color:var(--ink-2);flex:0 0 auto}
.faq-q .chev.up{transform:rotate(180deg)}
.faq-a{padding:0 16px 15px;font-size:13.5px;line-height:1.55;color:var(--ink-2)}
.plan-feat{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--ink)}
.plan-feat svg{color:var(--green);flex:0 0 auto}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{background:#000}

/* global notify() toast (#nz-gtoast) — smooth fade in/out on inline opacity changes */
#nz-gtoast{transition:opacity .25s ease, transform .25s ease}
