/* ============================================================================
   SOARCERY INDEX HERO: THE TRAILER (Spec 03, docs/specs/03-hero-trailer.md)
   A 4-scene cinematic "trailer" of the autonomous, human-on-the-loop SOC.
   SEE (Omens) > INSTRUCT (Spell) > REASON (Coven) > CONTROL (Pact).
   Ported from claude design's design_handoff_hero_trailer kit. Site deltas:
   tokens come from site.css, height respects the sticky header, and every
   scene's visual stage is clipped above the copy block (--stage-clear is set
   by trailer.js from the measured copy height) so NOTHING can overlap the
   words, in any scene or animation. Three-light: purple=Soarcery/AI,
   teal=resolved/human, orange=attention, red=confirmed-bad.
   ============================================================================ */

.trailer{position:relative;width:100%;height:calc(100vh - var(--nav-h,69px));min-height:640px;max-height:980px;overflow:hidden;
  background:radial-gradient(120% 90% at 50% -10%,rgba(124,58,237,.06),transparent 60%),#050508}

/* ---- progress bar (top) ---- */
.t-progress{position:absolute;top:0;left:0;right:0;height:2px;z-index:30;background:rgba(255,255,255,.05)}
.t-progress-fill{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--purple-400),var(--purple-300));box-shadow:0 0 12px var(--purple-glow)}

/* ---- ambient field ---- */
.t-field{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.t-field .halo{position:absolute;border-radius:9999px;filter:blur(110px);transition:background 1.2s ease,opacity 1.2s ease,transform 1.2s ease}
.halo-a{top:-22%;left:-4%;width:60vw;height:60vw;max-width:880px;max-height:880px;opacity:.46;background:radial-gradient(circle,var(--purple-glow),transparent 60%)}
.halo-b{top:12%;right:4%;width:42vw;height:42vw;opacity:.22;background:radial-gradient(circle,var(--teal-glow),transparent 60%)}
.halo-c{bottom:-34%;left:34%;width:42vw;height:42vw;opacity:.14;background:radial-gradient(circle,var(--orange-glow),transparent 60%)}
.t-grid{position:absolute;inset:auto 0 0 0;height:52%;
  background-image:linear-gradient(rgba(124,58,237,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(124,58,237,.07) 1px,transparent 1px);
  background-size:52px 52px;-webkit-mask-image:linear-gradient(to top,#000,transparent);mask-image:linear-gradient(to top,#000,transparent);
  transform:perspective(680px) rotateX(60deg);transform-origin:bottom;opacity:.4}
.t-dust{position:absolute;inset:0}
.t-dust i{position:absolute;width:2px;height:2px;border-radius:9999px;background:#fff;animation:t-tw 6s ease-in-out infinite}
@keyframes t-tw{0%,100%{opacity:.05}50%{opacity:.3}}

/* field tints per scene (set on .trailer[data-scene]) */
.trailer[data-scene="1"] .halo-b{opacity:.26}
.trailer[data-scene="2"] .halo-a{opacity:.6} .trailer[data-scene="2"] .halo-b{opacity:.1}
.trailer[data-scene="3"] .halo-b{opacity:.3} .trailer[data-scene="3"] .halo-c{opacity:.2}
.trailer[data-scene="4"] .halo-a{opacity:.32} .trailer[data-scene="4"] .halo-b{opacity:.36;background:radial-gradient(circle,var(--teal-glow),transparent 60%)}

/* ---- scenes ---- */
.t-scenes{position:absolute;inset:0;z-index:2}
.scene{position:absolute;inset:0;opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .8s ease,visibility .8s ease}
.scene.is-active{opacity:1;visibility:visible;pointer-events:auto}

/* the staged area where each scene's visual lives. The bottom boundary is the
   no-overlap guarantee: trailer.js measures the tallest copy block and sets
   --stage-clear so the stage (overflow:hidden) ends above the words. */
.scene-stage{position:absolute;left:0;right:0;top:0;bottom:var(--stage-clear,44%);z-index:2;overflow:hidden}
/* top-center scene title (the "shot" label) */
.scene-kicker{position:absolute;top:34px;left:0;right:0;z-index:4;text-align:center;pointer-events:none}
.scene-kicker .k1{display:block;font-family:var(--font-mono);font-size:14px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--fg)}
.scene-kicker .k2{display:block;font-family:var(--font-mono);font-size:12.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--purple-300);margin-top:9px}

/* ---- headline block (lower-left, per scene) ---- */
.scene-copy{position:absolute;left:clamp(28px,5vw,72px);bottom:6vh;z-index:5;max-width:min(640px,52vw)}
.scene-copy .eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-mono);font-size:12px;font-weight:500;
  text-transform:uppercase;letter-spacing:.18em;color:var(--purple-300)}
