:root{
  --bg:#0a0a0b; --panel:#141416; --panel2:#1b1b1f; --line:#26262b;
  --ink:#f4f3ee; --mut:#8a8a92; --dim:#5b5b62;
  --signal:#ffc01e; --signal-dim:#b8901f; --heat:#e8432b; --heat-dim:#a8321f;
  --ok:#5fb838;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:'Familjen Grotesk',sans-serif}
body{
  min-height:100vh;
  background-image:radial-gradient(900px 500px at 80% -10%, rgba(255,192,30,.06), transparent 60%),
                   radial-gradient(700px 500px at -10% 110%, rgba(232,67,43,.05), transparent 60%);
}
/* grain */
body::after{content:"";position:fixed;inset:0;pointer-events:none;opacity:.035;z-index:9999;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
.wrap{max-width:880px;margin:0 auto;padding:48px 24px 96px}
.mono{font-family:'JetBrains Mono',monospace}

/* header */
.head{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin-bottom:6px;
  animation:rise .6s cubic-bezier(.2,.8,.2,1) both}
.kicker{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--signal-dim)}
h1{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(34px,6vw,58px);line-height:.95;letter-spacing:-.02em}
h1 .dot{color:var(--signal)}
.sub{color:var(--mut);font-size:15px;margin-top:14px;max-width:60ch;animation:rise .6s .06s cubic-bezier(.2,.8,.2,1) both}
.stage{display:inline-flex;align-items:center;gap:8px;margin-top:18px;font-family:'JetBrains Mono',monospace;
  font-size:11px;letter-spacing:.1em;color:var(--dim);animation:rise .6s .1s both}
.stage b{color:var(--signal)}
.stage .bar{width:120px;height:4px;background:var(--panel2);border-radius:3px;overflow:hidden;border:1px solid var(--line)}
.stage .bar i{display:block;height:100%;width:33%;background:var(--signal)}

/* input */
.console{margin-top:34px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:8px;
  box-shadow:0 30px 80px -40px rgba(0,0,0,.9);animation:rise .6s .14s both}
.inrow{display:flex;gap:8px;align-items:center}
.inrow .ic{padding:0 6px 0 14px;color:var(--signal);font-family:'JetBrains Mono',monospace;font-size:15px}
input[type=text]{flex:1;background:transparent;border:0;outline:0;color:var(--ink);
  font-family:'JetBrains Mono',monospace;font-size:15px;padding:18px 6px}
input[type=text]::placeholder{color:var(--dim)}
.btn{border:0;cursor:pointer;font-family:'Bricolage Grotesque';font-weight:700;font-size:15px;
  background:var(--signal);color:#0c0c00;padding:16px 26px;border-radius:11px;letter-spacing:-.01em;
  transition:transform .12s ease, box-shadow .2s ease}
.btn:hover{transform:translateY(-1px);box-shadow:0 10px 30px -10px rgba(255,192,30,.5)}
.btn:active{transform:translateY(0)}
.btn[disabled]{opacity:.5;cursor:wait}
.hint{margin-top:12px;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--dim);letter-spacing:.04em}

/* generic card */
.card{margin-top:22px;background:var(--panel);border:1px solid var(--line);border-radius:16px;overflow:hidden;
  animation:rise .5s cubic-bezier(.2,.8,.2,1) both}
.card .pad{padding:22px}

/* video card */
.vid{display:flex;gap:20px}
.vid .thumb{width:240px;flex:0 0 240px;aspect-ratio:16/9;background:var(--panel2);
  background-size:cover;background-position:center;border-right:1px solid var(--line)}
.vid .body{padding:20px;flex:1;min-width:0}
.badges{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:12px}
.tag{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  padding:5px 9px;border-radius:6px;border:1px solid var(--line);color:var(--mut)}
.tag.short{color:var(--heat);border-color:var(--heat-dim)}
.tag.long{color:var(--signal);border-color:var(--signal-dim)}
.tag.cache{color:var(--ok);border-color:#3a5e2a}
.vtitle{font-family:'Bricolage Grotesque';font-weight:700;font-size:21px;line-height:1.15;letter-spacing:-.01em}
.chan{color:var(--mut);font-size:13px;margin-top:6px;font-family:'JetBrains Mono',monospace}
.stats{display:flex;gap:26px;margin-top:18px;flex-wrap:wrap}
.stat .n{font-family:'Bricolage Grotesque';font-weight:700;font-size:19px}
.stat .l{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);margin-top:2px}

