  :root{
    --bg:#eceff3; --surface:#ffffff; --surface-2:#f5f7fa;
    --ink:#171c24; --muted:#5c6675; --faint:#8b95a4;
    --line:#dde2e9; --line-strong:#c9d0da;
    --accent:#3667b0; --accent-ink:#ffffff;
    --good:#1f9d57; --good-ink:#0d7a3f;
    --bad:#e0313f; --bad-ink:#c01f2c;
    --warn:#c8791a;
    --shadow:0 1px 2px rgba(20,28,40,.06),0 8px 24px rgba(20,28,40,.06);
    /* Instrument scope — a fixed dark world in BOTH themes (an analysis scope
       is a dark instrument, like a video/audio meter; deliberate, not an omission). */
    --scope-bg:#0b0e12; --scope-panel:#0f141b; --scope-grid:#1b2330;
    --scope-ink:#e7ecf3; --scope-muted:#7c879a;
    --lum:#f4f7fb; --red:#ff3b4e; --thresh:#8a94a6; --play:#ffd23f;
  }
  @media (prefers-color-scheme:dark){
    :root{
      --bg:#0d1117; --surface:#151b23; --surface-2:#111820;
      --ink:#e8ecf2; --muted:#98a2b2; --faint:#6b7788;
      --line:#242c37; --line-strong:#333c49;
      --accent:#5a90e0; --accent-ink:#0b0f15;
      --good:#35b56e; --good-ink:#4cc684;
      --bad:#ff5561; --bad-ink:#ff7a83;
      --warn:#e0a04a;
      --shadow:0 1px 2px rgba(0,0,0,.4),0 10px 30px rgba(0,0,0,.35);
    }
  }
  :root[data-theme="light"]{
    --bg:#eceff3; --surface:#ffffff; --surface-2:#f5f7fa;
    --ink:#171c24; --muted:#5c6675; --faint:#8b95a4;
    --line:#dde2e9; --line-strong:#c9d0da;
    --accent:#3667b0; --accent-ink:#ffffff;
    --good:#1f9d57; --good-ink:#0d7a3f; --bad:#e0313f; --bad-ink:#c01f2c; --warn:#c8791a;
    --shadow:0 1px 2px rgba(20,28,40,.06),0 8px 24px rgba(20,28,40,.06);
  }
  :root[data-theme="dark"]{
    --bg:#0d1117; --surface:#151b23; --surface-2:#111820;
    --ink:#e8ecf2; --muted:#98a2b2; --faint:#6b7788;
    --line:#242c37; --line-strong:#333c49;
    --accent:#5a90e0; --accent-ink:#0b0f15;
    --good:#35b56e; --good-ink:#4cc684; --bad:#ff5561; --bad-ink:#ff7a83; --warn:#e0a04a;
    --shadow:0 1px 2px rgba(0,0,0,.4),0 10px 30px rgba(0,0,0,.35);
  }

  *{box-sizing:border-box}
  html{-webkit-text-size-adjust:100%}
  body{
    margin:0;background:var(--bg);color:var(--ink);
    font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
    font-size:15px;line-height:1.5;
    -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  }
  .mono{font-family:ui-monospace,"Cascadia Code","SF Mono","JetBrains Mono",Consolas,monospace;font-variant-numeric:tabular-nums}
  .wrap{max-width:1140px;margin:0 auto;padding:0 20px}

  /* App bar */
  .appbar{display:flex;align-items:center;gap:14px;padding:14px 20px;max-width:1140px;margin:0 auto}
  .brand{display:flex;align-items:baseline;gap:9px}
  .brand b{font-size:19px;font-weight:800;letter-spacing:-.02em}
  .brand .peat{color:var(--accent)}
  .tag{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);
    border:1px solid var(--line-strong);border-radius:999px;padding:3px 9px}
  .appbar .sp{flex:1}
  .pick{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}
  .pick .val{color:var(--ink);font-weight:600;background:var(--surface);border:1px solid var(--line-strong);
    border-radius:8px;padding:5px 10px;cursor:default}
  .tbtn{display:inline-flex;align-items:center;gap:7px;background:var(--surface);color:var(--ink);
    border:1px solid var(--line-strong);border-radius:8px;padding:6px 11px;font:inherit;font-size:13px;cursor:pointer}
  .tbtn:hover{border-color:var(--accent)}
  .tbtn:focus-visible,.iconbtn:focus-visible,.dl:focus-visible,.timeline:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

  /* Provenance strip */
  .prov{max-width:1140px;margin:2px auto 16px;padding:11px 16px;display:flex;gap:12px;align-items:flex-start;
    background:color-mix(in srgb,var(--accent) 9%,var(--surface));
    border:1px solid color-mix(in srgb,var(--accent) 26%,var(--line));border-radius:12px}
  .prov .dot{flex:none;width:9px;height:9px;border-radius:50%;background:var(--accent);margin-top:6px;
    box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 20%,transparent)}
  .prov p{margin:0;font-size:13.5px;color:var(--muted)}
  .prov b{color:var(--ink);font-weight:650}

  /* Instrument */
  .instrument{display:grid;grid-template-columns:236px 1fr;gap:16px;align-items:start}
  .card{background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow)}
  .rail{padding:14px;display:flex;flex-direction:column;gap:14px}
  .viewport{position:relative;aspect-ratio:16/9;border-radius:9px;overflow:hidden;background:#000;
    border:1px solid var(--line)}
  .viewport img{width:100%;height:100%;object-fit:cover;display:block;image-rendering:auto}
  .viewport .tc{position:absolute;left:7px;bottom:7px;font-size:12px;padding:2px 7px;border-radius:6px;
    background:rgba(6,9,13,.72);color:#7CFC9B;letter-spacing:.03em}
  .viewport .flashwarn{position:absolute;top:7px;right:7px;font-size:10px;font-weight:700;letter-spacing:.06em;
    padding:3px 7px;border-radius:6px;background:var(--bad);color:#fff;opacity:0;transition:opacity .1s}
  .viewport.hot .flashwarn{opacity:1}
  .facts h4,.legend h4{margin:0 0 8px;font-size:11px;letter-spacing:.09em;text-transform:uppercase;color:var(--faint);font-weight:700}
  .facts dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:5px 10px;font-size:13px}
  .facts dt{color:var(--muted)}
  .facts dd{margin:0;text-align:right;font-weight:600}
  .legend ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:7px;font-size:12.5px;color:var(--muted)}
  .legend li{display:flex;align-items:center;gap:9px}
  .swatch{flex:none;width:22px;height:12px;border-radius:3px;position:relative}
  .sw-lum{background:linear-gradient(180deg,#fff, #b9c3d4)}
  .sw-red{background:var(--red)}
  .sw-th{background:repeating-linear-gradient(90deg,var(--thresh) 0 4px,transparent 4px 7px);height:2px;align-self:center}
  .sw-pass{background:var(--good)}
  .sw-fail{background:var(--bad)}
  .sw-fail::after{content:"";position:absolute;inset:0;border-radius:3px;
    background:repeating-linear-gradient(45deg,rgba(0,0,0,.32) 0 2px,transparent 2px 5px)}

  /* Scope */
  .scope{padding:14px 16px 16px;display:flex;flex-direction:column;gap:10px;position:relative}
  .scope-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap}
  .scope-head h3{margin:0;font-size:14px;font-weight:700;letter-spacing:-.01em}
  .scope-head .yaxis{font-size:11.5px;color:var(--faint)}
  .readout{display:flex;gap:16px;font-size:12.5px}
  .readout .r{display:flex;align-items:center;gap:6px;color:var(--muted)}
  .readout .r b{color:var(--ink);min-width:2ch;text-align:right}
  .readout .k{width:9px;height:9px;border-radius:2px}
  .k-lum{background:linear-gradient(180deg,#fff,#c2ccdc)}
  .k-red{background:var(--red)}
  .verdict-now{font-weight:700;letter-spacing:.02em;padding:2px 9px;border-radius:999px;font-size:12px}
  .vn-pass{background:color-mix(in srgb,var(--good) 20%,transparent);color:var(--good-ink)}
  .vn-fail{background:color-mix(in srgb,var(--bad) 22%,transparent);color:var(--bad-ink)}

  .plot{position:relative;background:var(--scope-bg);border-radius:10px;padding:0;overflow:hidden;
    border:1px solid #000}
  canvas{display:block;width:100%}
  #chart{height:240px}
  .ribbon-label{display:flex;justify-content:space-between;align-items:center;margin:8px 2px 2px;
    font-size:11px;color:var(--scope-muted)}
  #ribbon{height:26px;border-radius:5px}
  .brackets{position:relative;height:16px;margin-top:3px}
  .brk{position:absolute;top:0;height:16px;font-size:10px;font-weight:700;letter-spacing:.03em;
    color:var(--bad-ink);display:flex;align-items:center}
  .brk::before{content:"";position:absolute;left:0;right:0;top:0;height:6px;
    border:1px solid var(--bad);border-bottom:none;border-radius:3px 3px 0 0}
  .brk span{margin-top:6px;padding:0 4px;white-space:nowrap}

  .tooltip{position:absolute;pointer-events:none;opacity:0;transform:translate(-50%,-8px);
    background:rgba(9,13,18,.94);color:#e7ecf3;border:1px solid #232c39;border-radius:8px;
    padding:7px 9px;font-size:11.5px;line-height:1.45;white-space:nowrap;z-index:6;transition:opacity .08s}
  .tooltip .tt-t{color:#8b95a4;margin-bottom:3px}
  .tooltip .tt-r{display:flex;justify-content:space-between;gap:14px}
  .tooltip .tt-r span:last-child{font-variant-numeric:tabular-nums;font-family:ui-monospace,monospace}

  /* Transport */
  .transport{display:flex;align-items:center;gap:13px;padding-top:2px}
  .iconbtn{flex:none;width:42px;height:42px;border-radius:50%;border:1px solid var(--line-strong);
    background:var(--surface-2);color:var(--ink);cursor:pointer;display:grid;place-items:center}
  .iconbtn:hover{border-color:var(--accent);color:var(--accent)}
  .iconbtn svg{width:17px;height:17px;fill:currentColor}
  .timeline{position:relative;flex:1;height:32px;cursor:pointer;border-radius:6px}
  .timeline .track{position:absolute;left:0;right:0;top:13px;height:6px;border-radius:3px;background:var(--line-strong)}
  .timeline .filled{position:absolute;left:0;top:13px;height:6px;border-radius:3px;background:var(--accent)}
  .timeline .head{position:absolute;top:7px;width:4px;height:18px;border-radius:2px;background:var(--play);
    box-shadow:0 0 0 3px color-mix(in srgb,var(--play) 34%,transparent);transform:translateX(-2px)}
  .tcbox{flex:none;text-align:right;font-size:13px}
  .tcbox .big{font-size:15px;font-weight:600}
  .tcbox .sub{font-size:11px;color:var(--muted)}

  /* Summary tiles */
  .summary{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:16px}
  .tile{padding:14px}
  .tile .lab{font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--faint);font-weight:700}
  .tile .big{font-size:26px;font-weight:800;letter-spacing:-.02em;margin-top:3px;line-height:1.1}
  .tile .sub{font-size:12px;color:var(--muted);margin-top:2px}
  .tile.verdict-fail .big{color:var(--bad-ink)}
  .pillrow{display:inline-flex;align-items:center;gap:7px}
  .status-dot{width:11px;height:11px;border-radius:50%;flex:none}

  /* Events */
  .events{margin-top:16px;padding:16px}
  .events h3,.downloads h3{margin:0 0 4px;font-size:15px;font-weight:750}
  .events .hint,.downloads .hint{margin:0 0 12px;font-size:13px;color:var(--muted)}
  .evt{display:grid;grid-template-columns:96px 1fr auto;gap:12px;align-items:center;padding:11px 12px;
    border:1px solid var(--line);border-radius:10px;margin-bottom:8px;background:var(--surface-2);cursor:pointer}
  .evt:hover{border-color:var(--accent)}
  .evt .metric{display:flex;align-items:center;gap:8px;font-weight:700;font-size:13px}
  .evt .metric .d{width:10px;height:10px;border-radius:3px}
  .evt .rng{font-size:13px;color:var(--muted)}
  .evt .rng b{color:var(--ink)}
  .badge{font-size:11px;font-weight:700;letter-spacing:.04em;padding:4px 9px;border-radius:999px;white-space:nowrap}
  .b-haz{background:color-mix(in srgb,var(--bad) 20%,transparent);color:var(--bad-ink)}
  .b-fp{background:color-mix(in srgb,var(--warn) 22%,transparent);color:var(--warn)}

  /* Downloads */
  .downloads{margin-top:16px;padding:16px}
  .dlrow{display:flex;gap:10px;flex-wrap:wrap}
  .dl{display:inline-flex;align-items:center;gap:9px;background:var(--surface-2);color:var(--ink);
    border:1px solid var(--line-strong);border-radius:10px;padding:10px 14px;font:inherit;cursor:pointer}
  .dl:hover{border-color:var(--accent);color:var(--accent)}
  .dl svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.7}
  .dl .ext{font-size:11px;color:var(--faint);font-weight:700}

  footer{max-width:1140px;margin:26px auto 40px;padding:18px 20px 0;border-top:1px solid var(--line);color:var(--muted);font-size:13px}
  footer h4{margin:0 0 8px;color:var(--ink);font-size:13px;letter-spacing:.04em;text-transform:uppercase}
  footer ul{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:5px}
  footer b{color:var(--ink);font-weight:650}

  @media (max-width:820px){
    .instrument{grid-template-columns:1fr}
    .summary{grid-template-columns:repeat(2,1fr)}
    .rail{flex-direction:row;flex-wrap:wrap}
    .rail>*{flex:1;min-width:150px}
  }
  @media (prefers-reduced-motion:reduce){*{transition:none!important}}

/* ---- Live controls (video picker, standard select, engine status) ---- */
.appbar .pick select.val{font:inherit;font-size:13px;font-weight:600;color:var(--ink);
  background:var(--surface);border:1px solid var(--line-strong);border-radius:8px;padding:5px 8px;cursor:pointer}
.appbar .pick select.val:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:2px 0 14px}
.btn{display:inline-flex;align-items:center;gap:8px;font:inherit;font-size:13.5px;font-weight:600;
  border-radius:9px;padding:8px 13px;cursor:pointer;border:1px solid var(--line-strong);
  background:var(--surface);color:var(--ink)}
.btn:hover{border-color:var(--accent)}
.btn svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round}
.btn.primary{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.btn.primary:hover{filter:brightness(1.06)}
.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.btn[aria-disabled="true"]{opacity:.55;pointer-events:none}
.engchip{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:var(--muted);
  border:1px solid var(--line);border-radius:999px;padding:5px 11px}
.engdot{width:8px;height:8px;border-radius:50%;background:var(--faint);flex:none}
.engchip.ok .engdot{background:var(--good)} .engchip.ok{color:var(--good-ink)}
.engchip.warn .engdot{background:var(--warn)} .engchip.warn{color:var(--warn)}
.engchip.err .engdot{background:var(--bad)} .engchip.err{color:var(--bad-ink)}
.engchip.loading .engdot{background:var(--accent);animation:pulse 1s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.35}50%{opacity:1}}
.progress{font-size:12.5px;color:var(--muted)}
@media (prefers-reduced-motion:reduce){.engchip.loading .engdot{animation:none}}

/* ---- Empty state (before first analysis) ---- */
.hidden{display:none!important}
.empty{max-width:600px;margin:26px auto;padding:40px 32px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}
.empty-icon{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;
  background:color-mix(in srgb,var(--accent) 12%,var(--surface));border:1px solid color-mix(in srgb,var(--accent) 26%,var(--line))}
.empty-icon svg{width:30px;height:30px;fill:var(--accent)}
.empty h2{margin:2px 0 0;font-size:22px;font-weight:800;letter-spacing:-.02em;text-wrap:balance}
.empty p{margin:0;max-width:46ch;color:var(--muted);font-size:14.5px;line-height:1.55}
.empty .btn.big{font-size:15px;padding:11px 20px;margin-top:6px}
.empty-note{font-size:11.5px!important;color:var(--faint)!important;letter-spacing:.02em}

/* ---- Decoder select in the controls row ---- */
.controls .lbl{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:var(--muted)}
.controls select{font:inherit;font-size:13px;font-weight:600;color:var(--ink);background:var(--surface);
  border:1px solid var(--line-strong);border-radius:8px;padding:6px 9px;cursor:pointer}
.controls select:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.controls select:disabled{opacity:.55;cursor:default}
