/* ===================== THEME TOKENS ===================== */
:root, [data-theme="light"]{
  --bg:#E4DECF;
  --panel:#FBF8EF;
  --panel-2:#EFE9D9;
  --panel-3:#E2DAC4;
  --ink:#211C13;
  --txt:#211C13;
  --txt-2:#5C5444;
  --txt-3:#8C836E;
  --line-soft:rgba(33,28,19,.16);
  --accent:#d67c2e;
  --accent-2:#b85d1c;
  --accent-ink:#FBF8EF;
  --accent-soft:#F2DDCF;
  --good:#3E7D4F;
  --warn:#BC8A2B;
  --gold:#E7B23C;
  --shadow-col:#211C13;
  --dot:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18'%3E%3Crect width='1.6' height='1.6' x='1' y='1' fill='%23211C13' fill-opacity='0.13'/%3E%3C/svg%3E");
}
[data-theme="dark"]{
  --bg:#15130E;
  --panel:#211D16;
  --panel-2:#2A251C;
  --panel-3:#352F23;
  --ink:#EDE5D2;
  --txt:#EDE5D2;
  --txt-2:#B2A992;
  --txt-3:#7E7561;
  --line-soft:rgba(237,229,210,.16);
  --accent:#e9b14f;
  --accent-2:#f2a86f;
  --accent-ink:#15130E;
  --accent-soft:#3a2418;
  --good:#6CB178;
  --warn:#D8AB4E;
  --gold:#F0C055;
  --shadow-col:#000000;
  --dot:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18'%3E%3Crect width='1.6' height='1.6' x='1' y='1' fill='%23EDE5D2' fill-opacity='0.08'/%3E%3C/svg%3E");
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background-color:var(--bg);
  background-image:var(--dot);
  color:var(--txt);
  font-family:'Space Mono',ui-monospace,monospace;
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
.tnum{font-variant-numeric:tabular-nums}
.pix{font-family:'Silkscreen',monospace;letter-spacing:.02em}
::selection{background:var(--accent);color:var(--accent-ink)}
a{color:inherit}
button{font-family:inherit;cursor:pointer}
textarea,select,input{font-family:inherit}
:focus-visible{outline:3px solid var(--accent);outline-offset:2px}

.wrap{max-width:1240px;margin:0 auto;padding:0 24px}
.hidden{display:none !important}
.skip-to-content{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-to-content:focus{position:fixed;top:12px;left:12px;width:auto;height:auto;padding:10px 16px;background:var(--accent);color:var(--accent-ink);border:2px solid var(--ink);font-weight:700;font-size:13px;z-index:9999;text-decoration:none;box-shadow:3px 3px 0 var(--shadow-col)}

.noscript-banner{margin:16px auto;max-width:1192px;width:calc(100% - 48px);border:2px solid var(--ink);
  background:var(--accent-soft);color:var(--txt);padding:16px 20px;font-size:13px;line-height:1.6;
  box-shadow:4px 4px 0 var(--shadow-col)}
.noscript-banner strong{display:block;font-family:'Silkscreen',monospace;font-size:13px;margin-bottom:6px;color:var(--accent)}
.site-banner{position:sticky;top:0;z-index:80;border-bottom:2px solid var(--ink);color:#fff;box-shadow:0 3px 0 var(--shadow-col)}
.site-banner-in{min-height:44px;display:flex;align-items:center;justify-content:center;gap:14px;padding-top:9px;padding-bottom:9px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;text-align:center}
.site-banner button{margin-left:auto;border:2px solid currentColor;background:transparent;color:inherit;width:28px;height:28px;font-size:20px;line-height:20px;font-weight:700;display:grid;place-items:center;padding:0}

.hard{box-shadow:4px 4px 0 var(--shadow-col)}
.hard-sm{box-shadow:3px 3px 0 var(--shadow-col)}
.bd{border:2px solid var(--ink)}

/* ===================== NAV ===================== */
.nav{position:sticky;top:0;z-index:60;background:var(--panel);border-bottom:2px solid var(--ink)}
body.banner-visible .nav{top:var(--banner-offset,44px)}
.nav-in{display:flex;align-items:center;gap:16px;height:62px}
.brand{display:flex;align-items:center;gap:11px}
.brand .mark{width:34px;height:34px;border:2px solid var(--ink);background:var(--accent);
  display:grid;place-items:center;box-shadow:2px 2px 0 var(--shadow-col);overflow:hidden;flex:none}
.brand .mark img{display:block;width:100%;height:100%;object-fit:cover}
.brand .bt{font-family:'Silkscreen',monospace;font-weight:700;font-size:15px;letter-spacing:.02em;line-height:1}
.nav-steps{margin-left:14px;display:flex;gap:2px}
.nav-steps a{font-size:12px;color:var(--txt-2);text-decoration:none;padding:7px 10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;transition:.12s;border:2px solid transparent}
.nav-steps a:hover{color:var(--ink);border-color:var(--ink);background:var(--panel-2)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:8px}
.credit-pill{display:flex;align-items:center;gap:5px;border:2px solid var(--ink);background:var(--panel-2);padding:4px 5px 4px 7px;box-shadow:2px 2px 0 var(--shadow-col)}
.credit-coin{width:22px;height:22px;object-fit:contain;flex:none;display:block}
.credit-count{font-size:13px;font-weight:700;color:var(--ink);white-space:nowrap;font-family:'Silkscreen',monospace;min-width:20px;text-align:center}
.credit-add{width:28px;height:28px;border:2px solid var(--ink);background:var(--accent);color:var(--accent-ink);font-weight:700;font-size:18px;line-height:1;display:grid;place-items:center;cursor:pointer;padding:0;flex:none;box-shadow:1px 1px 0 var(--shadow-col);transition:transform .08s,box-shadow .08s}
.credit-add:hover{transform:translate(-1px,-1px);box-shadow:2px 2px 0 var(--shadow-col)}
.credit-add:active{transform:translate(1px,1px);box-shadow:0 0 0 transparent}
.dots-menu{position:relative}
.dots-btn{width:45px;height:38px;border:2px solid var(--ink);background:var(--panel-2);color:var(--ink);font-weight:700;font-size:20px;letter-spacing:.1em;display:grid;place-items:center;cursor:pointer;box-shadow:2px 2px 0 var(--shadow-col);transition:transform .08s,box-shadow .08s;padding:0;line-height:1;}
.dots-btn:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--shadow-col)}
.dots-btn:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--shadow-col)}
.dots-dropdown{position:absolute;right:0;top:calc(100% + 5px);background:var(--panel-2);border:2px solid var(--ink);box-shadow:3px 3px 0 var(--shadow-col);min-width:150px;z-index:300;display:flex;flex-direction:column}
.dots-dropdown[hidden]{display:none}
.dd-user-info{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 12px;border-bottom:2px solid var(--ink);min-width:0}
.dd-username{font-size:11px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.dd-tier{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;background:var(--accent);color:var(--accent-ink);padding:2px 6px;flex:none}
.dd-theme{display:flex;border-bottom:2px solid var(--ink)}
.dd-theme button{flex:1;padding:9px 6px;border:none;background:transparent;color:var(--txt-2);font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.04em;display:flex;align-items:center;justify-content:center;gap:5px;cursor:pointer;font-family:inherit}
.dd-theme button.on{background:var(--ink);color:var(--panel)}
.dd-theme button svg{width:13px;height:13px;flex:none}
.dd-item{width:100%;padding:10px 14px;border:none;background:transparent;color:var(--ink);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.04em;text-align:left;cursor:pointer;text-decoration:none;display:block;font-family:inherit}
.dd-item:hover{background:var(--panel-3)}

.btn{display:inline-flex;align-items:center;gap:9px;border:2px solid var(--ink);background:var(--panel);
  color:var(--ink);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.04em;
  padding:11px 16px;box-shadow:3px 3px 0 var(--shadow-col);transition:transform .08s, box-shadow .08s}
.btn:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--shadow-col)}
.btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--shadow-col)}
.btn.primary{background:var(--accent);color:var(--accent-ink)}
.btn svg{width:16px;height:16px}
.btn.sm{padding:8px 12px;font-size:11px;box-shadow:2px 2px 0 var(--shadow-col)}
.btn:disabled{opacity:.5;pointer-events:none}