/* section label */
.seclabel{display:flex;align-items:center;gap:10px;padding:14px 20px;border-top:1px solid var(--line);
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mut)}
.seclabel .led{width:7px;height:7px;border-radius:50%;background:var(--signal);box-shadow:0 0 10px var(--signal)}
.seclabel .led.warn{background:var(--heat);box-shadow:0 0 10px var(--heat)}

/* transcript */
.tscript{max-height:340px;overflow:auto;padding:18px 20px;border-top:1px solid var(--line);
  font-family:'JetBrains Mono',monospace;font-size:12.5px;line-height:1.85;color:#cfcfd4;white-space:pre-wrap}
.tscript::-webkit-scrollbar{width:10px}.tscript::-webkit-scrollbar-thumb{background:var(--line);border-radius:6px}
.tmeta{display:flex;gap:18px;padding:12px 20px;border-top:1px solid var(--line);
  font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--dim);letter-spacing:.06em}

/* paste fallback */
.paste{padding:20px;border-top:1px solid var(--line)}
.paste p{color:var(--mut);font-size:14px;line-height:1.6;margin-bottom:14px}
.paste .tip{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--signal-dim);
  background:rgba(255,192,30,.05);border:1px solid var(--signal-dim);border-radius:9px;padding:11px 13px;margin-bottom:14px;line-height:1.6}
textarea{width:100%;min-height:160px;background:var(--bg);border:1px solid var(--line);border-radius:11px;
  color:var(--ink);font-family:'JetBrains Mono',monospace;font-size:12.5px;line-height:1.7;padding:14px;resize:vertical;outline:0}
textarea:focus{border-color:var(--signal-dim)}
.pasterow{display:flex;justify-content:space-between;align-items:center;margin-top:12px}
.counter{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--dim)}
.counter.over{color:var(--heat)}

/* gate / error */
.gate{border-color:var(--heat-dim)}
.gate .pad{display:flex;gap:16px;align-items:flex-start}
.gate .mark{font-family:'Bricolage Grotesque';font-weight:800;font-size:30px;color:var(--heat);line-height:1}
.gate h3{font-family:'Bricolage Grotesque';font-weight:700;font-size:18px;margin-bottom:7px}
.gate p{color:var(--mut);font-size:14px;line-height:1.6}
.err{color:var(--heat);font-family:'JetBrains Mono',monospace;font-size:13px}

/* loading */
.loading{display:none;margin-top:22px;align-items:center;gap:14px;color:var(--mut);
  font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.1em}
.loading.on{display:flex;animation:rise .3s both}
.scanner{width:140px;height:5px;background:var(--panel2);border-radius:4px;overflow:hidden;border:1px solid var(--line)}
.scanner i{display:block;height:100%;width:40%;background:var(--signal);border-radius:4px;
  animation:scan 1.1s ease-in-out infinite}
@keyframes scan{0%{margin-left:-40%}100%{margin-left:100%}}
@keyframes rise{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.hide{display:none!important}

/* decode bar + report */
.decodebar{display:flex;align-items:center;gap:16px;margin-top:16px;flex-wrap:wrap;animation:rise .5s .05s both}
.decodebar .lab{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--dim);letter-spacing:.04em;max-width:42ch;line-height:1.5}
.report{margin-top:18px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:6px 0 10px;animation:rise .5s both}
.rhead{display:flex;align-items:center;gap:10px;padding:16px 22px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;color:var(--ok)}
.template{margin:6px 22px 12px;background:rgba(255,192,30,.06);border:1px solid var(--signal-dim);border-radius:12px;padding:16px 18px}
.template .tlbl{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;color:var(--signal);margin-bottom:8px}
.template p{font-size:15px;line-height:1.55;color:var(--ink)}
.rsec{padding:16px 22px;border-top:1px solid var(--line)}
.rlabel{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.2em;color:var(--mut);margin-bottom:12px}
.kv{display:flex;gap:14px;margin:6px 0;font-size:14px}
.kv .k{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.1em;color:var(--dim);min-width:104px;padding-top:3px}
.kv .v{color:var(--ink);flex:1;line-height:1.5}
.hookline{font-family:'Bricolage Grotesque';font-weight:500;font-size:18px;line-height:1.4;color:var(--signal);margin:12px 0;padding-left:14px;border-left:2px solid var(--signal-dim)}
.why{color:var(--mut);font-size:14px;line-height:1.6;margin-top:8px}
.formula{font-family:'JetBrains Mono',monospace;font-size:14px;color:var(--ink);background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:13px 15px;line-height:1.55}
.chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:10px}
.chip{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--mut);border:1px solid var(--line);border-radius:20px;padding:6px 12px}
.chip.dim{color:var(--dim)}
.blist{margin-top:6px;padding-left:0;list-style:none}
.blist li{position:relative;padding-left:18px;margin:9px 0;color:var(--mut);font-size:14px;line-height:1.55}
.blist li::before{content:"";position:absolute;left:2px;top:9px;width:6px;height:6px;background:var(--signal-dim);border-radius:50%}
.timeline{margin-top:4px}
.beat{display:flex;gap:14px;padding:11px 0;border-bottom:1px dashed var(--line)}
.beat:last-child{border-bottom:0}
.brange{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--signal-dim);min-width:82px;padding-top:3px}
.bbody{display:flex;flex-direction:column;gap:3px}
.bbody b{font-family:'Bricolage Grotesque';font-weight:700;font-size:14px}
.bbody span{color:var(--mut);font-size:13.5px;line-height:1.5}
@media(max-width:680px){.vid{flex-direction:column}.vid .thumb{width:100%;flex:none;border-right:0;border-bottom:1px solid var(--line)}}

