/* ============================================================
   GROUNDED — Cinematic Video Platform · NexoraLabs
   Aesthetic: dark grading-suite / tungsten studio
   ============================================================ */

:root{
  --ink:#0d0b08;
  --ink2:#12100c;
  --panel:#171410;
  --panel2:#1d1913;
  --line:rgba(236,220,190,.09);
  --line-strong:rgba(236,220,190,.16);
  --text:#ede5d3;
  --dim:#9b917c;
  --faint:#6d6553;
  --amber:#f0a028;
  --amber-hi:#ffc45e;
  --amber-deep:#b06f0e;
  --teal:#43d9c0;
  --teal-deep:#1e6e61;
  --red:#ff5c45;
  --green:#8fd47f;
  --violet:#b79bff;
  --r:10px;
  --font-d:"Bricolage Grotesque",sans-serif;
  --font-b:"Instrument Sans",sans-serif;
  --font-m:"Spline Sans Mono",monospace;
}

*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{
  background:var(--ink);
  color:var(--text);
  font-family:var(--font-b);
  font-size:14.5px;
  line-height:1.5;
  display:flex;
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
}
::selection{background:rgba(240,160,40,.35)}
.mono{font-family:var(--font-m);font-size:.82em;letter-spacing:.04em}
.dim{color:var(--dim)}
.ta-r{text-align:right}
button{font-family:inherit;color:inherit;background:none;border:none;cursor:pointer}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:#2c2620;border-radius:9px;border:2px solid var(--ink)}
::-webkit-scrollbar-track{background:transparent}

/* ---- film grain overlay ---- */
.grain{
  position:fixed;inset:-100px;z-index:999;pointer-events:none;opacity:.055;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 1.2s steps(4) infinite;
}
@keyframes grain{
  0%{transform:translate(0,0)}25%{transform:translate(-40px,30px)}
  50%{transform:translate(30px,-45px)}75%{transform:translate(-25px,-20px)}100%{transform:translate(0,0)}
}

/* ============================ RAIL ============================ */
.rail{
  width:232px;min-width:232px;height:100vh;
  background:linear-gradient(180deg,#131009 0%,#0e0c08 100%);
  border-right:1px solid var(--line);
  display:flex;flex-direction:column;
  padding:22px 14px 16px;
  position:relative;z-index:5;
}
.rail-logo{display:flex;align-items:center;gap:11px;padding:0 8px 22px;border-bottom:1px solid var(--line)}
.logo-mark{
  width:38px;height:38px;border-radius:11px;flex:none;
  background:radial-gradient(circle at 32% 28%,#12202e,#0b1119);
  border:1px solid var(--line-strong);
  display:grid;place-items:center;
  box-shadow:0 0 24px rgba(67,217,192,.16);
}
.logo-mark svg{
  width:27px;height:27px;
  filter:drop-shadow(0 0 7px rgba(69,207,196,.35));
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.logo-word{font-family:var(--font-d);font-weight:700;font-size:16px;letter-spacing:.14em;line-height:1.1}
.logo-word em{display:block;font-family:var(--font-m);font-style:normal;font-weight:400;font-size:9px;letter-spacing:.12em;color:var(--dim);margin-top:3px;text-transform:uppercase}

.rail-nav{display:flex;flex-direction:column;gap:3px;padding-top:18px;flex:1}
.nav-item{
  display:flex;align-items:center;gap:12px;
  padding:11px 12px;border-radius:9px;
  color:var(--dim);font-size:13.5px;font-weight:500;letter-spacing:.02em;
  transition:all .18s ease;text-align:left;
  border:1px solid transparent;
}
.nav-item svg{width:17px;height:17px;fill:currentColor;flex:none;opacity:.85}
.nav-item:hover{color:var(--text);background:rgba(236,220,190,.04)}
.nav-item.active{
  color:var(--amber-hi);
  background:linear-gradient(90deg,rgba(240,160,40,.14),rgba(240,160,40,.03));
  border-color:rgba(240,160,40,.22);
  box-shadow:inset 2.5px 0 0 var(--amber);
}
.rail-foot{border-top:1px solid var(--line);padding-top:14px;display:flex;flex-direction:column;gap:12px}
.stack-mini{background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:10px 12px}
.stack-mini-title{font-family:var(--font-m);font-size:9px;letter-spacing:.18em;color:var(--faint);margin-bottom:6px}
.stack-mini-row{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--dim)}
.stack-mini-row + .stack-mini-row{margin-top:3px;padding-left:15px}
.user-chip{display:flex;align-items:center;gap:10px;padding:0 4px}
.avatar{
  width:32px;height:32px;border-radius:50%;flex:none;
  background:linear-gradient(135deg,var(--amber-deep),var(--amber));
  color:#180f02;font-family:var(--font-m);font-size:11px;font-weight:600;
  display:grid;place-items:center;
}
.user-chip b{display:block;font-size:12.5px}
.user-chip small{color:var(--faint);font-size:10.5px}

.dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex:none}
.dot.ok{background:var(--green);box-shadow:0 0 8px rgba(143,212,127,.7);animation:pulse 3s infinite}

/* ============================ FRAME ============================ */
.frame{flex:1;display:flex;flex-direction:column;height:100vh;min-width:0}
.topbar{
  height:54px;min-height:54px;
  border-bottom:1px solid var(--line);
  background:rgba(13,11,8,.85);backdrop-filter:blur(6px);
  display:flex;align-items:center;gap:18px;
  padding:0 22px;z-index:4;
}
.crumb{font-family:var(--font-m);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim)}
.crumb-root{color:var(--amber)}
.crumb-sep{margin:0 8px;color:var(--faint)}
#crumbView{color:var(--text)}
.project-chip{
  margin-left:auto;
  font-family:var(--font-m);font-size:10px;letter-spacing:.14em;
  color:var(--dim);border:1px solid var(--line);border-radius:99px;
  padding:6px 14px;display:flex;align-items:center;gap:8px;
}
.project-chip i{width:6px;height:6px;border-radius:50%;background:var(--teal);box-shadow:0 0 8px var(--teal)}
.topbar-right{display:flex;align-items:center;gap:16px}
.rec{display:flex;align-items:center;gap:7px;font-family:var(--font-m);font-size:11px;letter-spacing:.2em;color:var(--red)}
.rec-dot{width:9px;height:9px;border-radius:50%;background:var(--red);box-shadow:0 0 10px var(--red);animation:pulse 1.4s infinite}
.tc{font-size:13px;color:var(--text);letter-spacing:.08em}

/* ============================ VIEWS ============================ */
.views{flex:1;overflow-y:auto;overflow-x:hidden;position:relative}
.view{display:none;padding:30px 30px 60px;animation:viewIn .45s cubic-bezier(.2,.7,.3,1)}
.view.active{display:block}
@keyframes viewIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