@keyframes blink{50%{opacity:0}}
@media(max-width:1080px){.nav-steps{display:none}}
@media(max-width:720px){.brand .bt{display:none}.nav-in{gap:8px}.nav-right{gap:5px}.btn.sm{padding:7px 9px;font-size:10px}}

/* ===================== HERO ===================== */
.hero{padding:54px 0 22px;position:relative}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:11px;font-weight:700;
  color:var(--ink);letter-spacing:.08em;text-transform:uppercase;
  background:var(--panel);border:2px solid var(--ink);padding:7px 12px;box-shadow:3px 3px 0 var(--shadow-col)}
.eyebrow .dot{width:8px;height:8px;background:var(--good);animation:blink 1.1s steps(1) infinite}
.payg-badge{display:inline-block;margin-top:10px;font-size:11px;font-weight:700;
  color:var(--accent-ink);background:var(--accent);border:2px solid var(--ink);
  letter-spacing:.04em;text-transform:uppercase;padding:7px 12px;box-shadow:3px 3px 0 var(--shadow-col)}
h1.hero-title{font-family:'Silkscreen',monospace;font-weight:700;
  font-size:clamp(26px,4.4vw,50px);line-height:1.32;letter-spacing:.01em;margin:24px 0 0;max-width:18ch}
h1.hero-title .hl{color:var(--accent)}
.hero-sub{margin:22px 0 0;font-size:15px;color:var(--txt-2);max-width:60ch;line-height:1.7}
.hero-actions{margin-top:28px;display:flex;gap:13px;flex-wrap:wrap;align-items:center}
.hero-stats{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}
.hero-stat{border:2px solid var(--ink);background:var(--panel);padding:12px 16px;box-shadow:3px 3px 0 var(--shadow-col);min-width:118px}
.hero-stat .n{font-family:'Silkscreen',monospace;font-size:20px}
.hero-stat .l{font-size:10.5px;color:var(--txt-3);margin-top:6px;text-transform:uppercase;letter-spacing:.05em}

.rail{display:flex;gap:0;margin:42px 0 8px;border:2px solid var(--ink);background:var(--panel);
  box-shadow:4px 4px 0 var(--shadow-col);overflow-x:auto;scrollbar-width:none}
.rail::-webkit-scrollbar{display:none}
.rail-step{flex:1 0 auto;min-width:150px;display:flex;align-items:center;gap:11px;padding:14px 16px;text-decoration:none;
  border-right:2px solid var(--ink);transition:background .12s}
.rail-step:last-child{border-right:none}
.rail-step:hover{background:var(--panel-2)}
.rail-num{flex:none;width:30px;height:30px;display:grid;place-items:center;font-family:'Silkscreen',monospace;
  font-size:12px;color:var(--accent-ink);background:var(--ink);transition:.12s}
.rail-step:hover .rail-num{background:var(--accent)}
.rail-step .t{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--ink)}
.rail-step .d{font-size:10.5px;color:var(--txt-3)}
.rail-step.done .rail-num{background:var(--good)}
.rail-step.active{background:var(--accent-soft)}
.rail-step.active .rail-num{background:var(--accent)}
.nav-steps a.done{color:var(--good)}
.nav-steps a.done::before{content:"\2713 ";font-size:10px}
.nav-steps a.active{color:var(--accent);border-color:var(--accent);background:var(--panel-2)}

/* ===================== WINDOW / SECTION ===================== */
section.step{padding:50px 0 8px;scroll-margin-top:74px}
.step-head{display:flex;align-items:flex-start;gap:15px;margin-bottom:22px}
.step-badge{flex:none;width:46px;height:46px;display:grid;place-items:center;font-family:'Silkscreen',monospace;
  font-size:18px;color:var(--accent-ink);background:var(--accent);border:2px solid var(--ink);box-shadow:3px 3px 0 var(--shadow-col)}
.step-head h2{font-family:'Silkscreen',monospace;font-weight:700;margin:2px 0 0;font-size:clamp(17px,2.3vw,24px);
  letter-spacing:.01em;line-height:1.3}
.step-head p{margin:10px 0 0;color:var(--txt-2);font-size:13px;max-width:66ch;line-height:1.6}

.win{border:2px solid var(--ink);background:var(--panel);box-shadow:4px 4px 0 var(--shadow-col)}
.win-bar{display:flex;align-items:center;gap:10px;padding:9px 12px;border-bottom:2px solid var(--ink);
  background:var(--ink);color:var(--panel)}
.win-bar .lights{display:flex;gap:5px}
.win-bar .lights i{width:11px;height:11px;border:2px solid var(--panel);display:block}
.win-bar .lights i.fill{background:var(--panel)}
.win-bar .wt{font-family:'Silkscreen',monospace;font-size:11px;letter-spacing:.03em}
.win-bar .wmeta{margin-left:auto;font-size:11px;color:rgba(255,255,255,.6);font-weight:700;text-transform:uppercase;letter-spacing:.04em}
[data-theme="dark"] .win-bar .wmeta{color:rgba(0,0,0,.55)}
.win-body{padding:22px}

.grid{display:grid;gap:20px}

