/* =========================================================================
   Rooky — live.css   (intelligence-forward sections & live widgets)
   Loaded after components.css.
   ========================================================================= */

/* ---------- shared SVG gradients live in the HTML <defs> ---------- */

/* ===================== HERO v2 — centered + decision pipeline ===================== */
.hero-center{position:relative;z-index:2;text-align:center;display:flex;flex-direction:column;align-items:center}
.hero-center h1{font-size:clamp(46px,7.4vw,96px);margin:28px 0 0;letter-spacing:-0.045em;line-height:1.0}
.hero-center .sub{margin:24px auto 0;font-size:clamp(16px,2vw,19px);line-height:1.6;color:var(--ink-2);max-width:58ch}
.hero-center .cta{margin-top:32px;display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}

.pipeline{position:relative;z-index:2;margin-top:clamp(38px,5vw,58px);padding:20px 22px 16px;text-align:left}
.pl-head{display:flex;align-items:center;gap:14px;justify-content:space-between;font-family:var(--mono);font-size:10.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-3);margin-bottom:16px}
.pl-title{flex:1;text-align:center}
.pl-clock{color:var(--ink-4);font-variant-numeric:tabular-nums;white-space:nowrap;flex-shrink:0}
.pl-flow{display:flex;align-items:stretch}
.pl-node{flex:1;min-width:0;background:var(--panel-2);border:1px solid var(--hair-soft);border-radius:12px;padding:13px 14px 11px;display:flex;flex-direction:column;gap:8px;transition:border-color .4s,box-shadow .4s,opacity .4s}
.pl-node.hot{border-color:color-mix(in srgb,var(--up) 36%,var(--hair));box-shadow:0 0 26px -10px color-mix(in srgb,var(--up) 42%,transparent)}
.pl-node.dim{opacity:.6}
.pl-k{font-family:var(--mono);font-size:9.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--cyan)}
.pl-d{font-size:11px;color:var(--ink-4);line-height:1.4;margin-top:auto}
.pl-v{font-family:var(--mono);font-size:12.5px;color:var(--ink);font-variant-numeric:tabular-nums;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pl-wave{height:36px}
.pl-wave svg{width:100%;height:100%;display:block}
.pl-conn{width:26px;flex-shrink:0;position:relative;align-self:center;height:2px;background:var(--hair)}
.pl-conn i{position:absolute;top:50%;left:0;width:6px;height:6px;border-radius:50%;background:var(--cyan);transform:translate(-50%,-50%);box-shadow:0 0 8px 1px color-mix(in srgb,var(--cyan) 70%,transparent);animation:connPulse 1.8s linear infinite}
@keyframes connPulse{0%{left:0;opacity:0}15%{opacity:1}85%{opacity:1}100%{left:100%;opacity:0}}
.pl-checks{display:flex;flex-direction:column;gap:5px}
.pl-checks span{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10.5px;color:var(--ink-2);transition:color .3s}
.pl-checks i{width:14px;height:14px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;font-size:9px;font-style:normal;flex-shrink:0;background:var(--up-soft);color:var(--up);transition:.3s}
.pl-checks span.off i{background:var(--panel);color:var(--ink-4);border:1px solid var(--hair)}
.pl-checks span.off{color:var(--ink-4)}
.pl-pats{display:flex;gap:5px;flex-wrap:wrap}
.pl-pats span{font-family:var(--mono);font-size:10px;padding:3px 7px;border-radius:5px;border:1px solid var(--hair);color:var(--ink-3);transition:.3s}
.pl-pats span.on{color:var(--up);border-color:color-mix(in srgb,var(--up) 42%,transparent);background:var(--up-soft)}
.pl-decision{font-family:var(--mono);font-weight:700;font-size:17px;letter-spacing:0.04em;color:var(--up);transition:color .3s;white-space:nowrap}
.pl-decision.wait{color:var(--ink-3)}
.pl-exit{display:flex;flex-direction:column;gap:5px;font-family:var(--mono);font-size:10px;color:var(--ink-3)}
.pl-exit span{display:flex;align-items:center;gap:6px;white-space:nowrap}
.pl-exit i{width:7px;height:7px;border-radius:2px;flex-shrink:0}
.pl-term{margin-top:14px;border-top:1px solid var(--hair-soft);padding-top:11px;display:flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12px;color:var(--ink-2);min-height:28px;overflow:hidden;white-space:nowrap}
.pl-prompt{color:var(--cyan);flex-shrink:0}
.pl-caret{width:7px;height:14px;background:var(--cyan);flex-shrink:0;animation:caretBlink 1s steps(1) infinite}
@keyframes caretBlink{50%{opacity:0}}
@media(max-width:960px){
  .pl-flow{flex-wrap:wrap;gap:10px}
  .pl-node{flex:1 1 calc(50% - 10px)}
  .pl-conn{display:none}
}
@media(max-width:560px){.pl-node{flex:1 1 100%}}
@media(prefers-reduced-motion:reduce){.pl-conn i,.pl-caret{animation:none}}

/* ===================== HERO CONSOLE upgrades ===================== */
.gp-head .live-tag{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--cyan)}
.gp-head .live-tag i{width:6px;height:6px;border-radius:50%;background:var(--cyan);box-shadow:0 0 0 0 color-mix(in srgb,var(--cyan) 60%,transparent);animation:liveBlink 1.8s var(--ease) infinite}
@keyframes liveBlink{0%,100%{box-shadow:0 0 0 0 color-mix(in srgb,var(--cyan) 55%,transparent)}50%{box-shadow:0 0 0 5px transparent}}