.section-label{
  font-family:var(--font-m);font-size:10px;letter-spacing:.22em;color:var(--faint);
  margin:28px 0 12px;display:flex;align-items:center;gap:12px;
}
.section-label::after{content:"";flex:1;height:1px;background:var(--line)}
.eyebrow{font-family:var(--font-m);font-size:10px;letter-spacing:.24em;color:var(--amber);margin-bottom:10px}

.panel{
  background:linear-gradient(180deg,var(--panel),var(--ink2));
  border:1px solid var(--line);border-radius:var(--r);
  padding:18px;min-width:0;
}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.panel-head.mt{margin-top:22px}
.panel-head h3{font-family:var(--font-d);font-size:15px;font-weight:600;letter-spacing:.02em}
.live-tag{display:flex;align-items:center;gap:6px;font-family:var(--font-m);font-size:9.5px;letter-spacing:.18em;color:var(--teal)}
.live-tag i{width:6px;height:6px;border-radius:50%;background:var(--teal);animation:pulse 1.6s infinite}
.chip-soft{font-family:var(--font-m);font-size:9.5px;letter-spacing:.1em;color:var(--dim);border:1px solid var(--line);padding:4px 10px;border-radius:99px}

/* buttons */
.btn{
  border-radius:9px;padding:11px 20px;font-weight:600;font-size:13.5px;letter-spacing:.02em;
  transition:all .18s ease;border:1px solid transparent;
}
.btn-amber{
  background:linear-gradient(135deg,var(--amber-hi),var(--amber) 55%,var(--amber-deep));
  color:#1c1102;box-shadow:0 4px 22px rgba(240,160,40,.28);
}
.btn-amber:hover{transform:translateY(-1px);box-shadow:0 7px 28px rgba(240,160,40,.42)}
.btn-amber:disabled{opacity:.5;cursor:default;transform:none}
.btn-ghost{border-color:var(--line-strong);color:var(--text)}
.btn-ghost:hover{border-color:var(--amber);color:var(--amber-hi)}
.btn-teal{background:linear-gradient(135deg,#6fe8d4,var(--teal) 55%,var(--teal-deep));color:#04211c;box-shadow:0 4px 20px rgba(67,217,192,.22)}
.btn-teal:hover{transform:translateY(-1px)}
.btn-teal:disabled{opacity:.5;cursor:default;transform:none}
.btn-block{width:100%;margin-top:16px}
.btn-sm{padding:7px 13px;font-size:12px;border-radius:7px}

/* ============================ DECK ============================ */
.deck-hero{
  display:grid;grid-template-columns:1.4fr 1fr;gap:26px;
  border:1px solid var(--line);border-radius:16px;
  padding:38px 38px 34px;
  background:
    radial-gradient(900px 420px at 8% -20%,rgba(240,160,40,.13),transparent 60%),
    radial-gradient(600px 300px at 95% 120%,rgba(67,217,192,.07),transparent 60%),
    linear-gradient(180deg,#16120c,#0f0d09);
  position:relative;overflow:hidden;
}
.deck-hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent 0 3px,rgba(0,0,0,.12) 3px 4px);
  opacity:.35;
}
.deck-hero-copy h1{
  font-family:var(--font-d);font-weight:750;font-size:clamp(30px,3.6vw,52px);
  line-height:1.02;letter-spacing:-.015em;margin:6px 0 16px;
}
.deck-hero-copy h1 span{
  color:transparent;
  background:linear-gradient(100deg,var(--amber-hi),var(--amber) 60%,#e2703a);
  -webkit-background-clip:text;background-clip:text;
}
.deck-hero-copy p{color:var(--dim);max-width:46ch;font-size:15px}
.hero-actions{display:flex;gap:12px;margin-top:24px}
.deck-hero-meta{display:flex;flex-direction:column;gap:14px;justify-content:center;position:relative;z-index:1}
.phase-card{background:rgba(13,11,8,.6);border:1px solid var(--line-strong);border-radius:12px;padding:16px 18px}
.phase-label{font-family:var(--font-m);font-size:9px;letter-spacing:.22em;color:var(--faint)}
.phase-name{font-family:var(--font-d);font-weight:600;font-size:15.5px;margin:7px 0 12px}
.phase-bar{height:6px;border-radius:99px;background:#241e15;overflow:hidden}
.phase-bar span{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--amber-deep),var(--amber-hi));box-shadow:0 0 12px rgba(240,160,40,.5)}
.phase-foot{font-size:9.5px;letter-spacing:.16em;color:var(--dim);margin-top:9px}
.phase-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:7px}
.ph{
  border:1px solid var(--line);border-radius:9px;padding:9px 8px 8px;
  font-size:10px;color:var(--faint);line-height:1.25;
}
.ph b{display:block;font-family:var(--font-m);font-size:10px;letter-spacing:.1em;margin-bottom:4px;color:var(--dim)}
.ph.done{border-color:rgba(143,212,127,.3);color:var(--dim)}
.ph.done b{color:var(--green)}
.ph.now{border-color:rgba(240,160,40,.5);background:rgba(240,160,40,.07);color:var(--text)}
.ph.now b{color:var(--amber)}

.stack-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.stack-card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r);
  padding:14px 15px;transition:border-color .2s;
}
.stack-card:hover{border-color:var(--line-strong)}
.stack-card header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}
.stack-card b{font-family:var(--font-d);font-size:14px;font-weight:600}
.stack-card p{font-size:11px;color:var(--faint);margin-bottom:10px}
.lat{font-size:11px;color:var(--teal)}

.deck-cols{display:grid;grid-template-columns:1.1fr 1fr;gap:14px;margin-top:26px}
.feed{display:flex;flex-direction:column;gap:2px;max-height:340px;overflow-y:auto}
.feed-line{
  display:flex;gap:12px;padding:8px 10px;border-radius:7px;font-size:12.5px;
  animation:feedIn .4s ease;
}
@keyframes feedIn{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:none}}
.feed-line:nth-child(odd){background:rgba(236,220,190,.025)}
.feed-time{font-family:var(--font-m);font-size:10px;color:var(--faint);padding-top:2px;flex:none;width:56px}
.feed-agent{font-family:var(--font-m);font-size:10px;letter-spacing:.08em;padding:2px 7px;border-radius:5px;flex:none;height:fit-content}
.feed-agent.pplx{background:rgba(67,217,192,.12);color:var(--teal)}
.feed-agent.claude{background:rgba(240,160,40,.12);color:var(--amber)}
.feed-agent.veo{background:rgba(183,155,255,.12);color:var(--violet)}
.feed-agent.manus{background:rgba(143,212,127,.12);color:var(--green)}
.feed-agent.nblm{background:rgba(255,120,90,.12);color:#ff9c7d}
.feed-text{color:var(--dim)}
.feed-text b{color:var(--text);font-weight:600}

.queue{display:flex;flex-direction:column;gap:12px}
.q-item{display:grid;grid-template-columns:1fr 130px 42px;align-items:center;gap:12px}
.q-info b{display:block;font-size:13px;font-weight:600}
.q-info small{color:var(--faint);font-size:11px}
.q-bar{height:5px;border-radius:99px;background:#241e15;overflow:hidden}
.q-bar.big{height:7px;margin-top:8px}
.q-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--amber-deep),var(--amber-hi));border-radius:99px;transition:width .3s ease;box-shadow:0 0 10px rgba(240,160,40,.4)}
.q-bar.teal span{background:linear-gradient(90deg,var(--teal-deep),var(--teal))}
.q-pct{font-size:11px;color:var(--dim);text-align:right}