/* ===================== STEP 1 UPLOAD ===================== */
.upload-grid{grid-template-columns:1.4fr 1fr}
@media(max-width:860px){.upload-grid{grid-template-columns:1fr}}
.dropzone{padding:34px;border:2px dashed var(--ink);background:var(--panel-2);
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:13px;cursor:pointer;transition:background .12s}
.dropzone:hover,.dropzone.drag{background:var(--accent-soft)}
.dropzone .ico{width:56px;height:56px;background:var(--accent);border:2px solid var(--ink);display:grid;place-items:center;box-shadow:3px 3px 0 var(--shadow-col)}
.dropzone .ico svg{width:26px;height:26px}
.dropzone h3{margin:0;font-size:15px;font-weight:700}
.dropzone p{margin:0;color:var(--txt-3);font-size:12px}
.dropzone .pill{font-size:10.5px;color:var(--txt-2);background:var(--panel);border:2px solid var(--ink);padding:5px 10px;margin-top:3px;text-transform:uppercase;letter-spacing:.04em}
.record-open{margin-top:2px}
.file-body{padding:20px;display:flex;flex-direction:column;gap:15px;justify-content:center}
.file-row{display:flex;align-items:center;gap:13px}
.file-ico{width:46px;height:46px;border:2px solid var(--ink);background:var(--panel-2);display:grid;place-items:center;color:var(--accent)}
.file-ico svg{width:22px;height:22px}
.file-meta{flex:1;min-width:0}
.file-meta .name{font-weight:700;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.file-meta .sub{font-size:11px;color:var(--txt-3)}
.badge-ok{font-size:10.5px;font-weight:700;color:var(--good);background:var(--panel-2);border:2px solid var(--good);
  padding:4px 8px;display:inline-flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:.04em}
.badge-ok .d{width:7px;height:7px;background:var(--good)}
.badge-wait{font-size:10.5px;font-weight:700;color:var(--warn);background:var(--panel-2);border:2px solid var(--warn);
  padding:4px 8px;display:inline-flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:.04em}
.badge-wait .d{width:7px;height:7px;background:var(--warn);animation:blink 1s steps(1) infinite}
.mini-wave{height:48px;width:100%;display:block;border:2px solid var(--ink);background:var(--panel-2)}

/* ===================== STEP 2 TRANSCRIPT ===================== */
.transcript-grid{grid-template-columns:1fr 1.25fr}
@media(max-width:920px){.transcript-grid{grid-template-columns:1fr}}
.full-transcript{font-size:14px;line-height:1.85;color:var(--txt-2);max-height:430px;overflow:auto;padding:18px}
.full-transcript .s{transition:.12s;padding:1px 2px;cursor:pointer}
.full-transcript .s.active{background:var(--accent);color:var(--accent-ink)}
.sent-list{display:flex;flex-direction:column;gap:0;max-height:470px;overflow:auto}
.shot-granularity{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:2px solid var(--ink);background:var(--panel-2)}
.shot-granularity .sg-label{font-size:9px;text-transform:uppercase;letter-spacing:.06em;color:var(--txt-3);font-weight:700}
.shot-granularity input[type=range]{flex:1;accent-color:var(--accent);cursor:pointer}
.shot-granularity input[type=range]:disabled{opacity:.45;cursor:not-allowed}
.shot-granularity .sg-note{font-size:9px;color:var(--txt-3);min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sent{display:grid;grid-template-columns:auto 1fr;gap:13px;align-items:start;padding:13px 16px;
  border-bottom:2px solid var(--line-soft);cursor:pointer;transition:background .1s}
.sent:hover{background:var(--panel-2)}
.sent.active{background:var(--accent-soft);border-left:4px solid var(--accent);padding-left:12px}
.sent .ts{font-size:11px;color:var(--accent);font-weight:700;white-space:nowrap;padding-top:2px}
.sent .ts .dur{display:block;color:var(--txt-3);margin-top:2px}
.sent .idx{font-family:'Silkscreen',monospace;font-size:9.5px;color:var(--txt-3);margin-bottom:4px}
.sent .txt{font-size:12.5px;color:var(--txt);line-height:1.5}
.sent .txt.editing{outline:2px solid var(--accent);outline-offset:2px;background:var(--panel);cursor:text;white-space:pre-wrap}
.full-transcript::-webkit-scrollbar,.sent-list::-webkit-scrollbar{width:10px}
.full-transcript::-webkit-scrollbar-track,.sent-list::-webkit-scrollbar-track{background:var(--panel-2);border-left:2px solid var(--ink)}
.full-transcript::-webkit-scrollbar-thumb,.sent-list::-webkit-scrollbar-thumb{background:var(--ink)}

/* ===================== STEP 3 PROMPT ASSIST ===================== */
.assist-grid{grid-template-columns:repeat(3,1fr);margin-top:18px}
@media(max-width:980px){.assist-grid{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:9px}
.field label{font-size:12px;font-weight:700;display:flex;align-items:center;gap:8px;text-transform:uppercase;letter-spacing:.03em}
.field label .li{width:24px;height:24px;border:2px solid var(--ink);background:var(--panel-2);display:grid;place-items:center;color:var(--accent)}
.field label .li svg{width:13px;height:13px}
.field .hint{font-size:11px;color:var(--txt-3);font-weight:400;text-transform:none;letter-spacing:0}
textarea{width:100%;min-height:170px;resize:vertical;background:var(--panel-2);border:2px solid var(--ink);
  padding:13px;color:var(--txt);font-size:12.5px;line-height:1.6}
textarea:focus{outline:3px solid var(--accent);outline-offset:-1px;background:var(--panel)}
/* Prompt-assist fields: overlay the square loader (centered) while AI drafts. */
.ta-wrap{position:relative}
.ta-wrap textarea{display:block}
.field-loader{position:absolute;inset:0;display:none;place-items:center;background:var(--panel-2);border:2px solid var(--ink);color:var(--accent);z-index:2}
.ta-wrap.loading .field-loader{display:grid}
.assist-info{font-size:12px;color:var(--txt-2)}
.pulse{animation:pulse 1s ease-in-out infinite}
@keyframes pulse{50%{opacity:.45}}
.cast-block{margin-top:22px;border-top:2px solid var(--line-soft);padding-top:18px}
.cast-head{display:flex;flex-direction:column;gap:18px}
.cast-controls{display:grid;grid-template-columns:minmax(0,1fr);align-items:start;gap:14px;min-width:0;width:100%}
.cast-controls .ctl{min-width:0}
.cast-controls .combo{display:block;width:100%}
.cast-controls .combo input{display:block;width:100%}
.cast-controls .btn{height:50px;white-space:nowrap;margin-bottom:0;align-self:start;justify-content:center;width:100%}
.cast-controls .ctl label{font-size:11px;font-weight:700;color:var(--txt-2);margin-bottom:8px;display:block;text-transform:uppercase;letter-spacing:.04em}
.cast-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;margin-top:16px}
.cast-grid:empty{display:none}
.cast-card{border:2px solid var(--ink);background:var(--panel);box-shadow:3px 3px 0 var(--shadow-col)}
.cast-card .cc-img{position:relative;aspect-ratio:1/1;overflow:hidden;border-bottom:2px solid var(--ink);background:#0a0d10;display:grid;place-items:center}
.cast-card .cc-img img{width:100%;height:100%;object-fit:cover}
.cast-card .cc-img .cc-loading{position:absolute;inset:0;display:grid;place-items:center;background:rgba(8,10,14,.72);
  font-family:'Silkscreen',monospace;font-size:9px;color:#fff;letter-spacing:.04em;text-align:center;padding:8px}
.cast-card .cc-img .cc-err{position:absolute;inset:0;display:grid;place-items:center;text-align:center;padding:8px;font-size:9px;color:#ffb4a0;background:#2a1215}
.cast-card .cc-img .cc-preview-ph{position:absolute;inset:0;display:grid;place-items:center;text-align:center;padding:12px;font-size:9px;color:var(--txt-3);background:var(--panel-2);gap:6px}
.cast-card .cc-img .cc-preview-ph span{line-height:1.4;text-transform:uppercase;letter-spacing:.04em}
.cast-card .cc-refresh{position:absolute;top:6px;right:6px;z-index:3;width:26px;height:26px;display:grid;place-items:center;
  border:2px solid var(--ink);background:var(--panel);color:var(--ink);box-shadow:2px 2px 0 var(--shadow-col)}
.cast-card .cc-refresh:hover{background:var(--accent);color:var(--accent-ink)}
.cast-card .cc-refresh:disabled{opacity:.6;pointer-events:none}
.cast-card .cc-refresh svg{width:13px;height:13px}
.cast-card .cc-refresh.spinning svg{animation:spin .8s linear infinite}
.cast-card .cc-refresh .cc-refresh-cost{position:absolute;top:-9px;right:-9px;min-width:16px;height:16px;padding:0 3px;display:grid;place-items:center;
  font-family:'Space Mono',monospace;font-size:9px;font-weight:700;line-height:1;border:2px solid var(--ink);background:var(--accent);color:var(--accent-ink);border-radius:9px}
.cast-card .cc-meta{padding:9px 10px}
.cast-card .cc-name{font-size:11px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cast-card .cc-prompt-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:6px;font-size:9px;color:var(--txt-3);text-transform:uppercase;letter-spacing:.06em;font-weight:700}.cast-card .cc-edit{border:2px solid var(--ink);background:var(--panel-2);color:var(--ink);width:24px;height:22px;display:grid;place-items:center;box-shadow:1px 1px 0 var(--shadow-col);font-size:12px;line-height:1}.cast-card .cc-edit:hover{background:var(--accent);color:var(--accent-ink)}.cast-card .cc-edit:disabled{opacity:.5;pointer-events:none}.cast-card .cc-prompt-edit{width:100%;min-height:92px;margin-top:5px;font-size:10.5px;line-height:1.4;padding:8px;resize:vertical;background:var(--panel-2);border:2px solid var(--ink);color:var(--txt)}
.cast-card .cc-desc{font-size:10.5px;color:var(--txt-2);margin-top:3px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.loadblock{background:var(--panel-2);color:transparent!important;animation:pulse 1s ease-in-out infinite;position:relative;overflow:hidden}
.loadblock::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(214,85,46,.18),transparent);
  transform:translateX(-100%);animation:shimmer 1.2s ease-in-out infinite}
@keyframes shimmer{100%{transform:translateX(100%)}}
.dots::after{content:"";animation:dots 1.2s steps(4,end) infinite}
@keyframes dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}100%{content:""}}
.indeterminate{height:6px;border:2px solid var(--ink);background:var(--panel-2);overflow:hidden;margin-top:10px}
.indeterminate i{display:block;height:100%;width:35%;background:var(--accent);animation:indeterminate 1.1s ease-in-out infinite}
@keyframes indeterminate{0%{transform:translateX(-120%)}100%{transform:translateX(330%)}}

/* Reusable loader: three squares whose highlight sweeps left→right→left like a
   scanner. Inherits color via currentColor, so it adapts to whatever container
   it sits in. Use .lg for bigger squares inside overlays, and wrap with
   .sq-loading-box to stack a label beneath it (centered). */
.sq-loader{display:inline-flex;gap:5px;align-items:center;justify-content:center;line-height:0}
.sq-loader i{display:block;width:8px;height:8px;background:currentColor;opacity:.2}
.sq-loader.lg{gap:6px}
.sq-loader.lg i{width:11px;height:11px}
.sq-loader i:nth-child(1){animation:sqSweep0 1.2s linear infinite}
.sq-loader i:nth-child(2){animation:sqSweep1 1.2s linear infinite}
.sq-loader i:nth-child(3){animation:sqSweep2 1.2s linear infinite}
@keyframes sqSweep0{0%,24%{opacity:1}25%,100%{opacity:.2}}
@keyframes sqSweep1{0%,24%{opacity:.2}25%,49%{opacity:1}50%,74%{opacity:.2}75%,99%{opacity:1}100%{opacity:.2}}
@keyframes sqSweep2{0%,49%{opacity:.2}50%,74%{opacity:1}75%,100%{opacity:.2}}
.sq-loading-box{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;text-align:center}
@media(prefers-reduced-motion:reduce){.sq-loader i{animation:none;opacity:.55}}

/* ===================== STEP 4 GENERATE ===================== */
.gen-grid{grid-template-columns:1.5fr 1fr}
@media(max-width:920px){.gen-grid{grid-template-columns:1fr}}
.controls{padding:22px;display:grid;gap:18px;grid-template-columns:1fr 1fr}
@media(max-width:620px){.controls{grid-template-columns:1fr}}
.controls .full{grid-column:1/-1}
.ctl label{font-size:11px;font-weight:700;color:var(--txt-2);margin-bottom:8px;display:block;text-transform:uppercase;letter-spacing:.04em}
.selectwrap{position:relative}
.selectwrap svg{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--ink);pointer-events:none}
select,input[type=number],input[type=text]{width:100%;background:var(--panel-2);border:2px solid var(--ink);
  padding:11px 13px;color:var(--txt);font-size:13px;font-weight:700;appearance:none}
select:focus,input:focus{outline:3px solid var(--accent);outline-offset:-1px;background:var(--panel)}
.refzone{border:2px dashed var(--ink);padding:14px;display:flex;align-items:center;gap:13px;background:var(--panel-2);cursor:pointer;transition:.12s}
.refzone:hover{background:var(--accent-soft)}
.refzone.disabled{opacity:.45;pointer-events:none;border-style:solid}
.refzone .rico{width:40px;height:40px;border:2px solid var(--ink);background:var(--panel);display:grid;place-items:center;color:var(--accent);overflow:hidden}
.refzone .rico svg{width:19px;height:19px}
.refzone .rico img{width:100%;height:100%;object-fit:cover}
.refzone .rt{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.03em}
.refzone .rh{font-size:11px;color:var(--txt-3);margin-top:3px}
.refzone .ref-clear{margin-left:auto;flex:none;width:34px;height:34px;border:2px solid var(--ink);background:var(--panel);color:var(--ink);font-size:20px;line-height:1;display:grid;place-items:center;box-shadow:2px 2px 0 var(--shadow-col)}
.refzone .ref-clear:hover{background:var(--accent);color:var(--accent-ink)}
.controls .cast-block{margin-top:0;border-top:none;padding-top:0;min-width:0}
.controls .cast-block .assist-info{max-width:62ch;line-height:1.65}

.gen-side{padding:22px;display:flex;flex-direction:column;gap:16px}
.meter-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.meter-row .k{font-size:11px;color:var(--txt-3);text-transform:uppercase;letter-spacing:.04em}
.meter-row .v{font-family:'Silkscreen',monospace;font-size:14px}
.meter-row .v.accent{color:var(--accent)}
.qbar{height:14px;border:2px solid var(--ink);background:var(--panel-2);padding:2px}
.qbar i{display:block;height:100%;background:var(--accent);transition:width .35s steps(12)}
.quality-hint{font-size:11.5px;color:var(--txt-2);line-height:1.55;background:var(--panel-2);border:2px solid var(--ink);padding:12px;min-height:92px;display:flex;align-items:center}
.est-box{margin-top:auto;background:var(--accent-soft);border:2px solid var(--ink);padding:15px;box-shadow:3px 3px 0 var(--shadow-col)}
.est-box .big{font-family:'Silkscreen',monospace;font-size:26px;color:var(--accent)}
.est-box .lbl{font-size:11px;color:var(--txt-2);margin-top:7px}
.gen-progress{display:flex;align-items:center;gap:12px}
.gen-progress .render-track{flex:1}

/* ===================== STEP 5 GALLERY ===================== */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:20px}
@media(max-width:980px){.gallery{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.gallery{grid-template-columns:repeat(2,1fr)}}
@media(max-width:440px){.gallery{grid-template-columns:1fr}}
.tile{border:2px solid var(--ink);background:var(--panel);transition:transform .1s, box-shadow .1s;cursor:pointer}
.tile:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--shadow-col)}
.tile .img{aspect-ratio:16/9;position:relative;overflow:hidden;border-bottom:2px solid var(--ink);background:#0a0d10}
.tile .img svg,.tile .img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.tile .img .ph-idx{font-family:'Silkscreen',monospace;font-size:10px;color:var(--accent-ink);background:var(--ink);
  padding:4px 6px;position:absolute;top:7px;left:7px;z-index:2}
.tile .img .ph-tag{position:absolute;bottom:7px;right:7px;font-size:8.5px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--ink);background:rgba(255,255,255,.82);padding:3px 6px;z-index:2}
.tile .img .ph-err{position:absolute;inset:0;display:grid;place-items:center;text-align:center;padding:10px;font-size:10px;color:#ffb4a0;background:#2a1215;z-index:3}
.tile .img .tile-refresh{position:absolute;top:7px;right:7px;z-index:4;width:28px;height:28px;display:grid;place-items:center;
  border:2px solid var(--ink);background:var(--panel);color:var(--ink);box-shadow:2px 2px 0 var(--shadow-col);transition:transform .08s,box-shadow .08s}
.tile .img .tile-refresh:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--shadow-col);background:var(--accent);color:var(--accent-ink)}
.tile .img .tile-refresh:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--shadow-col)}
.tile .img .tile-refresh svg{width:15px;height:15px}
.tile .img .tile-refresh:disabled{opacity:.6;pointer-events:none}
.tile .img .tile-refresh.spinning svg{animation:spin .8s linear infinite}
.tile .img .tile-refresh .tile-refresh-cost{position:absolute;top:-9px;right:-9px;min-width:16px;height:16px;padding:0 3px;display:grid;place-items:center;
  font-family:'Space Mono',monospace;font-size:9px;font-weight:700;line-height:1;border:2px solid var(--ink);background:var(--accent);color:var(--accent-ink);border-radius:9px}