.console-read{display:flex;align-items:center;gap:14px;margin-top:14px}
.console-wave{flex:1;height:54px;min-width:0}
.console-wave svg{width:100%;height:100%;display:block}
.score-ring{position:relative;width:74px;height:74px;flex-shrink:0}
.score-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.score-ring .sr-c{fill:none;stroke-width:6}
.score-ring .sr-bg{stroke:var(--hair)}
.score-ring .sr-fg{stroke:url(#ringGrad);stroke-linecap:round;transition:none}
.score-ring .sr-label{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px}
.score-ring .sr-num{font-family:var(--mono);font-weight:700;font-size:17px;color:var(--ink);line-height:1}
.score-ring .sr-cap{font-family:var(--mono);font-size:8px;letter-spacing:0.1em;color:var(--ink-4);text-transform:uppercase}

/* hero gate rows: reframed to states + confidence bar */
.gp-gate .n{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gp-gate .st{margin-left:10px;font-family:var(--mono);font-size:10.5px;letter-spacing:0.04em;color:var(--up);text-align:right;flex-shrink:0;white-space:nowrap}
.gp-gate .cf{display:block;width:44px;height:4px;border-radius:3px;background:var(--hair);overflow:hidden;flex-shrink:0}
.gp-gate .cf > i{display:block;height:100%;width:80%;border-radius:3px;background:linear-gradient(90deg,var(--blue),var(--cyan))}

/* ===================== GATES — consensus engine ===================== */
.gates-grid{display:grid;grid-template-columns:1.25fr 0.75fr;gap:30px;align-items:center}
@media(max-width:980px){.gates-grid{grid-template-columns:1fr;gap:34px}}
#gateGrid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(max-width:560px){#gateGrid{grid-template-columns:1fr}}
.gate-tile{position:relative;padding:16px 16px 18px;border:1px solid var(--hair);border-radius:var(--radius-sm);background:var(--panel-2);overflow:hidden;transition:border-color .4s,background .4s}
.gate-tile.ok{border-color:color-mix(in srgb,var(--up) 26%,var(--hair))}
.gate-tile.warn{border-color:color-mix(in srgb,var(--warn) 26%,var(--hair))}
.gate-tile.mut{opacity:.72}
.gate-tile:nth-child(5){grid-column:1/-1}
.gt-w{margin-left:auto;font-family:var(--mono);font-size:10px;letter-spacing:0.05em;color:var(--ink-3);border:1px solid var(--hair);padding:2.5px 7px;border-radius:6px;background:var(--bg);white-space:nowrap}
.gt-w.call{color:var(--blue);border-color:color-mix(in srgb,var(--blue) 32%,var(--hair))}
.gt-w.put{color:var(--down);border-color:color-mix(in srgb,var(--down) 32%,var(--hair))}
.gate-tile.ok .gt-w{background:color-mix(in srgb,var(--up) 8%,var(--bg))}
/* safety gate checklist */
.sg-list{display:flex;flex-direction:column;gap:8px;text-align:left}
.sg-check{display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--ink-2);font-family:var(--sans)}
.sg-check i{width:18px;height:18px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-style:normal;flex-shrink:0;transition:.3s;background:var(--up-soft);color:var(--up)}
.sg-check.off i{background:var(--panel-2);color:var(--ink-4);border:1px solid var(--hair)}
.sg-check.off{color:var(--ink-3)}
.gt-top{display:flex;align-items:center;gap:8px;margin-bottom:11px}
.gt-dot{width:8px;height:8px;border-radius:50%;background:var(--ink-4);flex-shrink:0;transition:background .4s,box-shadow .4s}
.gt-dot.ok{background:var(--up);box-shadow:0 0 0 4px var(--up-soft)}
.gt-dot.warn{background:var(--warn);box-shadow:0 0 0 4px color-mix(in srgb,var(--warn) 16%,transparent)}
.gt-dot.mut{background:var(--ink-4)}
.gt-state{font-family:var(--mono);font-size:10px;letter-spacing:0.12em;color:var(--ink-3);text-transform:uppercase}
.gate-tile.ok .gt-state{color:var(--up)}.gate-tile.warn .gt-state{color:var(--warn)}
.gt-name{font-family:var(--disp);font-weight:600;font-size:15px;letter-spacing:-0.01em;color:var(--ink)}
.gt-desc{font-size:12px;color:var(--ink-3);margin-top:3px;line-height:1.4}
.gt-bar{margin-top:13px;height:5px;border-radius:3px;background:var(--hair);overflow:hidden}
.gt-bar > i{display:block;height:100%;width:50%;border-radius:3px;background:linear-gradient(90deg,var(--blue),var(--cyan))}
.gt-bar > i.ok{background:linear-gradient(90deg,var(--up),#34d399)}
.gt-bar > i.warn{background:linear-gradient(90deg,var(--warn),#f7c873)}
.gt-bar > i.mut{background:var(--ink-4)}

/* consensus gauge */
.consensus{padding:30px 26px;text-align:center;position:relative}
.gauge{position:relative;width:200px;height:200px;margin:6px auto 0}
.gauge svg{width:100%;height:100%;transform:rotate(-90deg)}
.gauge .g-c{fill:none;stroke-width:11}
.gauge .g-bg{stroke:var(--hair)}
.gauge .g-fg{stroke:url(#gaugeGrad);stroke-linecap:round}
.gauge-label{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}
.gauge-num{font-family:var(--mono);font-weight:700;font-size:46px;letter-spacing:-0.02em;color:var(--ink);line-height:1}
.gauge-num::after{content:"%";font-size:20px;color:var(--ink-3);margin-left:2px}
.gauge-num.raw{font-size:42px}
.gauge-num.raw::after{content:""}
.gauge-cap{font-family:var(--mono);font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-4)}
.consensus-decision{margin-top:20px;display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-weight:600;font-size:15px;letter-spacing:0.08em;padding:11px 22px;border-radius:11px;transition:.4s}
.consensus-decision::before{content:"";width:8px;height:8px;border-radius:50%}
.consensus-decision.engage{color:var(--up);background:var(--up-soft);border:1px solid color-mix(in srgb,var(--up) 36%,transparent)}
.consensus-decision.engage::before{background:var(--up);box-shadow:0 0 0 4px var(--up-soft)}
.consensus-decision.hold{color:var(--ink-3);background:var(--panel-2);border:1px solid var(--hair)}
.consensus-decision.hold::before{background:var(--ink-4)}
.consensus-count{margin-top:14px;font-family:var(--mono);font-size:11.5px;color:var(--ink-3);letter-spacing:0.03em}
.consensus-sub{margin-top:6px;font-size:12.5px;color:var(--ink-4);max-width:30ch;margin-left:auto;margin-right:auto;line-height:1.5}

/* ===================== ALWAYS WATCHING band ===================== */
.watch{position:relative;border-radius:calc(var(--radius) + 6px);border:1px solid var(--hair);overflow:hidden;background:var(--panel-2)}
.watch .field-glow{opacity:.7}
.watch-wave-wrap{position:absolute;inset:0;z-index:0;opacity:.55}
.watch-wave-wrap svg{width:100%;height:100%;display:block}
.watch-inner{position:relative;z-index:2;padding:clamp(36px,5vw,58px) clamp(28px,5vw,56px)}
.watch-top{display:flex;align-items:flex-start;justify-content:space-between;gap:30px;flex-wrap:wrap}
.watch-h{max-width:30ch}
.watch-h h2{font-size:clamp(28px,3.8vw,42px);letter-spacing:-0.03em;margin-bottom:14px}
.watch-h p{font-size:15.5px;color:var(--ink-2);line-height:1.6}
.watch-live{display:flex;align-items:center;gap:9px;font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--up);white-space:nowrap}
.watch-live i{width:8px;height:8px;border-radius:50%;background:var(--up);box-shadow:0 0 0 0 var(--up-soft);animation:liveBlink 1.6s var(--ease) infinite}
.watch-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin-top:38px;background:var(--hair-soft);border:1px solid var(--hair-soft);border-radius:14px;overflow:hidden}
.watch-stat{background:color-mix(in srgb,var(--bg) 55%,var(--panel-2));backdrop-filter:blur(6px);padding:22px 20px}
.watch-stat .ws-n{font-family:var(--mono);font-weight:700;font-size:clamp(24px,3vw,30px);letter-spacing:-0.01em;color:var(--ink);font-variant-numeric:tabular-nums}
.watch-stat .ws-n .u{font-size:14px;color:var(--ink-3);font-weight:500;margin-left:3px}
.watch-stat .ws-l{margin-top:7px;font-size:12px;line-height:1.45;color:var(--ink-3)}
@media(max-width:760px){.watch-stats{grid-template-columns:1fr 1fr}}

/* ===================== VALIDATION — adherence gauge ===================== */
.adherence{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:26px}
.gauge-sm{position:relative;width:150px;height:150px}
.gauge-sm svg{width:100%;height:100%;transform:rotate(-90deg)}
.gauge-sm .g-c{fill:none;stroke-width:9}
.gauge-sm .g-bg{stroke:var(--hair)}
.gauge-sm .g-fg{stroke:url(#adhGrad);stroke-linecap:round}
.gauge-sm .gauge-label .gauge-num{font-size:34px}
.adherence h4{font-family:var(--disp);font-weight:600;font-size:17px;margin-top:18px;letter-spacing:-0.01em}
.adherence p{font-size:13px;color:var(--ink-3);margin-top:7px;max-width:30ch;line-height:1.5}

/* draw-on for validation line */
#valChart .draw{stroke-dasharray:1400;stroke-dashoffset:1400;animation:drawLine 1.8s var(--ease) forwards;animation-delay:.2s}
@keyframes drawLine{to{stroke-dashoffset:0}}

/* ===================== EXIT PLAN — live chart ===================== */
.exit-chart{position:relative;height:330px;margin:18px 0 6px}
.exit-chart svg{width:100%;height:100%;display:block}
.ec-tag{position:absolute;transform:translateY(-50%);font-family:var(--mono);font-size:10.5px;letter-spacing:0.02em;white-space:nowrap;
  padding:3px 9px;border-radius:6px;border:1px solid var(--hair-soft);background:var(--bg);color:var(--ink-3);pointer-events:none;z-index:3}
.ec-tag.l{left:8px}
.ec-tag.r{right:8px}
.ec-tag.dn{color:var(--down);border-color:color-mix(in srgb,var(--down) 34%,transparent)}
.ec-tag.ok{color:var(--up);border-color:color-mix(in srgb,var(--up) 40%,transparent);background:color-mix(in srgb,var(--up) 10%,var(--bg))}
.ec-tag.bl{color:var(--blue);border-color:color-mix(in srgb,var(--blue) 34%,transparent)}
.ec-tag.wn{color:var(--warn);border-color:color-mix(in srgb,var(--warn) 34%,transparent)}
.ec-tag.peak{transform:translate(-50%,-145%)}
.ec-events{position:absolute;inset:0;pointer-events:none;z-index:4}
.ec-evt{position:absolute;transform:translate(-50%,-50%) scale(.75);opacity:0;font-family:var(--mono);font-size:10px;letter-spacing:.02em;padding:3px 9px;border-radius:6px;border:1px solid var(--hair-soft);background:var(--bg);color:var(--ink-2);white-space:nowrap;pointer-events:none;z-index:4;transition:opacity .35s,transform .35s}
.ec-evt.pop{opacity:1;transform:translate(-50%,-50%) scale(1)}
.ec-evt.ok{color:var(--up);border-color:color-mix(in srgb,var(--up) 38%,transparent)}
.ec-evt.dn{color:var(--down);border-color:color-mix(in srgb,var(--down) 38%,transparent)}
.ec-evt.wn{color:var(--warn);border-color:color-mix(in srgb,var(--warn) 38%,transparent)}
.ec-evt.bl{color:var(--blue);border-color:color-mix(in srgb,var(--blue) 38%,transparent)}
.ec-progress{height:3px;border-radius:99px;background:var(--hair);margin-top:10px;overflow:hidden}
.ec-progress i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--blue),var(--cyan));border-radius:99px}
.ec-scenarios{display:flex;align-items:center;gap:8px;margin-top:13px;flex-wrap:wrap}
.ec-sc-label{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-4);margin-right:2px}
.ec-sc{font-family:var(--mono);font-size:11px;letter-spacing:.03em;padding:7px 12px;border-radius:8px;border:1px solid var(--hair);background:var(--panel-2);color:var(--ink-3);cursor:pointer;transition:color .25s,border-color .25s,background .25s}
.ec-sc:hover{color:var(--ink)}
.ec-sc.on{color:var(--ink);border-color:color-mix(in srgb,var(--cyan) 45%,var(--hair));background:color-mix(in srgb,var(--cyan) 10%,var(--panel-2))}
.ec-replay{margin-left:auto;font-size:14px;width:30px;height:30px;border-radius:8px;border:1px solid var(--hair);background:var(--panel-2);color:var(--ink-3);cursor:pointer;transition:color .25s}
.ec-replay:hover{color:var(--ink)}
.ec-dot{animation:ecPulse 1.6s ease-in-out infinite}
.ec-diamond{filter:drop-shadow(0 0 7px color-mix(in srgb,var(--blue) 80%,transparent))}
@keyframes ecPulse{0%,100%{opacity:1}50%{opacity:.4}}
@media(prefers-reduced-motion:reduce){.ec-dot{animation:none}}

/* ===================== ARCHITECTURE pulses ===================== */
.arch-cells .pulse{position:absolute;left:0;top:0;bottom:0;width:90px;pointer-events:none;
  background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--cyan) 10%,transparent),transparent);
  animation:flowPulse 3.4s linear infinite;opacity:0}
@keyframes flowPulse{0%{left:-90px;opacity:0}10%{opacity:1}90%{opacity:1}100%{left:100%;opacity:0}}

/* gates section background scan line */
.gates-stage{position:relative}
.scan-line{position:absolute;left:0;right:0;height:120px;pointer-events:none;z-index:1;
  background:linear-gradient(180deg,transparent,color-mix(in srgb,var(--cyan) 7%,transparent),transparent);
  animation:scanMove 5.5s var(--ease) infinite}
@keyframes scanMove{0%{top:-120px}100%{top:100%}}

@media(prefers-reduced-motion:reduce){
  .arch-cells .pulse,.scan-line,.watch-live i,.gp-head .live-tag i{animation:none}
  #valChart .draw{animation:none;stroke-dashoffset:0}
}