.risk-table{width:100%;border-collapse:collapse;font-size:12.5px}
.risk-table td{padding:8px 6px;border-top:1px solid var(--line)}
.risk-table td:last-child{text-align:right;font-size:11px}
.sev{font-family:var(--font-m);font-size:9px;letter-spacing:.12em;padding:3px 8px;border-radius:5px}
.sev.crit{background:rgba(255,92,69,.15);color:var(--red)}
.sev.high{background:rgba(240,160,40,.14);color:var(--amber)}
.sev.med{background:rgba(236,220,190,.08);color:var(--dim)}

/* ============================ CINEMA ============================ */
.cinema-grid{display:grid;grid-template-columns:290px 1fr 270px;gap:14px;align-items:start}
.script-panel,.cam-panel{padding:16px}

.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:16px}
.tab{
  font-family:var(--font-m);font-size:10px;letter-spacing:.14em;color:var(--faint);
  padding:8px 10px;border-bottom:2px solid transparent;margin-bottom:-1px;
}
.tab.active{color:var(--amber);border-color:var(--amber)}
.tab-pane{display:none}
.tab-pane.active{display:block}

.fld-label{display:block;font-family:var(--font-m);font-size:9.5px;letter-spacing:.18em;color:var(--faint);margin:16px 0 7px}
textarea,.fld{
  width:100%;background:#0d0b07;border:1px solid var(--line-strong);border-radius:8px;
  color:var(--text);font-family:var(--font-b);font-size:13px;line-height:1.55;
  padding:11px 12px;resize:vertical;
}
textarea:focus,.fld:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(240,160,40,.12)}
select.fld{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--dim) 50%),linear-gradient(135deg,var(--dim) 50%,transparent 50%);background-position:calc(100% - 18px) 50%,calc(100% - 13px) 50%;background-size:5px 5px;background-repeat:no-repeat}