@keyframes spin{100%{transform:rotate(360deg)}}
.tile .img .tile-loading{position:absolute;inset:0;display:grid;place-items:center;background:rgba(8,10,14,.72);z-index:5;
  font-family:'Silkscreen',monospace;font-size:10px;color:#fff;letter-spacing:.04em}
.tile .img .tile-prompt-btn{position:absolute;top:7px;right:41px;z-index:4;width:28px;height:28px;display:grid;place-items:center;border:2px solid var(--ink);background:var(--panel);color:var(--ink);box-shadow:2px 2px 0 var(--shadow-col);transition:transform .08s,box-shadow .08s}
.tile .img .pending-edit-btn{right:7px}
.tile .img .tile-prompt-btn:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--shadow-col);background:var(--accent);color:var(--accent-ink)}
.tile .img .tile-prompt-btn:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--shadow-col)}
.tile .img .tile-prompt-btn svg{width:14px;height:14px}
.tile .meta{padding:10px 11px;position:relative}
.tile .meta .fn{font-size:11px;color:var(--accent);font-weight:700}
.tile .meta .cap-row{display:flex;align-items:flex-start;gap:5px;margin-top:4px}
.tile .meta .cap-edit-btn{flex-shrink:0;margin-top:1px;width:18px;height:18px;display:grid;place-items:center;border:2px solid var(--line-soft);background:var(--panel-2);color:var(--txt-3);opacity:.6;transition:opacity .1s}
.tile .meta .cap-edit-btn:hover{opacity:1;border-color:var(--ink);color:var(--ink)}
.tile .meta .cap-edit-pop{margin-top:6px;display:grid;gap:6px}
.tile .meta .cap-edit-pop[hidden]{display:none}
.tile .meta .cap-edit-area{width:100%;border:2px solid var(--ink);background:var(--panel-2);color:var(--txt);font-size:11px;padding:6px 7px;resize:vertical;line-height:1.4}
.tile .meta .cap{font-size:11px;color:var(--txt-2);flex:1;line-height:1.45;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tile .meta .tile-prompt-pop{position:absolute;left:8px;right:8px;bottom:calc(100% - 2px);z-index:20;
  border:2px solid var(--ink);background:var(--panel);box-shadow:4px 4px 0 var(--shadow-col);padding:10px;display:flex;flex-direction:column;gap:8px}
.tile .meta .tile-prompt-pop[hidden]{display:none}
.tile .meta .tile-prompt-pop label{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--txt-3)}
.tile .meta .tile-prompt-pop .prompt-not-ready{font-size:11px;color:var(--txt-2);line-height:1.5;margin:6px 0 0}
.tile .meta .tile-prompt-pop .tile-prompt-edit{width:100%;border:2px solid var(--ink);background:var(--panel-2);color:var(--txt);
  font-family:'Space Mono',monospace;font-size:11px;line-height:1.45;padding:8px;resize:vertical;min-height:90px}