/* ===== STAGE 3 . apply step + script timeline ===== */
.applybox{margin-top:18px;border-top:1px solid var(--line);padding-top:18px}
#ideabox{width:100%;min-height:92px;background:var(--bg);border:1px solid var(--line);border-radius:11px;
  color:var(--ink);font-family:'Familjen Grotesk',sans-serif;font-size:14px;line-height:1.6;padding:13px;resize:vertical;outline:0}
input.angle{width:100%;margin-top:10px;background:var(--bg);border:1px solid var(--line);border-radius:11px;
  color:var(--ink);font-family:'Familjen Grotesk',sans-serif;font-size:14px;padding:12px 13px;outline:0}
#ideabox:focus,input.angle:focus{border-color:var(--signal-dim)}
#ideabox::placeholder,input.angle::placeholder{color:var(--dim)}
.scriptcard{margin-top:18px;background:var(--panel2);border:1px solid var(--line);border-radius:14px;padding:6px 0 10px;animation:rise .5s both}
.titles{display:flex;flex-direction:column;gap:8px}
.titleopt{font-family:'Bricolage Grotesque';font-weight:500;font-size:15px;color:var(--ink);
  background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:11px 14px;line-height:1.4}
.sttable{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.strow{display:grid;grid-template-columns:64px 1.3fr 1fr 1fr;border-bottom:1px solid var(--line)}
.strow:last-child{border-bottom:0}
.strow>span{padding:11px 12px;font-size:13px;line-height:1.55;border-left:1px solid var(--line)}
.strow>span:first-child{border-left:0}
.strow>span label{display:none}
.sthead{background:var(--bg)}
.sthead>span{font-family:'JetBrains Mono',monospace;font-size:9.5px;letter-spacing:.12em;color:var(--dim);padding:9px 12px}
.c-t{color:var(--signal-dim);font-family:'JetBrains Mono',monospace;font-size:11px}
.c-s{color:var(--ink)}
.c-v,.c-x{color:var(--mut)}
.muted{color:var(--dim);font-style:normal}
.actions{display:flex;gap:10px;border-top:1px solid var(--line);flex-wrap:wrap;padding-top:16px}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn.ghost:hover{box-shadow:none;border-color:var(--signal-dim);transform:translateY(-1px)}
@media(max-width:680px){
  .strow{grid-template-columns:1fr}
  .strow>span{border-left:0;border-top:1px dashed var(--line)}
  .strow>span:first-child{border-top:0}
  .sthead{display:none}
  .strow>span label{display:block;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.12em;color:var(--dim);margin-bottom:4px}
}

/* ===== access layer: login + mode badges ===== */
.loginwrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.logincard{width:100%;max-width:380px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:30px 28px;box-shadow:0 30px 80px -40px rgba(0,0,0,.9)}
.loginerr{background:rgba(232,67,43,.08);border:1px solid var(--heat-dim);color:var(--heat);font-family:'JetBrains Mono',monospace;font-size:12px;padding:10px 12px;border-radius:9px;margin-bottom:14px}
.modebadge{position:absolute;top:20px;right:24px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.12em;padding:7px 12px;border-radius:8px;text-decoration:none}
.modebadge.testing{color:var(--heat);border:1px solid var(--heat-dim);background:rgba(232,67,43,.06)}
.modebadge.logout{color:var(--dim);border:1px solid var(--line)}
.modebadge.logout:hover{color:var(--ink);border-color:var(--signal-dim)}

/* logo wordmark colors */
.brand-r{color:var(--heat)}
.brand-g{color:var(--ok)}