.ground-row{display:flex;gap:11px;align-items:flex-start;margin-top:14px;padding:11px;border:1px solid rgba(67,217,192,.25);background:rgba(67,217,192,.05);border-radius:9px}
.ground-row b{font-size:12.5px;display:block}
.ground-row small{color:var(--dim);font-size:11px}
.switch{position:relative;display:inline-block;width:34px;height:19px;flex:none;margin-top:2px}
.switch input{opacity:0;width:0;height:0}
.switch span{position:absolute;inset:0;border-radius:99px;background:#2b251c;transition:.2s;cursor:pointer}
.switch span::before{content:"";position:absolute;width:13px;height:13px;border-radius:50%;background:var(--dim);top:3px;left:3px;transition:.2s}
.switch input:checked + span{background:var(--teal-deep)}
.switch input:checked + span::before{background:var(--teal);transform:translateX(15px)}

.seg{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}
.seg button{
  font-family:var(--font-m);font-size:12px;padding:8px 0;border-radius:7px;
  border:1px solid var(--line-strong);color:var(--dim);transition:all .15s;
}
.seg button.active{border-color:var(--amber);color:var(--amber-hi);background:rgba(240,160,40,.1)}

.dropzone{
  border:1.5px dashed var(--line-strong);border-radius:9px;padding:26px 14px;text-align:center;
  transition:border-color .2s;cursor:pointer;
}
.dropzone:hover{border-color:var(--amber)}
.dropzone b{display:block;font-size:13px}
.dropzone small{color:var(--faint);font-size:11px}
.dropzone.drag{border-color:var(--teal);background:rgba(67,217,192,.05)}
.dropzone.has-ref{border-style:solid;border-color:rgba(67,217,192,.45);background-size:cover;background-position:center}
.dropzone.has-ref b,.dropzone.has-ref small{background:rgba(0,0,0,.55);border-radius:4px;padding:2px 8px;display:inline-block;color:#fff}
.char-lock{display:flex;gap:7px}
.char-chip{font-family:var(--font-m);font-size:10.5px;padding:7px 11px;border-radius:7px;border:1px solid var(--line-strong);color:var(--violet)}
.char-chip.ghost{color:var(--faint)}

.gen-status{margin-top:14px}
.gen-stage{font-size:10px;letter-spacing:.16em;color:var(--amber)}

.vo-preview{
  margin-top:8px;width:100%;
  font-family:var(--font-m);font-size:9.5px;letter-spacing:.12em;
  color:var(--teal);border:1px solid rgba(67,217,192,.35);border-radius:7px;
  padding:7px 0;transition:all .15s;
}
.vo-preview:hover{background:rgba(67,217,192,.1)}

/* image lab (Nano Banana equivalent) */
.img-lab{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.img-cell{
  aspect-ratio:16/10;border:1.5px dashed var(--line-strong);border-radius:8px;
  position:relative;overflow:hidden;display:grid;place-items:end start;
}
.img-cell span{
  font-family:var(--font-m);font-size:8px;letter-spacing:.1em;
  color:rgba(255,255,255,.85);background:rgba(0,0,0,.45);
  padding:3px 7px;border-radius:4px;margin:6px;
}
.img-cell.shimmer{
  border-style:solid;
  background:linear-gradient(100deg,#171410 40%,#262117 50%,#171410 60%);
  background-size:200% 100%;animation:shim 1.1s linear infinite;
}
@keyframes shim{to{background-position:-200% 0}}
.img-cell[class*="fill-"]{border:1px solid var(--line-strong)}
.img-cell.fill-a{background:radial-gradient(120% 100% at 20% 20%,#3b2b10,#120d06 62%),linear-gradient(160deg,rgba(240,160,40,.5) -60%,transparent 45%)}
.img-cell.fill-b{background:radial-gradient(130% 110% at 80% 15%,#12343b,#0a1216 68%)}
.img-cell.fill-c{background:linear-gradient(200deg,#241a2e 8%,#6e3420 92%)}
.img-cell.fill-d{background:radial-gradient(100% 100% at 50% 40%,#1d4266,#0a1826 72%)}

/* monitor */
.monitor-wrap{display:flex;flex-direction:column;gap:10px}
.monitor{
  border:1px solid var(--line-strong);border-radius:12px;overflow:hidden;
  background:#000;box-shadow:0 20px 60px rgba(0,0,0,.5),0 0 0 6px rgba(236,220,190,.02);
}
.letterbox{height:26px;background:#050403}
.scene-clip{position:relative;aspect-ratio:21/9;overflow:hidden}
.scene{position:absolute;inset:-12%;transition:transform .25s cubic-bezier(.2,.7,.3,1)}
.sky{position:absolute;inset:0;background:linear-gradient(180deg,#0b0d16 0%,#241a2e 34%,#6e3420 62%,#c47b2c 78%,#e9a94b 92%)}
.sun{
  position:absolute;left:50%;top:58%;width:26%;aspect-ratio:1;transform:translate(-50%,-50%);
  border-radius:50%;
  background:radial-gradient(circle,#ffd98a 0%,#f2a33c 45%,rgba(242,163,60,0) 72%);
  filter:blur(2px);
}
.ridge{position:absolute;left:-5%;right:-5%;bottom:18%}
.ridge.r1{
  height:34%;background:#191016;
  clip-path:polygon(0 100%,0 62%,7% 60%,10% 38%,14% 55%,20% 30%,24% 52%,30% 44%,36% 20%,40% 48%,47% 40%,52% 12%,57% 44%,63% 34%,70% 50%,76% 26%,82% 48%,88% 40%,94% 56%,100% 46%,100% 100%);
}
.ridge.r2{
  height:24%;bottom:14%;background:#241722;opacity:.8;
  clip-path:polygon(0 100%,0 70%,6% 55%,12% 68%,18% 44%,26% 66%,33% 52%,42% 70%,50% 40%,58% 64%,66% 50%,74% 68%,81% 46%,90% 66%,100% 52%,100% 100%);
}
.gridfloor{
  position:absolute;left:-30%;right:-30%;bottom:-4%;height:26%;
  background:
    repeating-linear-gradient(90deg,rgba(240,160,40,.35) 0 1px,transparent 1px 60px),
    repeating-linear-gradient(0deg,rgba(240,160,40,.3) 0 1px,transparent 1px 22px),
    linear-gradient(180deg,#170f08,#0b0704);
  transform:perspective(300px) rotateX(58deg);
  transform-origin:top;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.9),transparent 95%);
}
.dataline{
  position:absolute;height:1.5px;border-radius:99px;
  background:linear-gradient(90deg,transparent,var(--teal) 30%,#bff5ea 50%,var(--teal) 70%,transparent);
  filter:drop-shadow(0 0 5px var(--teal));
  animation:dataflow 4.5s linear infinite;opacity:.75;
}
.dataline.d1{top:42%;left:12%;width:34%}
.dataline.d2{top:52%;left:48%;width:28%;animation-delay:1.4s}
.dataline.d3{top:36%;left:55%;width:24%;animation-delay:2.8s}
@keyframes dataflow{
  0%{transform:scaleX(0);transform-origin:left;opacity:0}
  15%{transform:scaleX(1);opacity:.8}
  70%{transform:scaleX(1);transform-origin:right;opacity:.8}
  100%{transform:scaleX(0);transform-origin:right;opacity:0}
}
.mon-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:none;z-index:2;cursor:pointer}
.mon-video.on{display:block}
.hud{position:absolute;inset:0;pointer-events:none;z-index:3;font-size:10px;color:rgba(237,229,211,.85);text-shadow:0 1px 3px rgba(0,0,0,.8)}
.hud span{position:absolute;letter-spacing:.14em}
.hud-tl{top:12px;left:16px}
.hud-tr{top:12px;right:16px;color:var(--amber-hi)}
.hud-bl{bottom:12px;left:16px}
.hud-br{bottom:12px;right:16px;color:var(--teal)}
.safe-frame{position:absolute;inset:7%;border:1px solid rgba(237,229,211,.14);border-radius:4px}
.safe-frame::before,.safe-frame::after{content:"";position:absolute;background:rgba(237,229,211,.35)}
.safe-frame::before{left:50%;top:-5px;width:1px;height:10px}
.safe-frame::after{top:50%;left:-5px;height:1px;width:10px}

.transport{
  display:flex;align-items:center;gap:16px;
  background:var(--panel);border:1px solid var(--line);border-radius:10px;
  padding:10px 16px;
}
.t-btn{
  width:38px;height:38px;border-radius:50%;flex:none;
  border:1px solid var(--line-strong);color:var(--amber);font-size:13px;
  display:grid;place-items:center;transition:all .18s;
}
.t-btn:hover{border-color:var(--amber);box-shadow:0 0 16px rgba(240,160,40,.3)}
.t-btn.t-dl{font-size:15px;color:var(--teal)}
.t-btn.t-dl:hover{border-color:var(--teal);box-shadow:0 0 16px rgba(67,217,192,.3)}
.t-tc{font-size:15px;letter-spacing:.1em}
.t-label{margin-left:auto;font-size:10px;color:var(--faint);letter-spacing:.14em}
.clip-play{position:absolute;right:6px;top:4px;font-size:8px;color:rgba(20,13,2,.75);font-style:normal}

/* camera panel */
.cam-ctl{display:flex;flex-direction:column;gap:14px}
.cam-row{display:grid;grid-template-columns:38px 1fr 48px;align-items:center;gap:10px}
.cam-row label{font-family:var(--font-m);font-size:9px;letter-spacing:.14em;color:var(--faint)}
.cam-row .mono{font-size:11px;color:var(--amber-hi);text-align:right}
.slider{
  -webkit-appearance:none;appearance:none;width:100%;height:3px;border-radius:99px;
  background:linear-gradient(90deg,var(--amber-deep),var(--amber));outline:none;
}
.slider::-webkit-slider-thumb{
  -webkit-appearance:none;width:15px;height:15px;border-radius:50%;
  background:var(--text);border:3px solid var(--amber);cursor:grab;
  box-shadow:0 0 10px rgba(240,160,40,.5);
}
.slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--text);border:3px solid var(--amber);cursor:grab}
.preset-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.preset{
  font-family:var(--font-m);font-size:10.5px;letter-spacing:.06em;padding:9px 4px;
  border:1px solid var(--line-strong);border-radius:7px;color:var(--dim);transition:all .15s;
}
.preset:hover{border-color:var(--amber);color:var(--amber-hi)}

.audio-bed{display:flex;align-items:center;gap:13px}
.wave{display:flex;align-items:center;gap:2px;height:30px;flex:none}
.wave i{width:2.5px;background:var(--teal);border-radius:99px;opacity:.85;animation:wavey 1.3s ease-in-out infinite}
.wave i:nth-child(4n+1){height:35%;animation-delay:0s}
.wave i:nth-child(4n+2){height:80%;animation-delay:.16s}
.wave i:nth-child(4n+3){height:55%;animation-delay:.32s}
.wave i:nth-child(4n){height:95%;animation-delay:.48s}
@keyframes wavey{0%,100%{transform:scaleY(.55)}50%{transform:scaleY(1)}}
.audio-meta b{font-size:12.5px;display:block}
.audio-meta small{color:var(--faint);font-size:11px}

.brand-check{margin-top:18px;border:1px solid var(--line);border-radius:9px;padding:12px 13px;background:rgba(13,11,8,.5)}
.bc-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:9px}
.bc-head b{font-size:13px}
.bc-score{color:var(--green);font-size:15px;font-weight:600}
.bc-row{font-size:11.5px;color:var(--dim);padding:4px 0 4px 18px;position:relative}
.bc-row::before{content:"✓";position:absolute;left:0;color:var(--green);font-size:11px}
.bc-row.warn::before{content:"!";color:var(--amber)}
.bc-row.warn{color:var(--amber-hi)}

/* timeline */
.timeline-panel{
  margin-top:14px;background:linear-gradient(180deg,var(--panel),var(--ink2));
  border:1px solid var(--line);border-radius:var(--r);padding:14px 16px;overflow-x:auto;
}
.tl-head{display:flex;justify-content:space-between;margin-bottom:10px;min-width:1080px}
.tl-tools{display:flex;gap:10px;font-size:10px;color:var(--faint)}
.tl-ruler{position:relative;height:20px;min-width:1080px;border-bottom:1px solid var(--line-strong)}
.tick{position:absolute;bottom:0;width:1px;height:6px;background:var(--faint)}
.tick.major{height:11px;background:var(--dim)}
.tick-label{position:absolute;bottom:9px;font-family:var(--font-m);font-size:8.5px;color:var(--faint);transform:translateX(3px)}
.tl-track{position:relative;height:58px;min-width:1080px;margin-top:10px;background:rgba(13,11,8,.6);border:1px solid var(--line);border-radius:8px}
.tl-track.vo-track{height:34px;margin-top:8px}
.tl-clip{
  position:absolute;top:5px;bottom:5px;border-radius:6px;padding:7px 11px;overflow:hidden;
  border:1px solid rgba(255,255,255,.14);cursor:grab;
  transition:filter .15s;
}
.tl-clip:hover{filter:brightness(1.15)}
.tl-clip b{display:block;font-size:11px;font-weight:600;white-space:nowrap;color:#140d02}
.tl-clip small{font-family:var(--font-m);font-size:9px;color:rgba(20,13,2,.65)}
.tl-clip.amber{background:linear-gradient(180deg,var(--amber-hi),var(--amber))}
.tl-clip.teal{background:linear-gradient(180deg,#7ceada,var(--teal))}
.tl-clip.teal b,.tl-clip.teal small{color:#03211c}
.tl-clip.violet{background:linear-gradient(180deg,#cdb9ff,var(--violet))}
.tl-clip.violet b,.tl-clip.violet small{color:#160b33}
.tl-clip.vo{top:4px;bottom:4px;background:repeating-linear-gradient(90deg,#232a26 0 4px,#2c342f 4px 8px);border-color:rgba(67,217,192,.3)}
.tl-clip.vo b{color:var(--teal);font-size:10px;font-weight:500}
.playhead{
  position:absolute;top:-32px;bottom:-46px;left:120px;width:1.5px;z-index:3;
  background:var(--red);box-shadow:0 0 8px rgba(255,92,69,.8);pointer-events:none;
}
.playhead::before{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  border:6px solid transparent;border-top-color:var(--red);
}

/* timeline export hand-off */
.tl-tools{align-items:center}
.tl-export-sel{
  background:#0d0b07;border:1px solid var(--line-strong);border-radius:6px;
  color:var(--dim);font-family:var(--font-m);font-size:9.5px;letter-spacing:.06em;
  padding:4px 7px;margin-left:10px;
}
.tl-export-sel:focus{outline:none;border-color:var(--amber)}
.tl-export-btn{
  font-family:var(--font-m);font-size:9.5px;letter-spacing:.1em;
  border:1px solid rgba(240,160,40,.4);color:var(--amber-hi);
  border-radius:6px;padding:4.5px 11px;transition:all .15s;white-space:nowrap;
}
.tl-export-btn:hover{background:rgba(240,160,40,.12)}

/* ============================ KNOWLEDGE ============================ */
.knowledge-grid{display:grid;grid-template-columns:340px 1fr;gap:14px;align-items:start;height:calc(100vh - 116px)}
.src-panel{display:flex;flex-direction:column;max-height:100%}
.src-list{display:flex;flex-direction:column;gap:6px;overflow-y:auto}
.src-item{
  display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:9px;
  border:1px solid var(--line);transition:border-color .18s;animation:feedIn .4s ease;
}
.src-item:hover{border-color:var(--line-strong)}
.src-item b{display:block;font-size:12.5px;line-height:1.3}
.src-item small{color:var(--faint);font-size:10.5px}
.src-item > div{flex:1;min-width:0}
.src-type{
  font-family:var(--font-m);font-size:8.5px;letter-spacing:.1em;
  width:40px;height:26px;border-radius:6px;flex:none;
  display:grid;place-items:center;
}
.src-type.pdf{background:rgba(255,92,69,.13);color:var(--red)}
.src-type.url{background:rgba(183,155,255,.13);color:var(--violet)}
.src-type.res{background:rgba(67,217,192,.13);color:var(--teal)}
.src-type.txt{background:rgba(236,220,190,.1);color:var(--dim)}
.src-type.aud{background:rgba(183,155,255,.16);color:var(--violet)}
.grounded{color:var(--green);font-size:12px;flex:none}

.chat-panel{display:flex;flex-direction:column;max-height:100%;height:100%}
.chat-scroll{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:14px;padding:6px 2px 14px}
.msg{max-width:78%;padding:13px 16px;border-radius:13px;font-size:13.5px;animation:feedIn .35s ease}
.msg p + p{margin-top:8px}
.msg.user{
  align-self:flex-end;background:linear-gradient(135deg,rgba(240,160,40,.2),rgba(240,160,40,.1));
  border:1px solid rgba(240,160,40,.3);border-bottom-right-radius:4px;
}
.msg.bot{
  align-self:flex-start;background:var(--panel2);border:1px solid var(--line);
  border-bottom-left-radius:4px;color:#d9d0bc;
}
.msg.bot b{color:var(--amber-hi)}
.cites{display:flex;flex-wrap:wrap;gap:6px;margin-top:11px}
.cite{
  font-family:var(--font-m);font-size:9px;letter-spacing:.05em;color:var(--teal);
  border:1px solid rgba(67,217,192,.3);background:rgba(67,217,192,.07);
  padding:3.5px 9px;border-radius:99px;
}
.typing{display:flex;gap:4px;padding:6px 2px}
.typing i{width:5px;height:5px;border-radius:50%;background:var(--dim);animation:blink 1s infinite}
.typing i:nth-child(2){animation-delay:.2s}
.typing i:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,100%{opacity:.25}50%{opacity:1}}
.chat-input{display:flex;gap:9px;border-top:1px solid var(--line);padding-top:14px}
.chat-input input{
  flex:1;background:#0d0b07;border:1px solid var(--line-strong);border-radius:9px;
  color:var(--text);font-family:var(--font-b);font-size:13.5px;padding:11px 14px;
}
.chat-input input:focus{outline:none;border-color:var(--amber)}

/* ============================ WORKFLOW ============================ */
.wf-toolbar{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:14px}
.wf-title{font-family:var(--font-d);font-size:21px;font-weight:650}
.wf-actions{display:flex;gap:9px}
.wf-templates{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.wf-tpl-label{font-size:9px;letter-spacing:.18em;color:var(--faint);margin-right:4px}
.wf-tpl{
  font-family:var(--font-m);font-size:10px;letter-spacing:.04em;color:var(--dim);
  border:1px solid var(--line);border-radius:99px;padding:6px 14px;transition:all .15s;
}
.wf-tpl i{font-style:normal;color:var(--faint);font-size:9px}
.wf-tpl:hover{border-color:var(--line-strong);color:var(--text)}
.wf-tpl.active{color:var(--amber-hi);border-color:rgba(240,160,40,.4);background:rgba(240,160,40,.08)}
.wf-tpl.active i{color:rgba(240,160,40,.7)}

.wf-canvas-wrap{
  border:1px solid var(--line);border-radius:var(--r);overflow:auto;
  background:
    radial-gradient(rgba(236,220,190,.09) 1px,transparent 1.5px);
  background-size:26px 26px;
  background-color:#0f0d09;
  height:470px;position:relative;
}
.wf-canvas{position:relative;width:1560px;height:560px}
.wf-wires{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.wf-wires path{fill:none;stroke:rgba(236,220,190,.22);stroke-width:1.6;transition:stroke .25s}
.wf-wires path.hot{stroke:var(--amber);filter:drop-shadow(0 0 5px rgba(240,160,40,.6));stroke-width:2}
.node{
  position:absolute;width:196px;border-radius:11px;cursor:grab;user-select:none;
  background:linear-gradient(180deg,#1d1913,#14110c);
  border:1px solid var(--line-strong);
  box-shadow:0 8px 24px rgba(0,0,0,.4);
  transition:border-color .2s,box-shadow .2s;
}
.node:active{cursor:grabbing}
.node.running{border-color:var(--amber);box-shadow:0 0 0 3px rgba(240,160,40,.15),0 8px 30px rgba(240,160,40,.2)}
.node.done{border-color:rgba(143,212,127,.45)}
.node-head{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--line)}
.node-dot{width:8px;height:8px;border-radius:50%;flex:none}
.node-head b{font-size:12.5px;font-weight:600}
.node-body{padding:9px 12px 11px}
.node-body p{font-size:10.5px;color:var(--faint);line-height:1.45}
.node-status{
  font-family:var(--font-m);font-size:8.5px;letter-spacing:.16em;margin-top:8px;
  color:var(--faint);
}
.node.running .node-status{color:var(--amber)}
.node.done .node-status{color:var(--green)}
.node-port{position:absolute;width:9px;height:9px;border-radius:50%;background:#2b251c;border:2px solid var(--dim);top:50%;transform:translateY(-50%)}
.node-port.in{left:-5px}
.node-port.out{right:-5px}
.node.done .node-port.out{background:var(--green);border-color:var(--green)}

.wf-log-panel{margin-top:14px;background:linear-gradient(180deg,var(--panel),var(--ink2));border:1px solid var(--line);border-radius:var(--r);padding:16px 18px}
.wf-log{max-height:150px;overflow-y:auto;font-size:11px;line-height:1.8;color:var(--dim)}
.log-line{animation:feedIn .3s ease}
.log-line b{color:var(--amber-hi);font-weight:500}
.log-line .ok{color:var(--green)}

/* ============================ MARKETING ============================ */
.tpl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.tpl-card{
  background:linear-gradient(180deg,var(--panel),var(--ink2));
  border:1px solid var(--line);border-radius:var(--r);padding:16px;
  display:flex;flex-direction:column;gap:7px;transition:all .2s;
}
.tpl-card:hover{border-color:var(--line-strong);transform:translateY(-2px)}
.tpl-card.hot{border-color:rgba(240,160,40,.35);background:linear-gradient(180deg,#1e1810,var(--ink2))}
.tpl-ratio{
  font-size:9.5px;letter-spacing:.14em;color:var(--amber);
  border:1px solid rgba(240,160,40,.3);border-radius:5px;
  width:fit-content;padding:3px 8px;
}
.tpl-card b{font-family:var(--font-d);font-size:15px;font-weight:600}
.tpl-card p{font-size:12px;color:var(--dim);flex:1}
.mkt-cols{display:grid;grid-template-columns:1.15fr 1fr;gap:14px;margin-top:26px}

.dist-table{width:100%;border-collapse:collapse}
.dist-table th{
  font-family:var(--font-m);font-size:9px;letter-spacing:.16em;color:var(--faint);
  text-align:left;padding:6px;border-bottom:1px solid var(--line-strong);
}
.dist-table td{padding:11px 6px;border-bottom:1px solid var(--line);font-size:13px;vertical-align:middle}
.dist-table td b{display:block;font-size:13px}
.dist-table td small{color:var(--faint);font-size:10.5px}
.dist-table td.mono{font-size:10px;color:var(--dim);letter-spacing:.1em}
.status{font-family:var(--font-m);font-size:8.5px;letter-spacing:.12em;padding:4px 9px;border-radius:5px;white-space:nowrap}
.status.live{background:rgba(143,212,127,.13);color:var(--green)}
.status.pub{background:rgba(240,160,40,.13);color:var(--amber)}
.status.sched{background:rgba(236,220,190,.07);color:var(--dim)}

.lead-list{display:flex;flex-direction:column;gap:11px}
.lead{
  display:grid;grid-template-columns:1fr 118px;grid-template-rows:auto auto;gap:6px 12px;
  border:1px solid var(--line);border-radius:9px;padding:12px 13px;align-items:center;
  animation:feedIn .35s ease;
}
.lead-co b{font-size:13.5px}
.lead-co small{display:block;color:var(--faint);font-size:11px}
.lead-intent{display:flex;align-items:center;gap:8px}
.lead-intent .mono{font-size:11px;color:var(--amber-hi)}
.intent-bar{flex:1;height:4px;border-radius:99px;background:#241e15;overflow:hidden}
.intent-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--amber-deep),var(--amber-hi));border-radius:99px}
.lead-signal{grid-column:1;font-size:11px}
.lead .btn{grid-column:2;grid-row:2}

/* localization engine */
.loc-controls{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center;margin-bottom:14px}
.loc-controls .fld{max-width:340px}
.loc-langs{display:flex;gap:6px}
.loc-lang{position:relative;cursor:pointer}
.loc-lang input{position:absolute;opacity:0;inset:0;cursor:pointer}
.loc-lang span{
  display:grid;place-items:center;width:42px;height:36px;
  border:1px solid var(--line-strong);border-radius:7px;
  font-family:var(--font-m);font-size:10px;letter-spacing:.06em;color:var(--dim);
  transition:all .15s;
}
.loc-lang input:checked + span{color:var(--teal);border-color:rgba(67,217,192,.5);background:rgba(67,217,192,.08)}
.loc-results{display:flex;flex-direction:column;gap:8px}
.loc-row{
  display:grid;grid-template-columns:46px 1fr auto;gap:13px;align-items:center;
  border:1px solid var(--line);border-radius:8px;padding:10px 14px;
  animation:feedIn .3s ease;
}
.loc-code{font-size:10px;color:var(--amber-hi);border:1px solid rgba(240,160,40,.3);border-radius:5px;text-align:center;padding:4.5px 0}
.loc-text{font-size:13px;line-height:1.45}
.loc-status{font-size:9px;letter-spacing:.12em;color:var(--faint);white-space:nowrap}
.loc-status.ok{color:var(--green)}

/* competitive intelligence */
.ci-bar{display:flex;gap:12px;align-items:stretch;margin-bottom:12px}
.ci-alert{
  flex:1;display:flex;align-items:center;gap:11px;
  border:1px solid rgba(255,92,69,.3);background:rgba(255,92,69,.06);
  border-radius:9px;padding:10px 15px;font-size:12.5px;color:var(--dim);
}
.ci-alert i{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 8px var(--red);animation:pulse 1.6s infinite;flex:none}
.ci-alert b{color:var(--text)}
.ci-alert .mono{margin-left:auto;font-size:8.5px;color:var(--faint);letter-spacing:.12em;white-space:nowrap;padding-left:12px}
.ci-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.ci-card{
  background:linear-gradient(180deg,var(--panel),var(--ink2));
  border:1px solid var(--line);border-radius:var(--r);padding:15px 16px;
  transition:border-color .2s;
}
.ci-card:hover{border-color:var(--line-strong)}
.ci-card header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.ci-card header b{font-family:var(--font-d);font-size:15.5px;font-weight:600}
.threat{font-family:var(--font-m);font-size:8.5px;letter-spacing:.12em;padding:3.5px 9px;border-radius:5px;white-space:nowrap}
.threat.high{background:rgba(255,92,69,.14);color:var(--red)}
.threat.med{background:rgba(240,160,40,.13);color:var(--amber)}
.threat.low{background:rgba(143,212,127,.12);color:var(--green)}
.ci-signal{font-size:12px;color:var(--dim);line-height:1.5;margin-bottom:11px}
.ci-move{
  display:flex;gap:9px;align-items:baseline;font-size:11.5px;color:var(--text);
  line-height:1.45;border-top:1px solid var(--line);padding-top:10px;
}
.ci-move .mono{font-size:8.5px;letter-spacing:.14em;color:var(--teal);flex:none}

/* ============================ ROI ============================ */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.kpi{
  background:linear-gradient(180deg,var(--panel),var(--ink2));
  border:1px solid var(--line);border-radius:var(--r);padding:20px 18px 16px;
  position:relative;overflow:hidden;
}
.kpi::before{content:"";position:absolute;top:0;left:18px;right:18px;height:2px;background:linear-gradient(90deg,var(--amber),transparent);border-radius:99px}
.kpi-val{font-family:var(--font-d);font-size:38px;font-weight:700;letter-spacing:-.02em;color:var(--amber-hi);line-height:1}
.kpi-name{font-size:13px;color:var(--text);margin:8px 0 6px}
.kpi-target{font-size:9px;letter-spacing:.14em;color:var(--faint)}
.kpi-target .up{color:var(--green)}
.roi-cols{display:grid;grid-template-columns:1.25fr 1fr;gap:14px;margin-top:14px}
.legend{display:flex;gap:16px;font-size:9px;letter-spacing:.1em;color:var(--dim)}
.legend span{display:flex;align-items:center;gap:6px}
.lg{width:14px;height:3px;border-radius:99px;display:inline-block}
.lg.amber{background:var(--amber)}
.lg.teal{background:var(--teal)}
.chart-wrap{width:100%}
#roiChart{width:100%;height:auto;display:block}

.funnel{display:flex;flex-direction:column;gap:9px}
.f-row{display:grid;grid-template-columns:110px 1fr 76px;align-items:center;gap:12px;font-size:12px}
.f-row label{color:var(--dim)}
.f-row .mono{font-size:10.5px;color:var(--text);text-align:right}
.f-bar{height:17px;border-radius:5px;background:rgba(13,11,8,.6);overflow:hidden}
.f-bar span{
  display:block;height:100%;width:0;border-radius:5px;
  background:linear-gradient(90deg,rgba(67,217,192,.5),var(--teal));
  transition:width .9s cubic-bezier(.2,.7,.3,1);
}
.f-bar.gold span{background:linear-gradient(90deg,var(--amber-deep),var(--amber-hi));box-shadow:0 0 14px rgba(240,160,40,.4)}

.cost-compare{display:flex;flex-direction:column;gap:12px;margin-bottom:14px}
.cost-row{display:grid;grid-template-columns:150px 1fr 66px;align-items:center;gap:12px;font-size:12.5px}
.cost-row label{color:var(--dim)}
.cost-row .mono{text-align:right;font-size:11.5px}
.c-bar{height:20px;border-radius:5px;background:rgba(13,11,8,.6);overflow:hidden}
.c-bar span{display:block;height:100%;width:0;border-radius:5px;transition:width 1s cubic-bezier(.2,.7,.3,1)}
.c-bar span.trad{background:linear-gradient(90deg,#4a4033,#6d5f49)}
.c-bar span.plat{background:linear-gradient(90deg,var(--amber-deep),var(--amber-hi));box-shadow:0 0 14px rgba(240,160,40,.45)}
.cost-note{font-size:12px;color:var(--dim);border:1px solid var(--line);border-radius:8px;padding:10px 13px;margin-bottom:16px}
.cost-note b{color:var(--amber-hi)}
.api-split{display:flex;flex-direction:column;gap:8px}
.api-row{display:grid;grid-template-columns:130px 1fr 40px;gap:10px;align-items:center;font-size:11.5px;color:var(--dim)}
.api-row .mono{font-size:10px;text-align:right}
.api-bar{height:5px;border-radius:99px;background:#241e15;overflow:hidden}
.api-bar span{display:block;height:100%;background:var(--teal);opacity:.8;border-radius:99px}

.predict{display:flex;flex-direction:column;gap:11px}
.p-item{border:1px solid var(--line);border-radius:9px;padding:13px 14px;position:relative}
.p-item b{font-size:13px}
.p-item p{font-size:12px;color:var(--dim);margin-top:4px;max-width:88%}
.p-item p b{color:var(--amber-hi);font-size:12px}
.conf{position:absolute;top:13px;right:13px;font-size:8.5px;letter-spacing:.12em;color:var(--teal)}
.roi-foot{margin-top:22px;text-align:center;font-size:9px;letter-spacing:.2em;color:var(--faint)}

/* ============================ SETTINGS & LIVE ENGINE ============================ */
.engine-chip{
  font-family:var(--font-m);font-size:9px;letter-spacing:.14em;
  border:1px solid var(--line);border-radius:99px;padding:5px 12px;
  color:var(--faint);cursor:pointer;transition:all .18s;
}
.engine-chip:hover{border-color:var(--line-strong);color:var(--dim)}
.engine-chip.live{
  color:var(--teal);border-color:rgba(67,217,192,.45);
  background:rgba(67,217,192,.07);box-shadow:0 0 12px rgba(67,217,192,.15);
}
.icon-btn{
  width:32px;height:32px;border-radius:8px;display:grid;place-items:center;
  border:1px solid transparent;color:var(--dim);transition:all .18s;
}
.icon-btn svg{width:16px;height:16px;fill:currentColor}
.icon-btn:hover{color:var(--amber-hi);border-color:var(--line-strong)}

.modal-back{
  position:fixed;inset:0;z-index:600;
  background:rgba(8,6,4,.72);backdrop-filter:blur(5px);
  display:grid;place-items:center;
  animation:viewIn .25s ease;
}
.modal-back[hidden]{display:none}
.modal{
  width:min(460px,92vw);
  background:linear-gradient(180deg,#1c1811,#12100b);
  border:1px solid var(--line-strong);border-radius:15px;
  padding:22px 24px 24px;
  box-shadow:0 30px 90px rgba(0,0,0,.6);
}
.modal-head{display:flex;align-items:center;gap:11px;margin-bottom:6px}
.modal-head h3{font-family:var(--font-d);font-size:17px;font-weight:650}
.modal-mark{width:30px;height:30px;filter:drop-shadow(0 0 6px rgba(69,207,196,.3))}
.modal-close{
  margin-left:auto;width:28px;height:28px;border-radius:7px;
  color:var(--faint);font-size:13px;transition:all .15s;
}
.modal-close:hover{color:var(--text);background:rgba(236,220,190,.06)}
.modal-note{font-size:12px;color:var(--dim);line-height:1.55;margin:12px 0 18px}
.modal-note b{color:var(--amber-hi)}
.modal-actions{display:flex;justify-content:flex-end;gap:9px}
.modal-session{
  display:flex;justify-content:space-between;align-items:center;
  font-size:9.5px;letter-spacing:.12em;color:var(--dim);
  border-top:1px solid var(--line);margin-top:18px;padding-top:14px;
}
.modal-session[hidden]{display:none}
.modal-session button{
  color:var(--red);letter-spacing:.12em;font-size:9.5px;font-family:var(--font-m);
  border:1px solid rgba(255,92,69,.35);border-radius:6px;padding:4px 11px;transition:all .15s;
}
.modal-session button:hover{background:rgba(255,92,69,.1)}

/* ============================ TEAM GATE ============================ */
.gate{
  position:fixed;inset:0;z-index:800;
  display:grid;place-items:center;
  background:
    radial-gradient(900px 460px at 50% -10%,rgba(240,160,40,.12),transparent 60%),
    radial-gradient(700px 400px at 88% 112%,rgba(67,217,192,.08),transparent 60%),
    #0b0906;
}
.gate[hidden]{display:none}
.gate::before,.gate::after{content:"";position:absolute;left:0;right:0;height:52px;background:#050403}
.gate::before{top:0}
.gate::after{bottom:0}
.gate-card{
  width:min(400px,90vw);position:relative;z-index:1;text-align:center;
  background:linear-gradient(180deg,#1b1610,#110f0a);
  border:1px solid var(--line-strong);border-radius:16px;
  padding:32px 30px 24px;
  box-shadow:0 40px 120px rgba(0,0,0,.6);
  animation:viewIn .5s cubic-bezier(.2,.7,.3,1);
}
.gate-card > svg{width:54px;height:54px;filter:drop-shadow(0 0 12px rgba(69,207,196,.4));margin-bottom:10px}
.gate-word{font-family:var(--font-d);font-weight:700;font-size:23px;letter-spacing:.16em}
.gate-word em{
  display:block;font-family:var(--font-m);font-style:normal;font-weight:400;
  font-size:9px;letter-spacing:.22em;color:var(--dim);margin-top:7px;text-transform:uppercase;
}
.gate-card .fld-label{text-align:left;margin-top:24px}
.gate-err{margin-top:12px;font-size:9.5px;letter-spacing:.14em;color:var(--red)}
.gate-err[hidden]{display:none}
.gate-err.shake{animation:shake .4s}
@keyframes shake{0%,100%{transform:none}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}
.gate-foot{margin-top:20px;font-size:8.5px;letter-spacing:.22em;color:var(--faint)}

.claude-out{
  margin-top:14px;border:1px solid rgba(240,160,40,.35);border-radius:9px;
  background:rgba(240,160,40,.05);padding:12px 13px;
  animation:feedIn .35s ease;
}
.co-head{
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  font-size:9px;letter-spacing:.16em;color:var(--amber);margin-bottom:8px;
}
.co-apply{
  font-family:var(--font-m);font-size:8.5px;letter-spacing:.08em;
  color:var(--amber-hi);border:1px solid rgba(240,160,40,.4);
  border-radius:5px;padding:3.5px 9px;transition:all .15s;white-space:nowrap;
}
.co-apply:hover{background:rgba(240,160,40,.14)}
.co-body{font-size:12.5px;color:#e6dcc6;line-height:1.6;white-space:pre-wrap}

/* render canvas must stay composited (not display:none) or captureStream
   delivers no frames — park it off-screen instead */
.render-canvas{position:fixed;left:-12000px;top:0;pointer-events:none}

/* ============================ TOASTS ============================ */
.toasts{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:9px;z-index:1000}
.toast{
  background:linear-gradient(180deg,#221c12,#181309);
  border:1px solid rgba(240,160,40,.4);border-radius:10px;
  padding:12px 18px;font-size:13px;max-width:340px;
  box-shadow:0 12px 40px rgba(0,0,0,.5);
  animation:toastIn .35s cubic-bezier(.2,.7,.3,1);
}
.toast b{color:var(--amber-hi)}
.toast.teal{border-color:rgba(67,217,192,.4)}
.toast.teal b{color:var(--teal)}
.toast.out{animation:toastOut .3s ease forwards}
@keyframes toastIn{from{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:none}}
@keyframes toastOut{to{opacity:0;transform:translateY(8px)}}

/* ============================ RESPONSIVE ============================ */
@media (max-width:1280px){
  .cinema-grid{grid-template-columns:270px 1fr}
  .cam-panel{grid-column:1 / -1;display:grid;grid-template-columns:1fr 1fr;gap:0 26px}
  .stack-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:1080px){
  .deck-hero,.deck-cols,.knowledge-grid,.mkt-cols,.roi-cols,.ci-grid{grid-template-columns:1fr}
  .ci-bar{flex-direction:column;align-items:stretch}
  .loc-controls{grid-template-columns:1fr}
  .loc-controls .fld{max-width:none}
  .knowledge-grid{height:auto}
  .tpl-grid,.kpi-grid{grid-template-columns:repeat(2,1fr)}
  .rail{width:74px;min-width:74px;padding:22px 10px 16px}
  .logo-word,.nav-item span,.stack-mini,.user-chip div:last-child{display:none}
  .nav-item{justify-content:center}
  .rail-logo{justify-content:center;padding-bottom:16px}
}
