/* ==========================================================================
   MEDIALIVE.CALL — public Regia console (demo.html)  ·  v2
   Skinned on the real MediaLive.Call control surface:
   cyan #20D7F2 on layered blacks, LED readouts, glowing faders, dot panels.
   ========================================================================== */

:root{
  --cy:#20D7F2; --cy-dim:rgba(32,215,242,.16); --cy-glow:rgba(32,215,242,.55);
  --rd:#F04B55; --rd-glow:rgba(240,75,85,.5);
  --yl:#F5C518;
  --k0:#020303; --k1:#050607; --k2:#07101B; --k3:#0B141C; --k4:#111820;
  --bd:#1B2833; --bd-soft:#142028;
  --tx:#F4FDFF; --tx2:#A1AFBA; --tx3:#8F9DA7;
  --mono2:var(--mono);
}
html{background:var(--k1)}
body.call{background:
  radial-gradient(120% 90% at 50% -20%, #0A1822 0%, transparent 55%),
  var(--k1);
  color:var(--tx); min-height:100svh}

/* ---------------- app bar ---------------- */
.cbar{position:sticky;top:0;z-index:60;display:flex;align-items:center;gap:18px;
  padding:0 20px;height:54px;background:rgba(4,7,9,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--bd-soft)}
.cbar .sysdot{width:9px;height:9px;border-radius:50%;background:var(--tx3);flex:none;margin-left:auto;
  box-shadow:0 0 0 3px rgba(255,255,255,.04);transition:all .3s}
body.on .cbar .sysdot{background:var(--cy);box-shadow:0 0 10px var(--cy-glow)}
.cbar .cwordmark{font-family:Roboto,Arial,sans-serif;font-size:19px;letter-spacing:0;text-decoration:none;
  display:inline-flex;align-items:baseline;white-space:nowrap}
.cbar .cwordmark .wm-media{font-weight:700;color:var(--tx)}
.cbar .cwordmark .wm-studio{font-weight:400;color:var(--cy)}
.cbar .ctabs{margin:0 auto;display:flex;gap:26px;font-family:var(--mono2);font-size:11px;
  letter-spacing:.18em;text-transform:uppercase}
.cbar .ctabs a{color:var(--tx3);text-decoration:none;padding:18px 2px 15px;border-bottom:2px solid transparent}
.cbar .ctabs a.act{color:var(--cy);border-color:var(--cy)}
.cbar .exit{font-family:var(--mono2);font-size:10px;letter-spacing:.14em;color:var(--tx2);
  text-decoration:none;text-transform:uppercase;border:1px solid var(--bd);border-radius:4px;
  padding:7px 12px;transition:all .2s}
.cbar .exit:hover{color:var(--tx);border-color:var(--tx3)}

/* ---------------- LED strip ---------------- */
.ledbar{position:sticky;top:54px;z-index:55;display:flex;align-items:center;gap:26px;
  padding:10px 20px;background:linear-gradient(180deg,#03090C,#04070A);
  border-bottom:1px solid var(--bd-soft)}
.led{font-family:var(--mono2);font-weight:700;font-style:italic;letter-spacing:.1em;
  color:var(--cy);text-shadow:0 0 9px var(--cy-glow),0 0 28px rgba(32,215,242,.25);
  background:#020809;border:1px solid #0E2A30;border-radius:5px;padding:5px 12px;
  font-size:21px;line-height:1;transform:skewX(-4deg)}
.led.sm{font-size:13px;padding:5px 10px}
.led.red{color:var(--rd);text-shadow:0 0 9px var(--rd-glow);border-color:#3A1418}
.ledlab{font-family:var(--mono2);font-size:8.5px;letter-spacing:.24em;color:var(--tx3);
  text-transform:uppercase;display:block;margin-bottom:4px}
.ledgrp{display:flex;flex-direction:column}
.telem{display:flex;gap:18px;margin-left:auto;align-items:center}
.telem .ledgrp{min-width:74px}
.pwr{display:flex;gap:8px;margin-left:8px}
.pwr button{font-family:var(--mono2);font-weight:700;font-size:11px;letter-spacing:.18em;
  padding:9px 18px;border-radius:5px;border:1px solid var(--bd);background:#0B1117;
  color:var(--tx2);cursor:pointer;transition:all .18s}
.pwr #pwrOn.act{background:var(--rd);border-color:var(--rd);color:#fff;
  box-shadow:0 0 16px var(--rd-glow),0 0 46px rgba(240,75,85,.25)}
.pwr #pwrOff.act{background:#1A222B;color:var(--tx)}

/* ---------------- grid ---------------- */
.deck{display:grid;grid-template-columns:308px minmax(0,1fr) 308px;gap:14px;
  padding:14px 20px 30px;align-items:start}
.col{display:flex;flex-direction:column;gap:14px;min-width:0}

/* ---------------- panel ---------------- */
.call header{position:static;height:auto;background:none;backdrop-filter:none;border:0;z-index:auto}
.call section.cp{padding:0}
.cp{background:linear-gradient(180deg,var(--k3),var(--k2));border:1px solid var(--bd-soft);
  border-radius:10px;overflow:hidden}
.cp.select-open{overflow:visible;position:relative;z-index:230}
.cp>header{display:flex;align-items:center;gap:9px;padding:10px 13px;cursor:pointer;
  user-select:none;background:rgba(255,255,255,.018);border-bottom:1px solid var(--bd-soft)}
.cp>header .pdot{width:7px;height:7px;border-radius:50%;background:var(--cy);
  box-shadow:0 0 8px var(--cy-glow);flex:none}
.cp>header h3{font-family:var(--mono2);font-size:10.5px;font-weight:700;letter-spacing:.22em;
  text-transform:uppercase;color:var(--tx)}
.cp>header .chev{margin-left:auto;color:var(--cy);transition:transform .25s;flex:none;display:flex}
.cp.closed>header{border-bottom-color:transparent}
.cp.closed>header .chev{transform:rotate(-90deg)}
.cp .pbody{padding:13px}
.cp.closed .pbody{display:none}

/* ---------------- buttons / pills ---------------- */
.kb{font-family:var(--mono2);font-size:10px;font-weight:500;letter-spacing:.14em;
  text-transform:uppercase;color:var(--tx2);background:#0C141B;border:1px solid var(--bd);
  border-radius:5px;padding:8px 11px;cursor:pointer;transition:all .14s;
  display:inline-flex;align-items:center;gap:7px;position:relative}
.kb:hover{color:var(--tx);border-color:#2A3B47}
.kb.act{color:#04161A;background:var(--cy);border-color:var(--cy);font-weight:700;
  box-shadow:0 0 14px var(--cy-glow),0 0 40px rgba(32,215,242,.18)}
.kb.red.act{background:var(--rd);border-color:var(--rd);color:#fff;
  box-shadow:0 0 14px var(--rd-glow)}
.kb.big{padding:13px 0;justify-content:center;font-size:12px;font-weight:700;flex:1}
.kb:disabled{opacity:.35;cursor:not-allowed}
.krow{display:flex;gap:7px;flex-wrap:wrap;align-items:center}
.krow+.krow{margin-top:9px}
.klab{font-family:var(--mono2);font-size:8.5px;letter-spacing:.22em;color:var(--tx3);
  text-transform:uppercase;width:100%;margin:2px 0 -2px}
.kin{font-family:var(--mono2);font-size:11.5px;color:var(--tx);background:#070D12;
  border:1px solid var(--bd);border-radius:5px;padding:8px 10px;flex:1;min-width:0}
.kin:focus{outline:none;border-color:var(--cy);box-shadow:0 0 0 2px var(--cy-dim)}
.ksel{appearance:none;-webkit-appearance:none;font-family:var(--mono2);font-size:10.5px;
  letter-spacing:.1em;color:var(--tx);background:#0C141B url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="10" height="6" viewBox="0 0 10 6"><path d="M1 1l4 4 4-4" stroke="%2320D7F2" stroke-width="1.6" fill="none"/></svg>') no-repeat right 10px center;
  border:1px solid var(--bd);border-radius:5px;padding:8px 28px 8px 10px;cursor:pointer}
.ksel:focus{outline:none;border-color:var(--cy)}
.native-select-hidden{position:absolute!important;opacity:0!important;pointer-events:none!important;width:1px!important;height:1px!important}
.custom-select{position:relative;min-width:0;flex:1}
.custom-select-button{width:100%;min-height:34px;display:flex;align-items:center;justify-content:space-between;gap:12px;
  border:1px solid var(--bd);border-radius:5px;background:#0C141B;color:var(--tx);padding:8px 10px;
  font-family:var(--mono2);font-size:10.5px;letter-spacing:.1em;text-align:left;cursor:pointer}
.custom-select-value{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.custom-select-chevron{width:10px;height:10px;border-right:2px solid var(--cy);border-bottom:2px solid var(--cy);
  transform:rotate(45deg) translateY(-2px);flex:none}
.custom-select.is-open .custom-select-button{border-color:var(--cy);box-shadow:0 0 0 2px var(--cy-dim)}
.custom-select.is-placeholder .custom-select-button{color:var(--tx2)}
.custom-select-list{position:absolute;z-index:220;left:0;right:0;top:calc(100% + 6px);display:none;overflow:hidden;
  border:1px solid rgba(32,215,242,.38);border-radius:10px;background:rgba(8,16,23,.96);
  box-shadow:0 18px 46px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.035),0 0 30px rgba(32,215,242,.12);
  padding:5px;backdrop-filter:blur(14px)}
.custom-select.is-open .custom-select-list{display:block}
.custom-select-option{width:100%;border:0;border-radius:6px;background:transparent;color:#C8D4DE;
  padding:8px 10px 8px 25px;font-family:var(--mono2);font-size:10.5px;letter-spacing:.06em;text-align:left;
  cursor:pointer;position:relative}
.custom-select-option:hover,.custom-select-option.is-selected{background:var(--cy);color:#04161A;font-weight:700}
.custom-select-option.is-selected::before{content:"✓";position:absolute;left:8px;top:50%;transform:translateY(-50%)}
.ktog{position:relative;width:40px;height:21px;border-radius:999px;background:#16202A;
  border:1px solid var(--bd);cursor:pointer;transition:all .2s;flex:none}
.ktog::after{content:"";position:absolute;top:2px;left:2px;width:15px;height:15px;border-radius:50%;
  background:var(--tx3);transition:all .2s}
.ktog.on{background:var(--cy);border-color:var(--cy);box-shadow:0 0 12px var(--cy-glow)}
.ktog.on::after{left:21px;background:#03242B}

/* horizontal slider */
.kslide{-webkit-appearance:none;appearance:none;flex:1;height:3px;border-radius:2px;cursor:pointer;
  background:linear-gradient(90deg,var(--cy) var(--fill,50%),#1A2630 var(--fill,50%))}
.kslide::-webkit-slider-thumb{-webkit-appearance:none;width:15px;height:15px;border-radius:50%;
  background:var(--cy);box-shadow:0 0 10px var(--cy-glow);cursor:grab;border:2px solid #062A30}
.kval{font-family:var(--mono2);font-size:9.5px;color:var(--cy);width:46px;text-align:right;flex:none}

/* ---------------- source slots ---------------- */
.slots{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.slot{position:relative;border:1px solid var(--bd);border-radius:7px;background:#0A1118;
  cursor:pointer;overflow:hidden;transition:border-color .15s, box-shadow .15s;text-align:left;padding:0}
.slot .thumb{aspect-ratio:16/9;background:#06090D center/cover no-repeat;display:flex;
  align-items:center;justify-content:center;color:var(--tx3)}
.slot .thumb svg{width:26px;height:26px;opacity:.7}
.slot .sname{display:flex;align-items:center;gap:6px;font-family:var(--mono2);font-size:9px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--tx2);padding:7px 8px;background:#080E13}
.slot .sname .ydot{width:6px;height:6px;border-radius:50%;background:var(--yl);flex:none;opacity:.85}
.slot .pills{position:absolute;top:6px;right:6px;display:flex;gap:4px}
.slot .pill{font-family:var(--mono2);font-size:7.5px;font-weight:700;letter-spacing:.14em;
  padding:3px 6px;border-radius:3px;background:rgba(5,10,14,.8);border:1px solid var(--bd);
  color:var(--tx3);backdrop-filter:blur(3px)}
.slot.is-pv{border-color:var(--cy);box-shadow:0 0 0 1px var(--cy),0 0 18px var(--cy-dim)}
.slot.is-pv .pill.pv{color:#04161A;background:var(--cy);border-color:var(--cy)}
.slot.is-pgm{border-color:var(--rd);box-shadow:0 0 0 1px var(--rd),0 0 18px rgba(240,75,85,.2)}
.slot.is-pgm .pill.pgm{color:#fff;background:var(--rd);border-color:var(--rd)}
.slot .live{position:absolute;top:6px;left:6px;font-family:var(--mono2);font-size:7.5px;
  font-weight:700;letter-spacing:.16em;color:var(--rd);display:flex;gap:4px;align-items:center}
.slot .live i{width:5px;height:5px;border-radius:50%;background:var(--rd);animation:blink 1.1s steps(2) infinite}
.source-panel{height:clamp(420px,calc((100vw - 699px) * .5625),540px)}
.source-panel.closed{height:auto!important}
.source-panel .pbody{height:calc(100% - 38px);display:flex;flex-direction:column;min-height:0}
.source-panel .slots{flex:1;min-height:0;overflow-y:auto;padding-right:4px;align-content:start}
.source-panel .slot{min-height:94px}
.slot .thumb.live-tv-thumb{background:
  radial-gradient(circle at 30% 25%,rgba(32,215,242,.28),transparent 38%),
  linear-gradient(135deg,#06121C,#0B141C 58%,#110A12);
  color:var(--tx);font-family:var(--display);font-weight:800;font-size:14px;letter-spacing:.04em}
.slot.live-channel-slot .sname{font-size:8.2px}
.live-source-status{font-family:var(--mono2);font-size:8.5px;letter-spacing:.14em;
  color:var(--tx3);text-transform:uppercase;white-space:nowrap}
.source-panel>header .live-source-status{margin-left:4px}
.live-source-status.ready{color:var(--cy)}
.live-source-status.error{color:var(--rd)}
@keyframes blink{50%{opacity:.25}}

.voice-panel .pbody{display:flex;align-items:flex-start;gap:12px}
.voice-panel .ktog{margin-top:2px}
.voice-copy{min-width:0}
.voice-copy span{display:block;font-family:var(--mono2);font-size:9px;letter-spacing:.14em;color:var(--tx2);
  text-transform:uppercase;margin-bottom:6px}
.voice-copy p{margin:0;font-family:var(--mono2);font-size:9.5px;letter-spacing:.1em;color:var(--tx3);line-height:1.6}

.clip-control-row{display:flex;flex-direction:column;align-items:stretch;gap:11px;margin-top:11px}
.clip-timers{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-items:flex-end;gap:8px;width:100%;min-width:0}
.clip-timers .ledgrp{min-width:0}
.clip-timers .ledlab{font-size:7.5px;letter-spacing:.12em}
.clip-timers .led.sm{font-size:12px;padding:5px 8px;width:100%;text-align:center}
.clip-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));align-items:flex-end;gap:6px;width:100%}
.clip-actions .kb{padding:8px 8px;min-width:0;justify-content:center}
.clip-actions #clipPlay{min-width:0}

/* ---------------- PROGRAM stage ---------------- */
.stagewrap{position:relative}
.stage{--r:8px;--acg:#20D7F2;--acg-ink:#04161A;
  position:relative;border-radius:var(--r);background:#000;overflow:hidden;
  border:1px solid var(--bd);aspect-ratio:16/9;
  box-shadow:0 20px 60px rgba(0,0,0,.55), inset 0 0 0 1px rgba(255,255,255,.03)}
#frame{position:absolute;inset:0;will-change:filter}
.bus{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;background:#000}
.bus.pgm{opacity:1;z-index:1}
.bus.pv{z-index:2}
/* DSK compositing of PV bus */
.stage[data-comp="pip"] .bus.pv{opacity:1;inset:auto 3.2% 13% auto;width:29%;height:29%;aspect-ratio:16/9;
  border:1px solid rgba(244,253,255,.35);border-radius:6px;box-shadow:0 12px 34px rgba(0,0,0,.6);z-index:3}
.stage[data-comp="split"] .bus.pgm,.stage[data-comp="split"] .bus.pv{
  top:0;bottom:0;width:50%;height:100%;aspect-ratio:auto;border-radius:0;object-fit:cover}
.stage[data-comp="split"] .bus.pgm{left:0;right:auto}
.stage[data-comp="split"] .bus.pv{opacity:1;left:auto;right:0;z-index:3}
.bus,.stage .lt,.demo-ticker{transition:inset .4s cubic-bezier(.5,0,.2,1),width .4s cubic-bezier(.5,0,.2,1),
  height .4s cubic-bezier(.5,0,.2,1),top .4s cubic-bezier(.5,0,.2,1),
  right .4s cubic-bezier(.5,0,.2,1),bottom .4s cubic-bezier(.5,0,.2,1),left .4s cubic-bezier(.5,0,.2,1)}

/* aspect masks via backdrop blur fill */
.maskbar{position:absolute;top:0;bottom:0;width:0;z-index:4;pointer-events:none;
  backdrop-filter:blur(34px) saturate(1.3) brightness(.75);transition:width .35s ease}
#maskL{left:0;border-right:1px solid rgba(244,253,255,.18)}
#maskR{right:0;border-left:1px solid rgba(244,253,255,.18)}
.stage[data-mask="1-1"] .maskbar{width:21.9%}
.stage[data-mask="9-16"] .maskbar{width:34.2%}

/* safe grid */
#safegrid{position:absolute;inset:0;z-index:6;pointer-events:none;opacity:0;transition:opacity .2s}
.stage.grid-on #safegrid{opacity:1}

/* transition veils */
#veil{position:absolute;inset:0;z-index:7;pointer-events:none;background:#000;opacity:0}
#wipe{position:absolute;top:0;bottom:0;left:0;width:0;z-index:7;pointer-events:none;
  background:linear-gradient(90deg,rgba(2,3,3,.95) 92%,var(--cy));box-shadow:6px 0 30px var(--cy-glow)}
.stage.fx-glitch #frame{animation:glx .68s steps(2) both}
.stage.fx-glitch::before{content:"";position:absolute;inset:-5%;z-index:11;pointer-events:none;
  background:
    repeating-linear-gradient(0deg,rgba(244,253,255,.18) 0 1px,transparent 1px 5px),
    linear-gradient(90deg,rgba(240,75,85,.55),transparent 34%,rgba(32,215,242,.7));
  mix-blend-mode:screen;animation:glitchFlash .68s steps(2) both}
.stage.fx-glitch::after{content:"";position:absolute;inset:0;z-index:12;pointer-events:none;
  background:linear-gradient(180deg,transparent 18%,rgba(32,215,242,.42) 19%,transparent 21%,transparent 55%,rgba(240,75,85,.34) 56%,transparent 59%);
  animation:glitchBands .68s steps(2) both}
@keyframes glx{
  14%{filter:contrast(2.4) saturate(2.8) hue-rotate(24deg);transform:translateX(12px) skewX(5deg) scale(1.02)}
  28%{filter:contrast(.45) saturate(.1) invert(.18);transform:translateX(-14px) translateY(5px)}
  45%{filter:contrast(2.1) saturate(3.2) hue-rotate(-36deg);transform:translateX(9px) skewX(-6deg)}
  62%{filter:contrast(.7) saturate(.45);transform:translateX(-8px) translateY(-4px) scale(1.025)}
  80%{filter:none;transform:none}}
@keyframes glitchFlash{0%,100%{opacity:0}12%,38%,66%{opacity:1}24%,52%{opacity:.28}}
@keyframes glitchBands{0%,100%{opacity:0;transform:none}18%,48%,72%{opacity:1;transform:translateY(9px)}32%,60%{opacity:.55;transform:translateY(-11px)}}

/* on-screen chrome */
.mtop{position:absolute;z-index:8;top:0;left:0;right:0;display:flex;justify-content:space-between;
  align-items:center;padding:10px 13px;pointer-events:none;
  background:linear-gradient(180deg,rgba(2,4,6,.55),transparent)}
.mtop .tallychip{display:flex;gap:7px;align-items:center;font-family:var(--mono2);font-size:9.5px;
  font-weight:700;letter-spacing:.2em;color:var(--rd)}
.mtop .tallychip i{width:7px;height:7px;border-radius:50%;background:var(--rd);
  box-shadow:0 0 10px var(--rd-glow);animation:blink 1.2s steps(2) infinite}
.mtop .tc{font-family:var(--mono2);font-size:11px;letter-spacing:.14em;color:var(--tx);
  text-shadow:0 0 8px rgba(0,0,0,.8)}
.mtop .tc b{color:var(--cy)}

/* lower third (program graphics use --acg) */
.stage .lt{position:absolute;z-index:8;left:4.2%;bottom:13%;max-width:min(68%,760px);
  opacity:0;pointer-events:none;isolation:isolate;filter:drop-shadow(0 18px 34px rgba(0,0,0,.58))}
.stage .lt.on{opacity:1}
.lt .lt-tag{font-family:var(--mono2);font-size:8px;font-weight:700;letter-spacing:.24em;
  text-transform:uppercase;margin-bottom:0}
.lt .lt-title{font-family:var(--display);font-weight:620;font-size:clamp(18px,2vw,30px);
  letter-spacing:-.018em;line-height:1.04}
.lt .lt-sub{font-family:var(--mono2);font-size:9px;font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;margin-top:5px;line-height:1.35}
.lt--glass{display:grid;grid-template-columns:auto minmax(0,1fr);column-gap:14px;align-items:stretch;
  border-radius:9px;overflow:hidden;background:linear-gradient(90deg,rgba(4,9,13,.94),rgba(6,15,22,.72) 72%,rgba(6,15,22,.25));
  border:1px solid rgba(244,253,255,.16);backdrop-filter:blur(12px) saturate(1.2)}
.lt--glass::before{content:"LIVE";display:flex;align-items:center;padding:0 13px;background:var(--acg);
  color:var(--acg-ink);font-family:var(--mono2);font-size:9px;font-weight:800;letter-spacing:.18em}
.lt--glass::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:linear-gradient(90deg,var(--acg),transparent 78%);
  box-shadow:0 0 18px var(--acg)}
.lt--glass .lt-tag,.lt--glass .lt-title,.lt--glass .lt-sub{grid-column:2}
.lt--glass .lt-tag{padding:12px 18px 0 0;color:var(--acg)}
.lt--glass .lt-title{padding:13px 18px 0 0;color:var(--tx)}
.lt--glass .lt-sub{padding:0 18px 13px 0;color:#C9D4DA}
.lt--solid{display:grid;grid-template-columns:minmax(0,1fr) auto;min-width:min(620px,68vw);
  border-radius:8px;overflow:hidden;background:var(--acg);color:var(--acg-ink)}
.lt--solid::after{content:"ON AIR";grid-row:1/3;grid-column:2;display:flex;align-items:center;
  padding:0 16px;background:rgba(2,8,10,.92);color:var(--acg);font-family:var(--mono2);
  font-size:9px;font-weight:800;letter-spacing:.2em;writing-mode:vertical-rl;text-orientation:mixed}
.lt--solid .lt-tag,.lt--solid .lt-title,.lt--solid .lt-sub{grid-column:1}
.lt--solid .lt-tag{padding:12px 18px 0;color:rgba(2,10,12,.62)}
.lt--solid .lt-title{padding:2px 18px 11px;color:var(--acg-ink);font-weight:760}
.lt--solid .lt-sub{margin:0;padding:8px 18px;background:rgba(2,8,10,.86);color:#EAFBFF}
.lt--line{left:5%;bottom:15%;padding:0 0 11px 18px;background:linear-gradient(90deg,rgba(3,7,10,.82),rgba(3,7,10,.12));
  border-left:4px solid var(--acg)}
.lt--line::before{content:"";position:absolute;left:-4px;bottom:0;width:clamp(220px,42vw,520px);height:2px;
  background:linear-gradient(90deg,var(--acg),rgba(32,215,242,.2),transparent);box-shadow:0 0 18px var(--acg)}
.lt--line .lt-tag{color:var(--acg);margin-bottom:5px}
.lt--line .lt-title{color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.9)}
.lt--line .lt-sub{color:#D7E2E8}
@keyframes ltSlide{from{clip-path:inset(0 100% 0 0);transform:translateX(-18px);opacity:0;filter:blur(8px)}
  to{clip-path:inset(0 0 0 0);transform:none;opacity:1;filter:none}}
@keyframes ltRise{from{transform:translateY(24px) scale(.98);opacity:0;filter:blur(7px)}
  to{transform:none;opacity:1;filter:none}}
@keyframes ltFlip{0%{transform:perspective(900px) rotateX(62deg) translateY(18px);opacity:0;filter:blur(5px)}
  68%{transform:perspective(900px) rotateX(-7deg);opacity:1;filter:none}100%{transform:none;opacity:1;filter:none}}
@keyframes ltPush{0%{transform:translateY(46px) scaleY(.18);transform-origin:bottom;clip-path:inset(82% 0 0 0);opacity:0;filter:blur(5px)}
  42%{transform:translateY(4px) scaleY(1.02);clip-path:inset(0 0 0 0);opacity:1;filter:blur(0)}
  100%{transform:none;clip-path:inset(0 0 0 0);opacity:1;filter:none}}
@keyframes ltBeam{0%{clip-path:inset(0 100% 0 0);transform:translateX(-28px);opacity:0;filter:drop-shadow(-18px 0 0 var(--acg)) blur(4px)}
  32%{opacity:1;filter:drop-shadow(22px 0 16px var(--acg)) brightness(1.7)}
  68%{clip-path:inset(0 0 0 0);filter:drop-shadow(42px 0 12px var(--acg)) brightness(1.24)}
  100%{clip-path:inset(0 0 0 0);transform:none;opacity:1;filter:none}}
@keyframes ltBar{0%{clip-path:inset(45% 100% 45% 0);transform:translateX(-10px);opacity:0;filter:drop-shadow(0 0 10px var(--acg))}
  18%{opacity:1}
  46%{clip-path:inset(45% 0 45% 0);transform:translateX(0);opacity:1;filter:drop-shadow(0 0 14px var(--acg))}
  100%{clip-path:inset(0 0 0 0);transform:none;opacity:1;filter:none}}
@keyframes ltBarText{0%,52%{opacity:0;transform:translateY(5px);filter:blur(3px)}
  72%,100%{opacity:1;transform:none;filter:none}}
@keyframes ltSlideOut{from{clip-path:inset(0 0 0 0);transform:none;opacity:1;filter:none}
  to{clip-path:inset(0 100% 0 0);transform:translateX(-18px);opacity:0;filter:blur(8px)}}
@keyframes ltRiseOut{from{transform:none;opacity:1;filter:none}
  to{transform:translateY(24px) scale(.98);opacity:0;filter:blur(7px)}}
@keyframes ltFlipOut{0%{transform:none;opacity:1;filter:none}
  100%{transform:perspective(900px) rotateX(62deg) translateY(18px);opacity:0;filter:blur(5px)}}
@keyframes ltPushOut{0%{transform:none;clip-path:inset(0 0 0 0);opacity:1;filter:none}
  58%{transform:translateY(4px) scaleY(1.02);clip-path:inset(0 0 0 0);opacity:1;filter:blur(0)}
  100%{transform:translateY(46px) scaleY(.18);transform-origin:bottom;clip-path:inset(82% 0 0 0);opacity:0;filter:blur(5px)}}
@keyframes ltBeamOut{0%{clip-path:inset(0 0 0 0);transform:none;opacity:1;filter:none}
  42%{clip-path:inset(0 0 0 0);filter:drop-shadow(42px 0 12px var(--acg)) brightness(1.24)}
  100%{clip-path:inset(0 100% 0 0);transform:translateX(-28px);opacity:0;filter:drop-shadow(-18px 0 0 var(--acg)) blur(4px)}}
@keyframes ltBarOut{0%{clip-path:inset(0 0 0 0);transform:none;opacity:1;filter:none}
  54%{clip-path:inset(45% 0 45% 0);transform:translateX(0);opacity:1;filter:drop-shadow(0 0 14px var(--acg))}
  100%{clip-path:inset(45% 100% 45% 0);transform:translateX(-10px);opacity:0;filter:drop-shadow(0 0 10px var(--acg))}}
@keyframes ltBarTextOut{0%,28%{opacity:1;transform:none;filter:none}
  48%,100%{opacity:0;transform:translateY(5px);filter:blur(3px)}}
.lt.on.anim-slide{animation:ltSlide .62s cubic-bezier(.18,.92,.16,1) both}
.lt.on.anim-rise{animation:ltRise .55s cubic-bezier(.18,.92,.16,1) both}
.lt.on.anim-flip{animation:ltFlip .7s cubic-bezier(.18,.92,.16,1) both;transform-origin:bottom}
.lt.on.anim-push{animation:ltPush .68s cubic-bezier(.18,.92,.16,1) both}
.lt.on.anim-beam{animation:ltBeam .72s cubic-bezier(.18,.92,.16,1) both}
.lt.on.anim-bar{animation:ltBar .66s cubic-bezier(.18,.92,.16,1) both}
.lt.on.anim-bar .lt-tag,.lt.on.anim-bar .lt-title,.lt.on.anim-bar .lt-sub{animation:ltBarText .66s cubic-bezier(.18,.92,.16,1) both}
.stage .lt.out{opacity:1}
.lt.out.anim-slide{animation:ltSlideOut .48s cubic-bezier(.62,0,.44,1) both}
.lt.out.anim-rise{animation:ltRiseOut .44s cubic-bezier(.62,0,.44,1) both}
.lt.out.anim-flip{animation:ltFlipOut .5s cubic-bezier(.62,0,.44,1) both;transform-origin:bottom}
.lt.out.anim-push{animation:ltPushOut .5s cubic-bezier(.62,0,.44,1) both}
.lt.out.anim-beam{animation:ltBeamOut .52s cubic-bezier(.62,0,.44,1) both}
.lt.out.anim-bar{animation:ltBarOut .48s cubic-bezier(.62,0,.44,1) both}
.lt.out.anim-bar .lt-tag,.lt.out.anim-bar .lt-title,.lt.out.anim-bar .lt-sub{animation:ltBarTextOut .48s cubic-bezier(.62,0,.44,1) both}

/* ticker */
.demo-ticker{position:absolute;z-index:8;left:0;right:0;bottom:0;height:32px;
  background:rgba(4,7,10,.88);border-top:1px solid rgba(244,253,255,.12);
  display:flex;align-items:center;overflow:hidden;backdrop-filter:blur(5px);
  pointer-events:none;opacity:0;transform:translateY(100%);
  transition:transform .36s cubic-bezier(.18,.92,.16,1),opacity .2s ease}
.stage.ticker-on .demo-ticker{opacity:1;transform:translateY(0)}
.demo-ticker .dt-label{flex:none;height:100%;display:flex;align-items:center;padding:0 13px;
  background:var(--acg);color:var(--acg-ink);font-family:var(--mono2);font-size:9px;
  font-weight:700;letter-spacing:.22em;position:relative;z-index:2;box-shadow:8px 0 14px rgba(4,7,10,.72)}
.dt-track{position:relative;z-index:1;display:flex;flex:0 0 auto;width:max-content;min-width:0;
  --ticker-loop:0px;animation:tickv2 var(--tickdur,30s) linear infinite;will-change:transform}
@keyframes tickv2{from{transform:translate3d(0,0,0)}to{transform:translate3d(calc(var(--ticker-loop) * -1),0,0)}}
.dt-seq{display:flex;flex:0 0 auto}
.dt-item,.dt-sep{font-family:var(--mono2);font-size:10.5px;letter-spacing:.16em;
  text-transform:uppercase;white-space:nowrap}
.dt-item{color:#D7E2E8}
.dt-sep{display:inline-flex;align-items:center;justify-content:center;padding:0 28px;color:var(--acg);font-size:8px}
.ticker-control-row{display:flex;align-items:center;gap:7px;flex-wrap:nowrap}
.ticker-control-row .ktog,.ticker-control-row .tspd{flex:0 0 auto}
.ticker-control-row .tspd{width:auto;inline-size:auto;min-width:0;justify-content:center}
.ticker-control-row .kin{flex:1 1 auto;min-width:0}
.ticker-control-row .tick-commit{flex:0 0 34px;width:34px;min-width:34px;padding:0;font-size:15px;line-height:1}

/* SYSTEM OFF splash */
#sysoff{position:absolute;inset:0;z-index:12;display:flex;flex-direction:column;gap:10px;
  align-items:center;justify-content:center;background:
  linear-gradient(180deg,rgba(2,5,8,.78),rgba(2,5,8,.9)),
  url('../img/mc-banner.webp') center/cover;border-radius:var(--r)}
#sysoff h2{font-family:var(--display);font-weight:900;font-variation-settings:'wdth' 120;
  font-size:clamp(40px,7.4vw,108px);letter-spacing:.02em;color:var(--tx);
  text-shadow:0 6px 40px rgba(0,0,0,.8)}
#sysoff p{font-family:var(--mono2);font-size:10px;letter-spacing:.22em;color:var(--tx2);
  text-transform:uppercase;text-align:center;max-width:42em;line-height:2.1;padding:0 18px}
#sysoff .hint{color:var(--cy);text-shadow:0 0 12px var(--cy-glow)}
body.on #sysoff{display:none}

/* ---------------- transport ---------------- */
.tbar{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:stretch}
.tbtns{display:flex;gap:8px}
#tbarWrap{display:flex;align-items:center;gap:10px;background:#0A1118;border:1px solid var(--bd);
  border-radius:7px;padding:6px 12px}
#tbarWrap label{font-family:var(--mono2);font-size:8.5px;letter-spacing:.2em;color:var(--tx3)}
#tbar{flex:1}

/* ---------------- knobs ---------------- */
.knobs{display:grid;grid-template-columns:repeat(3,1fr);gap:12px 8px}
.knob{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:ns-resize;
  user-select:none;touch-action:none}
.knob .ring{position:relative;width:54px;height:54px;border-radius:50%;
  background:radial-gradient(60% 60% at 50% 36%,#1A2630,#0A1118 70%);
  border:1px solid var(--bd);box-shadow:inset 0 2px 6px rgba(0,0,0,.6),0 4px 10px rgba(0,0,0,.4)}
.knob .ring::before{content:"";position:absolute;inset:-4px;border-radius:50%;
  background:conic-gradient(from 225deg, var(--cy) calc(var(--p,.5)*270deg), #16222B 0deg);
  -webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 3.5px),#000 calc(100% - 3px));
  mask:radial-gradient(farthest-side,transparent calc(100% - 3.5px),#000 calc(100% - 3px));
  filter:drop-shadow(0 0 5px var(--cy-glow))}
.knob .ring::after{content:"";position:absolute;left:50%;top:7px;width:2.5px;height:13px;border-radius:2px;
  background:var(--tx);transform-origin:50% 20px;transform:translateX(-50%) rotate(calc(var(--p,.5)*270deg - 135deg));
  box-shadow:0 0 6px rgba(244,253,255,.6)}
.knob.touched .ring{border-color:var(--cy)}
.knob .kv{font-family:var(--mono2);font-size:9px;color:var(--cy);letter-spacing:.08em;min-height:11px}
.knob .kn{font-family:var(--mono2);font-size:8px;letter-spacing:.18em;color:var(--tx3);text-transform:uppercase}
.geometry-mask-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:7px}
.geometry-mask-row .kb{justify-content:center}
.geometry-flip-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}
.geometry-flip-row .kb{display:flex;justify-content:center;justify-self:stretch;width:100%;inline-size:100%;min-width:0}

/* ---------------- PTZ pad ---------------- */
.ptz{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:center}
.dpad{position:relative;width:104px;height:104px}
.dpad button{position:absolute;width:32px;height:32px;border-radius:8px;border:1px solid var(--bd);
  background:#0C141B;color:var(--cy);cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all .12s}
.dpad button:hover{border-color:var(--cy)}
.dpad button:active{background:var(--cy);color:#04161A;box-shadow:0 0 14px var(--cy-glow)}
.dpad .up{top:0;left:36px}.dpad .dn{bottom:0;left:36px}.dpad .lf{left:0;top:36px}.dpad .rt{right:0;top:36px}
.dpad .ct{top:36px;left:36px;border-radius:50%;font-family:var(--mono2);font-size:8px;letter-spacing:.08em}
.zrock{display:flex;flex-direction:column;gap:8px}
.zrock .kb{justify-content:center}

/* ---------------- mixer ---------------- */
.mixv2{display:grid;grid-template-columns:repeat(5,minmax(40px,1fr));gap:6px}
.stripv2{border:1px solid var(--bd-soft);border-radius:7px;background:#0A1016;
  padding:10px 5px;display:flex;flex-direction:column;align-items:center;gap:8px}
.stripv2.mst{background:#0D141C;border-color:var(--bd)}
.stripv2 .nm{font-family:var(--mono2);font-size:7.5px;font-weight:700;letter-spacing:.08em;
  color:var(--tx2);text-transform:uppercase;white-space:nowrap}
.stripv2.mst .nm{color:var(--cy)}
.mfd{display:flex;gap:6px;align-items:stretch;height:132px}
.meter{width:6px;display:flex;flex-direction:column-reverse;gap:2px;position:relative}
.meter i{flex:1;background:#15202A;border-radius:1px;transition:background .05s}
.meter i.lit{background:#27E3A1;box-shadow:0 0 5px rgba(39,227,161,.5)}
.meter i:nth-last-child(-n+2).lit{background:var(--rd);box-shadow:0 0 6px var(--rd-glow)}
.meter i:nth-last-child(-n+4):nth-last-child(n+3).lit{background:var(--yl);box-shadow:0 0 5px rgba(245,197,24,.45)}
.meter .pk{position:absolute;left:0;right:0;height:2px;background:var(--tx);border-radius:1px;
  bottom:0;opacity:0;transition:bottom .08s}
.vfad{--level:.65;position:relative;width:31px;height:132px;border:1px solid #16242E;
  border-radius:9px;background:linear-gradient(180deg,#071017,#0B1118);box-shadow:inset 0 0 0 1px rgba(255,255,255,.025)}
.vfad::before{content:"";position:absolute;left:12px;right:12px;top:9px;bottom:9px;
  border-radius:999px;background:
  linear-gradient(0deg,var(--cy) 0%,var(--cy) calc(var(--level) * 100%),#111C25 calc(var(--level) * 100%),#111C25 100%);
  box-shadow:inset 0 0 7px rgba(0,0,0,.7)}
.vfad::after{content:"";position:absolute;left:7px;right:7px;height:15px;border-radius:5px;
  bottom:calc(9px + (100% - 18px) * var(--level) - 7.5px);
  background:linear-gradient(180deg,#D7FBFF,var(--cy));border:1px solid #083B44;
  box-shadow:0 0 12px var(--cy-glow),0 3px 7px rgba(0,0,0,.65)}
.vfad input{position:absolute;left:50%;top:50%;z-index:2;-webkit-appearance:none;appearance:none;
  width:122px;height:31px;transform:translate(-50%,-50%) rotate(-90deg);opacity:0;cursor:ns-resize}
.vfad input::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:31px;cursor:ns-resize}
.vfad input::-moz-range-thumb{width:24px;height:31px;border:0;cursor:ns-resize}
.vfad:focus-within{border-color:var(--cy);box-shadow:0 0 0 2px var(--cy-dim),inset 0 0 0 1px rgba(255,255,255,.025)}
.stripv2 .mu{font-family:var(--mono2);font-size:8px;letter-spacing:.12em;padding:5px 9px;
  border-radius:4px;border:1px solid var(--bd);background:#0C141B;color:var(--tx3);cursor:pointer;transition:all .15s}
.stripv2 .mu.act{border-color:var(--rd);color:var(--rd);box-shadow:0 0 10px rgba(240,75,85,.25)}
.stripv2 .fxgo{background:var(--cy);color:#04161A;border-color:var(--cy);font-weight:700}
.stripv2 .fxgo:active{transform:scale(.93)}

/* PV multiview + switching row */
.duomon{display:grid;grid-template-columns:minmax(300px,1.08fr) minmax(240px,.72fr) minmax(300px,.92fr);
  gap:14px;overflow-x:auto;padding-bottom:2px;align-items:stretch}
.duomon.select-open{overflow:visible}
.duomon>.cp{min-width:0;display:flex;flex-direction:column;height:100%}
.duomon>.cp>.pbody{flex:1;display:flex;flex-direction:column}
.duomon .pvstage{flex:1;min-height:0}
.transition-panel .pbody,.audio-panel .pbody{justify-content:space-between}
.pvstage{position:relative;aspect-ratio:16/9;background:#000;border:1px solid var(--bd);
  border-radius:8px;overflow:hidden}
.pvstage video,.pvstage canvas{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pvstage canvas{display:none;background:#000}
.pvstage.mirror-on video{visibility:hidden}
.pvstage.mirror-on canvas{display:block}
.pvtag{position:absolute;top:7px;left:7px;z-index:2;font-family:var(--mono2);font-size:8.5px;
  font-weight:700;letter-spacing:.2em;color:#04161A;background:var(--cy);border-radius:3px;
  padding:3px 7px;box-shadow:0 0 12px var(--cy-glow)}
.pvempty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--mono2);font-size:9.5px;letter-spacing:.22em;color:var(--tx3)}
.pnote{margin-top:9px;font-family:var(--mono2);font-size:9.5px;letter-spacing:.1em;color:var(--tx3);line-height:1.55}

/* Graphics · CG */
.graphics-toolbar{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;gap:12px;align-items:start}
.cg-group{min-width:0}
.cg-group .klab{width:auto;margin:0 0 7px}
.cg-group .krow{gap:7px;margin:0}
.accent-group .krow{flex-wrap:nowrap}
.swt.act{box-shadow:0 0 0 2px rgba(255,255,255,.95),0 0 14px rgba(255,255,255,.26)}
.lt-edit-row{display:grid;grid-template-columns:auto minmax(180px,1fr) minmax(220px,1.2fr);gap:10px;align-items:center;margin-top:13px}
.lt-edit-row label{display:flex;align-items:center;gap:8px;min-width:0}
.lt-edit-row label>span{font-family:var(--mono2);font-size:8.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--tx3);flex:none}
.lt-edit-row .kin{height:30px;padding:6px 10px;font-size:10.5px;line-height:1.2}

/* shots */
.shots{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.shot{position:relative;font-family:var(--mono2);font-weight:700;font-size:11px;letter-spacing:.1em;
  border:1px solid var(--bd);border-radius:7px;background:#0C141B;color:var(--tx3);
  padding:14px 0 16px;cursor:pointer;transition:all .15s}
.shot small{position:absolute;left:0;right:0;bottom:4px;font-size:6.5px;letter-spacing:.18em;color:var(--tx3);font-weight:500}
.shot.saved{color:var(--cy);border-color:#1E3A44}
.shot.flash{background:var(--cy);color:#04161A;box-shadow:0 0 18px var(--cy-glow)}

/* toast */
.toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%,16px);z-index:200;
  background:#0B141C;border:1px solid var(--bd);border-left:3px solid var(--cy);
  color:var(--tx);font-family:var(--mono2);font-size:11px;letter-spacing:.06em;
  padding:11px 17px;border-radius:6px;opacity:0;pointer-events:none;transition:all .3s;max-width:84vw}
.toast.show{opacity:1;transform:translate(-50%,0)}

/* voice pill */
#voicePill{display:none;gap:7px;align-items:center;font-family:var(--mono2);font-size:9px;
  letter-spacing:.16em;color:var(--cy);text-transform:uppercase}
#voicePill.live{display:inline-flex}
#voicePill i{width:6px;height:6px;border-radius:50%;background:var(--cy);animation:blink 1s steps(2) infinite}

/* homepage footer */
body.call footer.footer{position:relative;z-index:3;display:flex;justify-content:space-between;gap:20px;
  padding:34px clamp(22px,5.5vw,88px);border-top:1px solid rgba(255,255,255,.065);
  color:#8794a6;font-family:var(--mono2);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  background:rgba(2,4,8,.72)}
body.call footer.footer a{color:#dce7f3}
body.call footer.footer a:hover{color:var(--cy)}

/* ---------------- index hero mini bar (kept from v1) ---------------- */
.src-mini{display:flex;gap:8px;align-items:center;margin-top:14px;flex-wrap:wrap}
.src-mini .cbtn,.cbtn{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--grey);background:#11151C;border:1px solid var(--line);border-radius:3px;
  padding:8px 11px;cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:8px}
.cbtn:hover{color:var(--white);border-color:rgba(255,255,255,.3)}
.cbtn.active{color:var(--ac-ink);background:var(--ac);border-color:var(--ac);font-weight:700}
.src-mini .open-console{margin-left:auto;font-family:var(--mono);font-size:10px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ac);display:inline-flex;gap:8px;align-items:center}
.src-mini .open-console:hover{text-decoration:underline}

/* ---------------- responsive ---------------- */
@media (max-width:1240px){
  .deck{grid-template-columns:280px minmax(0,1fr)}
  .source-panel{height:clamp(420px,calc((100vw - 349px) * .5625),540px)}
  .col.right{grid-column:1/-1;flex-direction:row;flex-wrap:wrap}
  .col.right .cp{flex:1 1 300px}
}
@media (max-width:880px){
  .deck{grid-template-columns:1fr;padding:12px 12px 26px}
  .source-panel{height:auto}
  .source-panel .pbody{height:auto}
  .source-panel .slots{max-height:420px}
  .col.left{order:2}.col.center{order:1}.col.right{order:3}
  .ledbar{flex-wrap:wrap;gap:12px;row-gap:8px}
  .telem{margin-left:0;width:100%;justify-content:flex-start;flex-wrap:wrap;gap:10px}
  .pwr{margin-left:0}
  .cbar .ctabs{display:none}
  .slots{grid-template-columns:repeat(2,1fr)}
  .knobs{grid-template-columns:repeat(3,1fr)}
  .mixv2{grid-template-columns:repeat(5,1fr)}
  .stage .lt{max-width:82%}
  body.call footer.footer{flex-direction:column}
}
@media (prefers-reduced-motion:reduce){
  .dt-track{animation:none}
  .demo-ticker{transition:none}
  .mtop .tallychip i,.slot .live i,#voicePill i{animation:none}
  .lt.on{animation:none !important}
}