.tile .meta .tile-prompt-actions{display:flex;gap:8px;justify-content:flex-end}
.tile .meta .tile-prompt-actions button{border:2px solid var(--ink);background:var(--panel);box-shadow:2px 2px 0 var(--shadow-col);
  padding:6px 10px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--ink);cursor:pointer}
.tile .meta .tile-prompt-actions .tpp-apply{background:var(--accent);color:var(--accent-ink)}
.tile .meta .tile-prompt-actions button:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--shadow-col)}

/* ===================== STEP 6 EDITOR ===================== */
.editor .win-bar{background:var(--accent);color:var(--accent-ink)}
.editor .win-bar .lights i{border-color:var(--accent-ink)}
.editor .win-bar .lights i.fill{background:var(--accent-ink)}
.editor .win-bar .wmeta{color:var(--accent-ink);opacity:.8}
.editor-body{padding:22px;display:flex;flex-direction:column;gap:18px}
.editor-top{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.editor-top .label{font-size:10.5px;color:var(--txt-3);text-transform:uppercase;letter-spacing:.08em;font-weight:700}
.editor-top h3{font-family:'Silkscreen',monospace;margin:5px 0 0;font-size:16px}
.quality-est{font-size:10.5px;color:var(--txt-3);margin-top:6px;font-weight:700;letter-spacing:.03em}
.quality-est b{color:var(--accent);font-family:'Silkscreen',monospace;font-size:11px}
.export-controls{display:flex;flex-direction:column}
.export-q-label{font-size:11px;font-weight:700;color:var(--txt-2);margin-bottom:8px;display:block;text-transform:uppercase;letter-spacing:.04em}
.subtitle-controls{display:flex;gap:10px;align-items:center;justify-content:flex-end;margin-top:10px;flex-wrap:wrap}.checkline{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--txt-2);text-transform:uppercase;letter-spacing:.04em}.checkline input{width:16px;height:16px;accent-color:var(--accent)}.subtitle-select{width:230px;min-width:210px}.subtitle-select select{font-size:12px;padding-top:10px;padding-bottom:10px}
.export-row{display:flex;align-items:stretch;gap:12px;flex-wrap:wrap}
.export-row .selectwrap{min-width:190px}
.export-row .selectwrap select{height:100%}
.export-row .btn{white-space:nowrap}

/* custom combobox (typeable dropdown) */
.combo{position:relative}
.combo input{padding-right:42px}
.combo-toggle{position:absolute;right:0;top:0;height:100%;width:38px;display:grid;place-items:center;
  border:none;background:transparent;color:var(--ink);cursor:pointer}
.combo-toggle svg{width:16px;height:16px;transition:transform .15s}
.combo[aria-open="true"] .combo-toggle svg{transform:rotate(180deg)}
.combo-list{position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:40;margin:0;padding:0;list-style:none;
  max-height:260px;overflow:auto;border:2px solid var(--ink);background:var(--panel);box-shadow:4px 4px 0 var(--shadow-col)}
.combo-list[hidden]{display:none}
.combo-list li{padding:10px 13px;font-size:13px;font-weight:700;cursor:pointer;border-bottom:2px solid var(--line-soft)}
.combo-list li:last-child{border-bottom:none}
.combo-list li:hover,.combo-list li.active{background:var(--accent-soft)}
.combo-list li[aria-selected="true"]{border-left:4px solid var(--accent);padding-left:9px}