.scene-copy .eyebrow .tick{width:8px;height:8px;border-radius:9999px;background:var(--purple-400);box-shadow:0 0 12px var(--purple-glow)}
.scene-copy h1,.scene-copy .t-h1{font-size:clamp(30px,3.6vw,46px);line-height:1.04;letter-spacing:-.034em;margin:14px 0 0;text-wrap:balance;font-weight:600}
.scene-copy .grad{background:linear-gradient(108deg,#fff 6%,var(--purple-300) 54%,var(--purple-400) 92%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.scene-copy .grad-teal{background:linear-gradient(108deg,#fff 6%,var(--teal-300) 60%,var(--teal-400) 95%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.scene-copy .sub{font-size:clamp(14.5px,1.5vw,17px);line-height:1.5;color:var(--fg-muted);margin:14px 0 0;max-width:560px}
.scene-copy .sub b{color:var(--fg-secondary);font-weight:600}
.scene-copy .cta-row{display:flex;gap:13px;margin-top:20px;flex-wrap:wrap}
/* buttons come from site.css (.btn/.btn-lg/.btn-cast/.btn-ghost) */
/* server-rendered SEO copy block: visible without JS, adopted into scene 1 by
   trailer.js on start (it gains .rv reveals there) */
.trailer > .scene-copy.t-static{z-index:6}

/* staged reveal helper: elements animate in when scene becomes active */
.rv{opacity:0;transform:translateY(14px)}
.scene.is-active .rv{animation:rv-in .8s cubic-bezier(.2,.7,.2,1) forwards}
.scene.is-active .rv.d1{animation-delay:.15s}.scene.is-active .rv.d2{animation-delay:.32s}
.scene.is-active .rv.d3{animation-delay:.5s}.scene.is-active .rv.d4{animation-delay:.68s}
@keyframes rv-in{to{opacity:1;transform:none}}

/* ---- scene dots ---- */
.t-dots{position:absolute;right:26px;top:38%;transform:translateY(-50%);z-index:20;display:flex;flex-direction:column;gap:14px}
.t-dot{width:9px;height:9px;border-radius:9999px;border:0;background:rgba(255,255,255,.2);cursor:pointer;padding:0;position:relative;transition:background .3s ease,transform .3s ease}
.t-dot:hover{background:rgba(255,255,255,.4)}
.t-dot.on{background:var(--purple-300);transform:scale(1.35);box-shadow:0 0 12px var(--purple-glow)}

/* ---- control ---- */
.t-control{position:absolute;right:22px;bottom:22px;z-index:25;display:flex;align-items:center;gap:13px;
  padding:8px 14px 8px 9px;border-radius:9999px;background:rgba(12,12,18,.78);border:1px solid var(--border-strong);
  backdrop-filter:blur(8px);opacity:.5;transition:opacity .2s ease}
.t-control:hover{opacity:1}
.t-play{width:30px;height:30px;border-radius:9999px;border:1px solid var(--border-strong);background:rgba(255,255,255,.04);color:var(--fg-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}
.t-play:hover{color:#fff;border-color:var(--purple-400)}
.t-play svg{width:15px;height:15px;fill:currentColor}
.t-play .ic-play{display:none}
.trailer.paused .t-play .ic-pause{display:none}
.trailer.paused .t-play .ic-play{display:block;margin-left:1px}
.t-count{font-family:var(--font-mono);font-size:12.5px;font-weight:600;color:var(--fg);letter-spacing:.06em;font-variant-numeric:tabular-nums}
.t-label{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-faint);padding-left:12px;border-left:1px solid var(--border)}

/* ===========================================================================
   SHARED constellation kit (scene 1)
   =========================================================================== */
.cn-wires{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:visible}
.cn-base{fill:none;stroke:rgba(176,168,210,.2);stroke-width:1.3}
.cn-live{fill:none;stroke-width:2.4;stroke-linecap:round;opacity:0;filter:drop-shadow(0 0 6px currentColor);transition:opacity .4s ease}
.cn-live.on{opacity:.8}
.cn-core{fill:#fff;opacity:0}
.cn-halo{opacity:0}

/* ===========================================================================
   SCENE 1: THE OMENS (evidence trail)
   =========================================================================== */
.omen{position:absolute;z-index:3;transform:translate(-50%,-50%);min-width:188px;max-width:240px;display:flex;align-items:center;gap:12px;
  padding:12px 15px 12px 12px;border-radius:14px;background:linear-gradient(180deg,rgba(20,20,30,.72),rgba(12,12,20,.82));
  border:1px solid var(--border);box-shadow:0 16px 44px rgba(0,0,0,.5);backdrop-filter:blur(7px);
  opacity:.32;filter:saturate(.5);transition:opacity .5s ease,filter .5s ease,border-color .5s ease,box-shadow .5s ease}
.omen .ic{width:36px;height:36px;flex:none;border-radius:11px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--border-strong);background:rgba(124,58,237,.07);color:var(--fg-muted);transition:all .5s ease}
.omen .ic svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.omen .tt{display:block;font-size:14px;font-weight:600;letter-spacing:-.01em;color:var(--fg-secondary);line-height:1.22;text-wrap:balance}
.omen .mt{display:block;font-family:var(--font-mono);font-size:10.5px;color:var(--fg-faint);margin-top:5px;letter-spacing:.02em}
.omen .corner{position:absolute;top:-9px;right:-9px;width:20px;height:20px;border-radius:9999px;display:flex;align-items:center;justify-content:center;background:#0a0a12;border:1px solid var(--border-strong);opacity:0;transform:scale(.6);transition:opacity .4s ease,transform .4s ease}
.omen .corner svg{width:11px;height:11px;fill:none;stroke:currentColor;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.omen.lit{opacity:1;filter:none;border-color:rgba(124,58,237,.3)}
.omen.lit .tt{color:var(--fg)} .omen.lit .ic{color:var(--purple-300);border-color:rgba(124,58,237,.5);background:rgba(124,58,237,.14);box-shadow:0 0 20px rgba(124,58,237,.26)}
.omen.lit .corner{opacity:1;transform:none}
.omen.pop{animation:omen-pop .6s cubic-bezier(.3,1.4,.5,1)}
@keyframes omen-pop{0%{transform:translate(-50%,-50%) scale(1)}40%{transform:translate(-50%,-50%) scale(1.06)}100%{transform:translate(-50%,-50%) scale(1)}}
.omen.k-malicious.lit{border-color:rgba(239,68,68,.45);box-shadow:0 0 28px rgba(239,68,68,.2),0 16px 44px rgba(0,0,0,.5)}
.omen.k-malicious.lit .ic{color:#fca5a5;border-color:rgba(239,68,68,.5);background:rgba(239,68,68,.12);box-shadow:0 0 20px rgba(239,68,68,.3)}
.omen.k-malicious.lit .corner{border-color:rgba(239,68,68,.6);color:#fca5a5}
.omen.alert{min-width:262px;max-width:300px;padding:17px 19px;border-radius:18px}
.omen.alert .tt{font-size:17px}.omen.alert .ic{width:44px;height:44px;border-radius:13px}.omen.alert .ic svg{width:22px;height:22px}
.omen.alert.lit{border-color:rgba(239,68,68,.6);background:radial-gradient(120% 120% at 20% 0%,rgba(239,68,68,.18),rgba(12,12,20,.9));box-shadow:0 0 56px rgba(239,68,68,.32),0 22px 64px rgba(0,0,0,.6)}
.omen.alert.lit .ic{color:#fca5a5;border-color:rgba(239,68,68,.55);background:rgba(239,68,68,.16);box-shadow:0 0 24px rgba(239,68,68,.4)}
.omen.alert.lit .tt{color:#fff}
.omen.alert .badge{display:inline-flex;align-items:center;gap:7px;margin-top:8px;font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;color:#fca5a5;text-transform:uppercase}
.omen.alert .badge .pin{width:7px;height:7px;border-radius:9999px;background:#ef4444;box-shadow:0 0 10px rgba(239,68,68,.7);animation:t-beat 1.4s ease-in-out infinite}
@keyframes t-beat{0%,100%{opacity:1}50%{opacity:.35}}
.omen.agent .state-run,.omen.agent .state-done{display:flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:10.5px;margin-top:6px;letter-spacing:.03em}
.omen.agent .state-run{color:var(--purple-300)}.omen.agent .state-done{color:var(--teal-300);display:none}
.omen.agent .spin{width:11px;height:11px;border-radius:9999px;border:2px solid var(--purple-300);border-top-color:transparent;animation:t-spin 1s linear infinite}
@keyframes t-spin{to{transform:rotate(360deg)}}
.omen.agent.resolved{border-color:rgba(20,184,166,.5);box-shadow:0 0 32px rgba(20,184,166,.22),0 16px 44px rgba(0,0,0,.5)}
.omen.agent.resolved .ic{color:var(--teal-300);border-color:rgba(20,184,166,.5);background:rgba(20,184,166,.12);box-shadow:0 0 20px rgba(20,184,166,.3)}
.omen.agent.resolved .state-run{display:none}.omen.agent.resolved .state-done{display:flex}
.omen.agent.resolved .corner{border-color:rgba(20,184,166,.6);color:var(--teal-300)}
.cn-elabel{position:absolute;z-index:2;transform:translate(-50%,-50%);font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-faint);background:rgba(8,8,14,.7);padding:2px 8px;border-radius:6px;border:1px solid var(--border);white-space:nowrap;opacity:0;transition:opacity .5s ease}
.cn-elabel.show{opacity:1}

/* ===========================================================================
   SCENE 2: THE SPELL (plain English > workflow)
   Site delta: the spell column is a centered flex stack (card + plan) so it
   always fits inside the clipped stage instead of using fixed px offsets.
   =========================================================================== */
.spell{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(940px,92vw);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:clamp(14px,3vh,26px)}
.spell-card{position:relative;width:min(760px,100%);border:1px solid var(--border-strong);border-radius:20px;padding:clamp(16px,2.6vh,26px) 30px;
  background:linear-gradient(180deg,rgba(22,20,34,.8),rgba(12,12,20,.85));box-shadow:0 30px 90px rgba(0,0,0,.5),0 0 60px rgba(124,58,237,.12);backdrop-filter:blur(8px)}
.spell-card .lab{font-family:var(--font-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-faint);display:flex;align-items:center;gap:10px}
.spell-card .lab .glyph{color:var(--purple-300)}
.spell-text{font-size:clamp(22px,2.6vw,32px);font-weight:600;letter-spacing:-.02em;line-height:1.2;margin-top:12px;color:var(--fg);min-height:1.2em}
.spell-text .cap{color:var(--purple-300);font-weight:700}
.spell-caret{display:inline-block;width:3px;height:1.05em;background:var(--purple-300);margin-left:3px;vertical-align:-.15em;animation:t-blink 1s step-end infinite}
@keyframes t-blink{50%{opacity:.2}}
.spell-cast{margin-top:14px;display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:12.5px;color:var(--purple-300);opacity:0;transition:opacity .4s ease}
.spell-cast.show{opacity:1}
.spell-cast .dot{width:7px;height:7px;border-radius:9999px;background:var(--purple-400);box-shadow:0 0 10px var(--purple-glow);animation:t-beat 1.3s ease-in-out infinite}
/* the compiled plan steps */
.spell-plan{width:100%;z-index:3;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.plan-step{display:flex;align-items:center;gap:11px;padding:12px 15px;border-radius:13px;border:1px solid var(--border);
  background:rgba(14,14,22,.7);min-width:156px;opacity:0;transform:translateY(10px) scale(.96)}
.plan-step.in{animation:plan-in .55s cubic-bezier(.3,1.2,.5,1) forwards}
@keyframes plan-in{to{opacity:1;transform:none}}
.plan-step .pn{width:30px;height:30px;border-radius:9px;flex:none;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-strong);background:rgba(124,58,237,.1);color:var(--purple-300)}
.plan-step .pn svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.plan-step .pt{font-size:13.5px;font-weight:600;color:var(--fg-secondary)}
.plan-step .ps{display:block;font-family:var(--font-mono);font-size:10px;color:var(--fg-faint);margin-top:3px;letter-spacing:.04em}
.plan-step.tone-teal .pn{color:var(--teal-300);border-color:rgba(20,184,166,.4);background:rgba(20,184,166,.1)}
.plan-link{align-self:center;color:var(--fg-faint);opacity:0;transition:opacity .4s}
.plan-link.in{opacity:1}

/* ===========================================================================
   SCENE 3: THE COVEN (society of agents)
   Site delta: the consensus verdict anchors to the stage bottom (it collided
   with Quill in the kit) and familiars sit higher so the pill has its lane.
   =========================================================================== */
.coven{position:absolute;inset:0;z-index:3}
.coven-core{position:absolute;left:50%;top:42%;transform:translate(-50%,-50%);z-index:4;text-align:center;width:230px}
.coven-core .ring{position:absolute;left:50%;top:50%;width:150px;height:150px;transform:translate(-50%,-50%);border-radius:9999px;border:1px solid rgba(124,58,237,.3)}
.coven-core .ring.r2{width:210px;height:210px;border-color:rgba(124,58,237,.16);border-style:dashed}
.coven-core .core-mark{position:relative;width:84px;height:84px;margin:0 auto;border-radius:9999px;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle,rgba(124,58,237,.3),rgba(124,58,237,.08));border:1px solid rgba(124,58,237,.5);box-shadow:0 0 50px rgba(124,58,237,.4)}
.coven-core .core-mark img{width:46px;height:46px}
.coven-core .core-q{margin-top:16px;font-size:clamp(18px,2.2vw,26px);font-weight:600;letter-spacing:-.02em;color:var(--fg);min-height:1.3em;text-wrap:balance}
.coven-core .core-q .q{opacity:0}
.coven-core .core-q .q.show{animation:rv-in .5s ease forwards}
/* agent familiars orbit the core */
.familiar{position:absolute;z-index:5;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0}
.familiar.in{animation:fam-in .6s cubic-bezier(.3,1.1,.5,1) forwards}
@keyframes fam-in{from{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
.familiar .av{position:relative;width:70px;height:70px;border-radius:18px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,rgba(22,20,34,.9),rgba(12,12,20,.92));border:1px solid var(--border-strong);transition:border-color .4s ease,box-shadow .4s ease}
.familiar .av svg{width:30px;height:30px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;color:var(--fg-muted);transition:color .4s ease}
.familiar .nm{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--fg-secondary);letter-spacing:.02em}
.familiar .role{font-family:var(--font-mono);font-size:10px;color:var(--fg-faint);letter-spacing:.06em;text-transform:uppercase;margin-top:-4px}
.familiar .tools{display:flex;gap:5px;margin-top:2px;opacity:0;transition:opacity .4s ease}
.familiar.active .tools{opacity:1}
.familiar .tools img{width:18px;height:18px;border-radius:5px;background:rgba(255,255,255,.05);padding:2px;object-fit:contain}
.familiar.active .av{border-color:var(--ac,rgba(124,58,237,.6));box-shadow:0 0 28px var(--acg,rgba(124,58,237,.3))}
.familiar.active .av svg{color:var(--ac,var(--purple-300))}
.familiar.tone-purple{--ac:rgba(124,58,237,.6);--acg:rgba(124,58,237,.3);--ic:var(--purple-300)}
.familiar.tone-teal{--ac:rgba(20,184,166,.6);--acg:rgba(20,184,166,.3);--ic:var(--teal-300)}
.familiar.tone-orange{--ac:rgba(249,115,22,.6);--acg:rgba(249,115,22,.3);--ic:var(--orange-300)}
.familiar.active .av svg{color:var(--ic)}
.coven-verdict{position:absolute;left:50%;bottom:3%;transform:translateX(-50%);z-index:6;display:inline-flex;align-items:center;gap:11px;
  padding:11px 18px;border-radius:9999px;border:1px solid rgba(20,184,166,.45);background:rgba(20,184,166,.1);
  font-family:var(--font-mono);font-size:13px;color:var(--teal-300);opacity:0;white-space:nowrap}
.coven-verdict.in{animation:coven-vin .6s ease forwards}
@keyframes coven-vin{from{opacity:0;transform:translateX(-50%) translateY(10px)}to{opacity:1;transform:translateX(-50%)}}
.coven-verdict .ck{width:18px;height:18px;border-radius:9999px;background:rgba(20,184,166,.2);display:flex;align-items:center;justify-content:center}
.coven-verdict .ck svg{width:11px;height:11px;fill:none;stroke:var(--teal-300);stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round}

/* ===========================================================================
   SCENE 4: THE PACT (humans on the loop)
   =========================================================================== */
.pact{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(1020px,88vw);z-index:3}
.pact-cols{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.pact-col .ph{font-family:var(--font-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-muted);text-align:center;margin-bottom:18px}
.pact-acted{display:flex;flex-direction:column;gap:14px}
.acted-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:clamp(12px,2vh,18px) 22px;border-radius:15px;
  border:1px solid var(--border);background:rgba(14,14,22,.6);opacity:0;transform:translateX(-16px)}
.acted-row.in{animation:slide-r .55s cubic-bezier(.3,1,.4,1) forwards}
@keyframes slide-r{to{opacity:1;transform:none}}
.acted-row .l{display:flex;align-items:center;gap:14px}
.acted-row .ck{width:26px;height:26px;border-radius:9999px;background:rgba(20,184,166,.14);border:1px solid rgba(20,184,166,.4);display:flex;align-items:center;justify-content:center;flex:none}
.acted-row .ck svg{width:13px;height:13px;fill:none;stroke:var(--teal-300);stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round}
.acted-row .nm{font-size:18px;font-weight:600;color:var(--fg)}
.acted-row .src{font-family:var(--font-mono);font-size:12px;color:var(--fg-faint);letter-spacing:.08em}
.pact-decide{position:relative;border:1px solid rgba(249,115,22,.45);border-radius:18px;padding:clamp(18px,3vh,26px) 28px;
  background:radial-gradient(120% 120% at 80% 0%,rgba(249,115,22,.12),rgba(14,12,18,.85));box-shadow:0 0 50px rgba(249,115,22,.14);opacity:0;transform:translateX(16px)}
.pact-decide.in{animation:slide-l .6s cubic-bezier(.3,1,.4,1) .3s forwards}
@keyframes slide-l{to{opacity:1;transform:none}}
.pact-decide .dt{font-size:clamp(22px,2.4vw,28px);font-weight:600;letter-spacing:-.02em;color:#fff}
.pact-decide .drow{display:flex;align-items:center;justify-content:space-between;margin-top:20px}
.pact-decide .approved{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:9999px;border:1px solid rgba(20,184,166,.5);
  font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--teal-300);opacity:0}
.pact-decide.in .approved{animation:rv-in .5s ease 1s forwards}
.pact-decide .who{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-mono);font-size:13px;color:var(--fg-muted)}
.pact-decide .who .av{width:26px;height:26px;border-radius:9999px;border:1px solid var(--border-strong);display:flex;align-items:center;justify-content:center}
.pact-decide .who .av svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:1.8}
.pact-foot{text-align:center;margin-top:clamp(16px,3vh,30px);font-family:var(--font-mono);font-size:14px;letter-spacing:.1em;color:var(--fg-muted)}
.pact-foot b{color:var(--teal-300)}

@media(max-width:900px){
  .scene-copy{left:24px;right:24px;bottom:4.5vh;max-width:none}
  .pact-cols{grid-template-columns:1fr;gap:18px}
  .t-dots{right:14px;top:26%}
  .omen{min-width:148px;max-width:200px;padding:9px 11px;gap:9px}.omen .tt{font-size:12.5px}
  .omen .ic{width:28px;height:28px}.omen .ic svg{width:15px;height:15px}
  .omen .mt{font-size:9.5px;margin-top:3px}
  .omen.alert{min-width:196px;max-width:232px;padding:11px 13px;border-radius:14px}
  .omen.alert .tt{font-size:13.5px}.omen.alert .ic{width:32px;height:32px}.omen.alert .ic svg{width:16px;height:16px}
  .omen.alert .badge{font-size:9.5px;margin-top:5px}
  .omen.agent .state-run,.omen.agent .state-done{font-size:9.5px;margin-top:4px}
  .scene-kicker{top:22px}
  .scene-kicker .k1{font-size:12px}.scene-kicker .k2{font-size:10.5px;margin-top:6px}
}
@media(max-width:640px){
  .t-control{display:none}
}
/* short viewports: compact the shot chrome so the stage keeps room to act */
@media(max-height:760px){
  .scene-kicker{top:16px}
  .scene-kicker .k1{font-size:11.5px}.scene-kicker .k2{font-size:10px;margin-top:5px}
  .scene-copy h1,.scene-copy .t-h1{font-size:clamp(26px,3vw,38px)}
  .scene-copy .sub{font-size:14px;margin-top:10px}
  .scene-copy .cta-row{margin-top:14px}
  .omen{min-width:150px;max-width:210px;padding:9px 11px;gap:9px}
  .omen .ic{width:28px;height:28px}.omen .ic svg{width:15px;height:15px}
  .omen .tt{font-size:12px}.omen .mt{font-size:9.5px;margin-top:3px}
  .omen.alert{min-width:218px;max-width:250px;padding:12px 14px}
  .omen.alert .tt{font-size:14px}.omen.alert .ic{width:34px;height:34px}.omen.alert .ic svg{width:17px;height:17px}
  .spell-text{font-size:clamp(19px,2.2vw,26px)}
  .coven-core .core-mark{width:64px;height:64px}.coven-core .core-mark img{width:36px;height:36px}
  .coven-core .ring{width:116px;height:116px}.coven-core .ring.r2{width:164px;height:164px}
  .coven-core .core-q{font-size:clamp(16px,1.9vw,21px)}
  .familiar .av{width:54px;height:54px}.familiar .av svg{width:24px;height:24px}
  .acted-row .nm{font-size:15.5px}
  .pact-decide .dt{font-size:clamp(19px,2vw,24px)}
  .pact-foot{font-size:12.5px}
}
@media(prefers-reduced-motion:reduce){
  .scene{transition:none}
  .rv,.plan-step,.familiar,.acted-row,.pact-decide,.coven-verdict,.coven-core .core-q .q,.spell-cast,.pact-decide .approved{animation:none!important;opacity:1!important;transform:none!important}
  .coven-verdict{transform:translateX(-50%)!important}
  .familiar{transform:translate(-50%,-50%)!important}
  .t-dust i,.omen.alert .badge .pin,.spell-caret,.spell-cast .dot,.omen.agent .spin{animation:none!important}
  .cn-core,.cn-halo{display:none!important}
}