.preview{position:relative;aspect-ratio:16/9;width:100%;overflow:hidden;border:2px solid var(--ink);background:#0a0d10;display:grid;place-items:center;box-shadow:inset 0 0 0 4px rgba(0,0,0,.5)}
.preview canvas{position:absolute;inset:0;width:100%;height:100%}
.scanlines{position:absolute;inset:0;z-index:3;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4'%3E%3Crect width='4' height='1' y='0' fill='%23000' fill-opacity='0.35'/%3E%3C/svg%3E")}
.pv-cap{position:absolute;left:0;right:0;bottom:0;padding:14px 16px;z-index:4;background:rgba(8,10,14,.78);
  font-size:13px;line-height:1.45;color:#fff;border-top:2px solid rgba(255,255,255,.25); text-align:center;}
.pv-idx{position:absolute;top:12px;left:12px;z-index:4;font-family:'Silkscreen',monospace;font-size:10px;
  background:var(--accent);color:var(--accent-ink);padding:5px 8px}
.pv-live{position:absolute;top:12px;right:12px;z-index:4;display:flex;align-items:center;gap:6px;font-size:9.5px;font-weight:700;
  letter-spacing:.08em;background:rgba(8,10,14,.7);color:#fff;padding:5px 9px;border:2px solid rgba(255,255,255,.3)}
.pv-live .d{width:7px;height:7px;background:var(--good);animation:blink 1s steps(1) infinite}

.transport{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.tcontrols{display:flex;align-items:center;gap:8px}
.tbtn{width:42px;height:42px;border:2px solid var(--ink);background:var(--panel);color:var(--ink);display:grid;place-items:center;
  box-shadow:3px 3px 0 var(--shadow-col);transition:transform .08s,box-shadow .08s}
.tbtn:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--shadow-col)}
.tbtn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--shadow-col)}
.tbtn svg{width:18px;height:18px}
.tbtn.play{width:52px;height:52px;background:var(--accent);color:var(--accent-ink)}
.tbtn.play svg{width:22px;height:22px}
.time-read{font-family:'Silkscreen',monospace;font-size:13px;color:var(--txt-2)}
.time-read b{color:var(--ink)}
.vol{display:flex;align-items:center;gap:9px;margin-left:auto}
.vol svg{width:18px;height:18px;color:var(--txt-2)}
.vol input[type=range]{width:92px}

.tl-wrap{position:relative}
.tl-labels{display:flex;justify-content:space-between;font-family:'Silkscreen',monospace;font-size:9px;color:var(--txt-3);margin-bottom:7px}
.timeline{position:relative;display:flex;gap:2px;height:70px;border:2px solid var(--ink);background:var(--ink);cursor:pointer;overflow:hidden}
.clip{position:relative;height:100%;overflow:hidden;min-width:8px;background-size:cover;background-position:center}
.clip svg{position:absolute;inset:0;width:100%;height:100%}
.clip .clip-num{position:absolute;top:5px;left:6px;font-family:'Silkscreen',monospace;font-size:9px;color:#fff;text-shadow:1px 1px 0 #000;z-index:2}
.clip .clip-dur{position:absolute;bottom:4px;left:6px;font-size:8.5px;font-weight:700;color:#fff;text-shadow:1px 1px 0 #000;z-index:2}
.clip::after{content:"";position:absolute;inset:0;background:rgba(8,10,14,.4);transition:.12s;z-index:1}
.clip.active::after{background:transparent}
.clip.active .clip-ring{position:absolute;inset:0;border:3px solid var(--accent);z-index:3}

.wave-wrap{position:relative;margin-top:9px;border:2px solid var(--ink);background:var(--panel-2);cursor:pointer;height:82px;overflow:hidden}
.wave-wrap canvas{display:block;width:100%;height:100%}
.seg-dividers{position:absolute;inset:0;pointer-events:none}
.seg-dividers i{position:absolute;top:0;bottom:0;width:2px;background:var(--line-soft)}

.playhead{position:absolute;top:-2px;bottom:-2px;width:3px;background:var(--accent);z-index:6;pointer-events:none}
.playhead::before{content:"";position:absolute;top:-2px;left:50%;transform:translateX(-50%);width:13px;height:9px;background:var(--accent);border:2px solid var(--ink)}
.ph-grip{position:absolute;top:0;left:50%;transform:translateX(-50%);width:18px;height:100%;cursor:ew-resize;pointer-events:auto}

.export-bar{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.render-label{font-size:11px;color:var(--txt-3);font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.render-track{flex:1;min-width:200px;height:16px;border:2px solid var(--ink);background:var(--panel-2);overflow:hidden;padding:2px}
.render-track i{display:block;height:100%;width:0;background:var(--accent);transition:width .18s steps(8)}
.render-track.idle{opacity:.5}
.render-pct{font-family:'Silkscreen',monospace;font-size:12px;min-width:46px;text-align:right}
.music-panel{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;border:2px solid var(--ink);background:var(--panel-2);padding:14px;box-shadow:3px 3px 0 var(--shadow-col)}
.music-name{font-weight:700;font-size:13px;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:58ch}
.music-note{font-size:11px;color:var(--txt-3);line-height:1.5;margin-top:5px}
.music-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.music-vol{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--txt-2);display:flex;align-items:center;gap:8px;white-space:nowrap}
.music-vol input{width:120px}
@media(max-width:820px){.music-panel{grid-template-columns:1fr}.music-actions{justify-content:flex-start}.music-vol{width:100%}.music-vol input{flex:1}}

/* ===================== COST ===================== */
.cost-grid{grid-template-columns:1.3fr 1fr;align-items:start}
@media(max-width:860px){.cost-grid{grid-template-columns:1fr}}
.cost-lines .cost-line{display:flex;align-items:center;gap:13px;padding:14px 18px;border-bottom:2px solid var(--line-soft)}
.cost-lines .cost-line:last-child{border-bottom:none}
.cost-line .ci{width:34px;height:34px;border:2px solid var(--ink);background:var(--panel-2);display:grid;place-items:center;color:var(--accent);flex:none}
.cost-line .ci svg{width:16px;height:16px}
.cost-line .cl-main{flex:1;min-width:0}
.cost-line .cl-main .t{font-size:12.5px;font-weight:700}
.cost-line .cl-main .s{font-size:11px;color:var(--txt-3)}
.cost-line .amt{font-family:'Silkscreen',monospace;font-size:13px}
.cost-summary{padding:24px;display:flex;flex-direction:column;gap:15px;background:var(--accent-soft)}
.cost-summary .row{display:flex;align-items:center;justify-content:space-between}
.cost-summary .row .k{font-size:12px;color:var(--txt-2);text-transform:uppercase;letter-spacing:.03em}
.cost-summary .row .v{font-family:'Silkscreen',monospace;font-size:13px}
.cost-total{padding-top:15px;border-top:2px solid var(--ink)}
.cost-total .k{font-size:11px;color:var(--txt-2);text-transform:uppercase;letter-spacing:.06em;font-weight:700}
.cost-total .big{font-family:'Silkscreen',monospace;font-size:34px;color:var(--accent);margin-top:8px}
.cost-note{font-size:10.5px;color:var(--txt-3);line-height:1.5}

footer{padding:46px 0 64px;color:var(--txt-3);font-size:11px;border-top:2px solid var(--ink);margin-top:54px;text-transform:uppercase;letter-spacing:.04em}

.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(18px);z-index:100;
  background:var(--ink);color:var(--panel);border:2px solid var(--ink);padding:12px 18px;font-size:12px;font-weight:700;
  box-shadow:4px 4px 0 var(--shadow-col);opacity:0;transition:.2s;pointer-events:none;display:flex;align-items:center;gap:10px;text-transform:uppercase;letter-spacing:.03em}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast .d{width:8px;height:8px;background:var(--good)}
.toast.err .d{background:var(--accent)}

/* ===================== GUIDE MODAL ===================== */
.guide-modal{position:fixed;inset:0;z-index:130;background:rgba(0,0,0,.58);display:grid;place-items:center;padding:18px}
.guide-modal.hidden{display:none!important}
.guide-card{width:min(660px,100%);max-height:90vh;overflow-y:auto;border:2px solid var(--ink);background:var(--panel);box-shadow:8px 8px 0 var(--shadow-col)}
.guide-body{padding:28px 28px 32px;display:grid;gap:14px}
.guide-body h2{font-family:'Silkscreen',monospace;font-size:clamp(16px,2.4vw,24px);margin:4px 0 8px}
.guide-steps{margin:0;padding-left:22px;display:grid;gap:14px;list-style:decimal}
.guide-steps li{font-size:13px;line-height:1.65;color:var(--txt-2)}
.guide-steps li strong{display:block;font-family:'Silkscreen',monospace;font-size:11px;letter-spacing:.04em;color:var(--ink);margin-bottom:3px;text-transform:uppercase}
.guide-steps li span{display:block}

/* ===================== AUDIO RECORDER ===================== */
.audio-modal{position:fixed;inset:0;z-index:130;background:rgba(0,0,0,.58);display:grid;place-items:center;padding:18px}
.audio-modal.hidden{display:none!important}
.audio-card{width:min(1040px,100%);max-height:92vh;overflow:auto;border:2px solid var(--ink);background:var(--panel);box-shadow:8px 8px 0 var(--shadow-col)}
.audio-body{padding:22px;display:grid;gap:16px}
.audio-hero{display:grid;place-items:center;text-align:center;gap:18px}
.audio-hero-copy{display:grid;place-items:center;gap:10px;width:100%}
.audio-hero h2{font-family:'Silkscreen',monospace;font-size:clamp(20px,3vw,34px);line-height:1.2;margin:0;color:var(--ink)}
.audio-hero p{margin:8px 0 0;color:var(--txt-2);font-size:13px;line-height:1.6;max-width:78ch}
.timeline-ruler-row{display:flex;align-items:stretch}
.track-sidebar-space{width:80px;flex:none;border-right:2px solid var(--ink);background:var(--panel);border-bottom:1px solid var(--line-soft)}
.timeline-ruler{flex:1;display:block;min-width:0;background:var(--panel);border-bottom:2px solid var(--ink)}
.track-area{display:flex;flex-direction:column;gap:2px;overflow-y:auto;max-height:340px}
.track-row{display:flex;align-items:stretch;border:2px solid var(--ink);cursor:default;transition:border-color .1s}
.track-row.active{border-color:var(--accent)}
.track-row.drag-over{opacity:.55}
.track-sidebar{width:80px;flex:none;display:flex;flex-direction:column;justify-content:space-between;border-right:2px solid var(--ink);background:var(--panel);padding:5px 7px;gap:4px}
.track-sidebar-top{display:flex;align-items:center;gap:4px}
.track-drag{width:22px;height:22px;display:grid;place-items:center;cursor:grab;color:var(--txt-2);flex:none}
.track-drag svg{width:14px;height:14px}
.track-drag:active{cursor:grabbing}
.track-name{font-size:9px;font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:.04em;border:none;background:transparent;flex:1;min-width:0;padding:0;outline:none;font-family:inherit;overflow:hidden;text-overflow:ellipsis}
.track-name:focus{background:var(--panel-2);outline:1px solid var(--accent);padding:1px 3px}
.track-actions{display:flex;gap:3px}
.track-mute,.track-del{height:18px;padding:0 5px;border:1px solid var(--ink);background:var(--panel-2);color:var(--txt-2);font-size:9px;font-weight:700;display:grid;place-items:center;cursor:pointer;font-family:inherit;text-transform:uppercase}
.track-mute.muted{background:var(--accent);color:var(--accent-ink)}
.track-del:hover{background:#4b1717;color:#fff}
.track-wave{flex:1;display:block;min-width:0;cursor:crosshair}
.track-ctx-menu{position:fixed;z-index:500;background:var(--panel-2);border:2px solid var(--ink);box-shadow:4px 4px 0 var(--shadow-col);display:flex;flex-direction:column;min-width:170px}
.ctx-item{width:100%;padding:9px 14px;border:none;background:transparent;color:var(--ink);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.04em;text-align:left;cursor:pointer;font-family:inherit;border-bottom:1px solid var(--line-soft)}
.ctx-item:last-child{border-bottom:none}
.ctx-item:hover{background:var(--accent);color:var(--accent-ink)}
.ctx-item.ctx-danger:hover{background:#4b1717;color:#fff}
.track-ctx-menu.hidden{display:none}
.track-resize-bar{height:9px;background:var(--panel-3);border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);cursor:ns-resize;flex:none;display:flex;align-items:center;justify-content:center;transition:background .1s}
.track-resize-bar::after{content:"· · · · ·";font-size:8px;letter-spacing:3px;color:var(--txt-3);pointer-events:none;line-height:1}
.track-resize-bar:hover{background:var(--accent);border-color:var(--accent)}
.track-resize-bar:hover::after{color:var(--accent-ink)}
.track-resize-bar:active{background:var(--accent-2)}
.track-add-btn{width:100%;border:2px dashed var(--ink);background:transparent;color:var(--txt-2);font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.04em;padding:6px;cursor:pointer;font-family:inherit;margin-top:3px;text-align:center}
.track-add-btn:hover{border-style:solid;background:var(--panel-2)}
.wave-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.wave-hint{font-size:10px;color:var(--txt-3);font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.zoom-btns{display:flex;align-items:center;gap:5px}
.zoom-level{font-family:'Silkscreen',monospace;font-size:11px;color:var(--accent);min-width:28px;text-align:right}
.zoom-btn{width:28px;height:28px;border:2px solid var(--ink);background:var(--panel-2);color:var(--ink);font-weight:700;font-size:15px;display:grid;place-items:center;cursor:pointer;box-shadow:2px 2px 0 var(--shadow-col);padding:0;font-family:inherit}
.zoom-btn:hover{background:var(--panel-3)}
.audio-range{display:grid;grid-template-columns:1fr 1fr auto;align-items:center;gap:12px}
.audio-range label{display:grid;gap:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--txt-2)}
.audio-range input{width:100%}
#recordPreview{display:none}
.transport-bar{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.tbtn-group{display:flex}
.tbtn-group .tbtn{border-right:none}
.tbtn-group .tbtn:last-child{border-right:2px solid var(--ink)}
.tbtn{width:34px;height:34px;border:2px solid var(--ink);background:var(--panel-2);color:var(--ink);display:grid;place-items:center;cursor:pointer;padding:0;flex:none;box-shadow:2px 2px 0 var(--shadow-col);transition:background .07s}
.tbtn svg{width:15px;height:15px}
.tbtn:hover:not(:disabled){background:var(--panel-3)}
.tbtn:active:not(:disabled){background:var(--ink);color:var(--panel)}
.tbtn:disabled{opacity:.38;pointer-events:none}
.tbtn.on{background:var(--ink);color:var(--panel)}
.tbtn-rec{color:#d03030}
.tbtn-rec .rec-dot{width:12px;height:12px;background:currentColor;display:block;border-radius:50%}
.tbtn-rec.recording{background:#d03030;color:#fff;animation:pulse 1s ease-in-out infinite}
.tbtn-rec.recording .rec-dot{border-radius:2px}
.tbtn-save{background:var(--accent);color:var(--accent-ink);border-color:var(--ink)}
.tbtn-save:hover:not(:disabled){background:var(--accent-2)}
[data-tip]{position:relative}
[data-tip]:hover::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--ink);color:var(--panel);font-size:10px;font-weight:700;white-space:nowrap;padding:3px 7px;pointer-events:none;z-index:400;letter-spacing:.04em;text-transform:uppercase;box-shadow:2px 2px 0 var(--shadow-col)}
.tbtn-sep-v{width:1px;height:28px;background:var(--ink);opacity:.3;flex:none;margin:0 2px}
.transport-time{font-family:'Silkscreen',monospace;font-size:12px;color:var(--accent);min-width:52px;text-align:center}
.speed-btn{font-size:10px;font-weight:700;width:auto;padding:0 10px;letter-spacing:.02em}
.audio-boost{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.boost-label{display:flex;align-items:center;gap:10px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--txt-2);flex:1;min-width:200px}
.boost-label input[type=range]{flex:1;min-width:80px;accent-color:var(--accent)}
.boost-label #boostReadout{font-family:'Silkscreen',monospace;font-size:12px;color:var(--accent);min-width:32px}
.audio-note{font-size:11px;color:var(--txt-3);text-transform:uppercase;letter-spacing:.04em}
@media(max-width:720px){
  .record-main{width:100%}#recordPreview{min-width:100%;flex-basis:100%}
  .audio-range{grid-template-columns:1fr}.audio-actions{justify-content:stretch}.audio-actions .btn{flex:1}
  /* Voice recorder becomes a full-screen sheet that fits the viewport */
  .audio-modal{padding:0}
  .audio-card{width:100%;max-width:100%;height:100vh;height:100svh;max-height:100svh;display:flex;flex-direction:column;overflow:hidden;border:none;box-shadow:none}
  .audio-body{padding:14px;gap:12px;overflow-y:auto;flex:1;min-height:0;-webkit-overflow-scrolling:touch}
  .audio-hero{gap:10px}
  .audio-hero p{font-size:12px}
  .track-sidebar,.track-sidebar-space{width:64px}
  .track-sidebar{padding:5px}
  .track-area{max-height:40vh}
  .wave-hint{display:none}
  .wave-toolbar{justify-content:flex-end}
  .transport-bar{justify-content:center;gap:5px}
}
@media(max-width:420px){
  .track-sidebar,.track-sidebar-space{width:56px}
  .track-name{font-size:8px}
  .track-mute,.track-del{padding:0 4px;font-size:8px}
  .tbtn{width:32px;height:32px}
  .tbtn svg{width:14px;height:14px}
  .speed-btn{padding:0 8px}
  .boost-label{min-width:100%}
}

/* ===================== AUTH SNACKBAR ===================== */
.auth-snackbar,.billing-snackbar{position:fixed;inset:0;z-index:120;padding:0 18px 18px;display:flex;align-items:flex-end;justify-content:center;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.38));animation:snackIn .22s ease-out both}
.auth-snackbar.hidden,.billing-snackbar.hidden{display:none!important}
.auth-card{width:min(1180px,100%);border:2px solid var(--ink);background:var(--panel);box-shadow:6px 6px 0 var(--shadow-col)}
.billing-card{width:min(1180px,100%);border:2px solid var(--ink);background:var(--panel);box-shadow:6px 6px 0 var(--shadow-col)}
.auth-close{margin-left:auto;border:2px solid var(--panel);background:transparent;color:var(--panel);width:28px;height:26px;display:grid;place-items:center;font-size:18px;line-height:1;font-weight:700}
.auth-body{padding:18px;display:grid;grid-template-columns:1fr .9fr 1fr;align-items:end;gap:18px}
.auth-copy .eyebrow{box-shadow:2px 2px 0 var(--shadow-col);font-size:10px}
.auth-copy h2{font-family:'Silkscreen',monospace;font-size:clamp(19px,3vw,28px);line-height:1.25;margin:18px 0 0;color:var(--ink)}
.auth-copy p{margin:10px 0 0;color:var(--txt-2);font-size:13px;line-height:1.6}
.auth-tabs{display:grid;grid-template-columns:1fr;border:2px solid var(--ink);box-shadow:2px 2px 0 var(--shadow-col)}
.auth-tabs button{border:0;background:var(--panel-2);color:var(--txt-2);font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:11px;font-size:12px}
.auth-tabs button+button{border-top:2px solid var(--ink)}
.auth-tabs button.on{background:var(--ink);color:var(--panel)}
.auth-form{display:grid;gap:10px}
.auth-form label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--txt-2)}
.auth-form input{width:100%;border:2px solid var(--ink);background:var(--panel-2);color:var(--txt);padding:12px;font-size:13px}
.auth-form input:focus{outline:3px solid var(--accent);outline-offset:-1px;background:var(--panel)}
.auth-form .btn{justify-content:center;margin-top:6px}
.btn.google{background:var(--panel-2);color:var(--ink)}
.auth-message{min-height:20px;font-size:11.5px;color:var(--txt-3);line-height:1.5}
.auth-message.err{color:var(--accent)}
@keyframes snackIn{from{transform:translateY(110%);opacity:.3}to{transform:translateY(0);opacity:1}}
.billing-body{padding:18px;display:grid;grid-template-columns:.85fr 1.4fr;align-items:start;gap:18px}
.billing-body h2{font-family:'Silkscreen',monospace;font-size:clamp(19px,3vw,28px);line-height:1.25;margin:18px 0 0;color:var(--ink)}
.billing-body p{margin:10px 0 0;color:var(--txt-2);font-size:13px;line-height:1.6}
.pack-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.pack-card{border:2px solid var(--ink);background:var(--panel-2);box-shadow:3px 3px 0 var(--shadow-col);padding:16px;display:grid;gap:10px;text-align:left;color:var(--ink)}
.pack-card:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--shadow-col);background:var(--accent-soft)}
.pack-card .pack-name{font-family:'Silkscreen',monospace;font-size:14px;color:var(--accent)}
.pack-card .pack-price{font-family:'Silkscreen',monospace;font-size:25px;color:var(--ink)}
.pack-card .pack-original{font-size:15px;color:var(--txt-3);text-decoration:line-through;margin-right:8px}
.pack-card .pack-credits{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--txt-2)}
.pack-card .pack-save{justify-self:start;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  color:var(--accent-ink);background:var(--accent);border:2px solid var(--ink);padding:4px 8px;box-shadow:2px 2px 0 var(--shadow-col)}
.pack-card .pack-save.base{color:var(--txt-3);background:transparent;border-color:var(--txt-3);box-shadow:none}
.pack-card.best{background:var(--accent-soft);box-shadow:4px 4px 0 var(--accent-2)}
.pack-card .pack-desc{font-size:11px;color:var(--txt-3);line-height:1.5;min-height:48px}
.pack-card .pack-cta{margin-top:4px;border-top:2px solid var(--ink);padding-top:10px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
@media(max-width:900px){
  .auth-body,.billing-body{grid-template-columns:1fr}
  .auth-snackbar,.billing-snackbar{padding:0 12px 12px}
  .auth-copy h2{margin-top:12px}
  .pack-grid{grid-template-columns:1fr}
  .auth-card,.billing-card{max-height:calc(100vh - 24px);max-height:calc(100svh - 24px);display:flex;flex-direction:column;overflow:hidden}
  .auth-body,.billing-body{overflow-y:auto;flex:1;min-height:0;-webkit-overflow-scrolling:touch}
}
