@font-face{font-family:'Inter';src:url('../fonts/Inter-VariableFont_opsz,wght.ttf') format('truetype');font-weight:100 900;font-style:normal;font-optical-sizing:auto;font-display:swap}
@font-face{font-family:'Roboto Mono';src:url('../fonts/roboto-mono-v31-latin-regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Roboto Mono';src:url('../fonts/roboto-mono-v31-latin-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Cascadia Code';src:local('Cascadia Code'),local('CascadiaCode');font-display:swap}

/* ============================================================================
   CLASS-PREFIX SCHEME (owner → purpose)
   ----------------------------------------------------------------------------
   Global / cross-page
     nav-      Side navigation (items, dividers, group labels, meta block)
     gh-      Global header (logo, breadcrumb, actions zone, admin, timer)
     hb-      Hamburger button bars (header left, <992px)
     btn-     Button variants (ghost / accent / danger / block / file / sm)
     ico-     Icon system — mask-image spans (.ico + .ico-<name> + .ico-<size>)
     toast-   Toast notifications (showToast in shell.js)
     adv-modal-      Advanced Settings modal (Processing SI/PSI)
     lcn-modal-      LCN duplicate / remove dialogs (Processing)
     confirm-modal-  Generic confirmDialog (shell.js)
     help-modal-     Help modal (shell.js)
     kv-      Key-value row/column primitives (label + value pairs)
     is-      State flags on otherwise-reusable elements (is-hidden, is-disabled)
     dup      Duplicate-IP / duplicate-name flag (inputs + table cells)

   Dashboard (index.html / dashboard.js)
     p-overview   Page root
     ov-          Dashboard cards, metric tiles, alarms, tables row
     ov-metric-*  Metric-card color tints (temps/tuners/streams/bitrate)
     ov-ci / ci-  CAM slot tiles + state (active / warn / empty)
     ov-alarm-*   Recent-alarms row
     tt-          Tuner-inputs table (incl. .tt-id, .tt-mono, .tt-pol, …)
     st-          Active-streams table

   Input RF (inputrf.html / axing.mip.js)
     p-tuner   Page root
     tu-       Tuner page layout (body, sidebar, main, form, panel, aside)
     tl-       Tuner-list rows in the 160px left sidebar
     pip       Signal pip in sidebar + tuner-type colors (.type-s2 etc.)
     field fl fr   Form-field layout primitives (shared with Network)
     satdb-    SAT-DB lookup (mode group, search, menu, option)
     sig-      Signal monitor bars/values (.tu-aside)
     scan-     Scan progress spinner + step label
     pr-       Services-list rows + badges in .tu-aside

   Processing (tsprocessing.html / processing.js)
     tsp-      Everything Processing (service table, split layout, MPTS drawer,
               filter bar, assign panel, detail row, PID table, LCN modals)
     mpts-bar- MPTS capacity-bar color states (built dynamically)
     svc-badge- Service type badges TV/Radio/Data/FTA/CA (cross-page helper)

   Output IP (outputip.html / outputip.js)
     tsp-      Reuses Processing primitives (drawers, bulk controls, buttons)
     (table classes are shared .tt/.st where possible)

   CAM (cam.html / cam.js)
     cam-      CAM slot grid, status, services table, CI menu, PID toggle

   Network (network.html)
     nw-       Sub-navigation sidebar (reused by CAM + System), content sections,
               forms, Ethernet/SNMP/SMARTPortal tables

   System / Device (device.html)
     dev-      Action cards, controls row, notices, reboot controls
     cfg-      Config export grid, filename input
     reboot-   Fullscreen reboot overlay

   Notes
   - Prefixes are not renamed. Existing owners own their prefix.
   - When adding a new prefix, prefer extending an owner group over inventing a
     new one. Two-letter prefixes (tu-, tl-, st-, tt-, nw-) are legacy compact;
     new groups should use a descriptive 3+ letter prefix.
   ============================================================================ */

*{margin:0;padding:0;box-sizing:border-box}
::selection{background:var(--accent);color:white}
/* === LIGHT THEME (default) === */
:root{
  color-scheme:light;
  --bg0:#f0f2f5;--bg:rgb(252, 252, 252);--bg2:#ffffff;--bg3:rgb(238, 241, 245);--bg4:#d0d7de;--bg5:#bbc1c9;
  --t1:#1b1b1b;--t2:#303030;--t3:#505050;--t4:#808080;
  --bd:#d0d7de;--bd2:#c8d0d9;--bd3:#bbc1c9;
  --accent:#239591;--accent-dark:hsl(178,62%,28%);--accent-light:hsl(178,58%,46%);--abg:rgba(35,149,145,.06);--abg2:rgba(35,149,145,.12);--abr:rgba(35,149,145,.30);
  --focus-clr:hsl(163,70%,38%);--focus-ring:0 0 0 3px hsla(163,70%,38%,.25);
  --ok:#1a9a6b;--okbg:rgba(26,154,107,.08);
  --warn:hsl(38,100%,46%);--wbg:rgba(220,148,0,.08);
  --err:hsl(349,80%,50%);--ebg:rgba(210,42,62,.08);
  --blue:#0969da;--bbg:rgba(9,105,218,.08);
  --purple:#8250df;--pbg:rgba(130,80,223,.08);
  --coral:#cf4e2e;--cbg:rgba(207,78,46,.08);
  --font:'Inter',system-ui,sans-serif;
  --mono:'Cascadia Code','JetBrains Mono','Fira Code',monospace;
  --r:6px;--r2:10px;
  --fs-sm:14px;--fs-xs:13px;--fs-lg:1.5rem;
  --sidebar-w:11rem;
  --header-h:56px;
  --padding-sidenav-sm: 0.375rem 1rem;
  --padding-sidenav: 0.5rem 1rem;
  /* Shared modal chrome — identical in light + dark (overlay sits above card bg) */
  --backdrop-modal:rgba(0,0,0,.5);
  --shadow-modal:0 16px 48px rgba(0,0,0,.3);
}
/* === DARK THEME (manual toggle or system preference) === */
[data-theme="dark"]{
  color-scheme:dark;
  --bg0:hsl(230,16%,4%);--bg:rgb(12, 12, 12);--bg2:hsl(230,12%,9%);--bg3:hsl(225,7%,14%);--bg4:hsl(225,6%,18%);--bg5:hsl(225,5%,22%);
  --t1:#c7c7c7;--t2:#999999;--t3:#6b6b6b;--t4:#424242;
  --bd:hsl(225,7%,14%);--bd2:hsl(225,5%,21%);--bd3:hsl(225,4%,26%);
  --abg:rgba(35,149,145,.08);--abg2:rgba(35,149,145,.14);--abr:rgba(35,149,145,.25);
  --focus-clr:hsl(163,81%,49%);--focus-ring:0 0 0 3px hsla(163,81%,49%,.30);
  --ok:#2dce89;--okbg:rgba(45,206,137,.1);
  --warn:#f0ad4e;--wbg:rgba(240,173,78,.1);
  --err:#e85d6f;--ebg:rgba(232,93,111,.1);
  --blue:#58a6ff;--bbg:rgba(88,166,255,.1);
  --purple:#bc8cff;--pbg:rgba(188,140,255,.1);
  --coral:#f0886e;--cbg:rgba(240,136,110,.1);
}
html{font-size:16px;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}
body{font-family:var(--font);background:var(--bg0);color:var(--t1);-webkit-font-smoothing:antialiased;line-height:1.5}
a,a:visited{color:inherit}
input,select,button,textarea{font-family:var(--font);font-size:1rem;color:var(--t1)}
input[type="number"],input[type="text"],input[type="password"],select{background:var(--bg3);border:1px solid var(--bd2);border-radius:var(--r);padding:.375rem .75rem;outline:none;transition:border-color .15s,box-shadow .15s;width:100%;line-height:1.375}
select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23848d97' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='4 6 8 10 12 6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:14px;padding-right:2.25rem}
select option{background:var(--bg2);color:var(--t1)}
input:focus-visible,select:focus-visible{border-color:var(--focus-clr);box-shadow:var(--focus-ring)}
/* !important: duplicate-flag mark must beat .tt-mono / .st-mono cell colors + base input border */
.dup{color:var(--warn) !important;border-color:var(--warn) !important}
.dup-icon{color:var(--warn);margin-left:4px;font-size:var(--fs-sm)}
input.invalid{border-color:var(--err);box-shadow:0 0 0 3px hsla(349,80%,50%,.2)}
input.invalid:focus-visible{border-color:var(--err);box-shadow:0 0 0 3px hsla(349,80%,50%,.3)}
input[readonly]{color:var(--t3);cursor:default}
input[readonly]:focus-visible{border-color:var(--bd2);box-shadow:none}
input[type="number"]::-webkit-inner-spin-button{opacity:0}
input[type="file"]{background:var(--bg3);border:1px solid var(--bd2);border-radius:var(--r);padding:.25rem .5rem .25rem .25rem;color:var(--t2);font-size:var(--fs-sm);width:100%;cursor:pointer}
input[type="file"]:focus-visible{border-color:var(--focus-clr);box-shadow:var(--focus-ring);outline:none}
input[type="file"]::file-selector-button{background:var(--bg4);border:1px solid var(--bd2);border-radius:var(--r);color:var(--t1);font-family:var(--font);font-size:var(--fs-sm);padding:.25rem .625rem;margin-right:.625rem;cursor:pointer;transition:background .12s,border-color .12s}
input[type="file"]::file-selector-button:hover{background:var(--bg5);border-color:var(--bd3)}
button{cursor:pointer;border:1px solid transparent;border-radius:var(--r);padding:.375rem .75rem;font-size:1rem;font-weight:500;transition:all .12s;line-height:1.375}
button:focus-visible{outline:none;box-shadow:var(--focus-ring)}
a:focus-visible{outline:none;border-radius:var(--r);box-shadow:var(--focus-ring)}
button:active{transform:scale(.97)}
input[type="radio"]{appearance:none;-webkit-appearance:none;width:1.25rem;height:1.25rem;background:var(--bg3);border:2px solid var(--bd2);border-radius:50%;cursor:pointer;flex-shrink:0;transition:background .12s,border-color .12s;vertical-align:middle;margin:0;position:relative}
input[type="radio"]:checked{border-color:var(--accent);background:var(--accent);box-shadow:inset 0 0 0 3px var(--bg2)}
input[type="radio"]:hover:not(:checked){border-color:var(--bd3)}
input[type="radio"]:focus-visible{outline:none;border-color:var(--focus-clr);box-shadow:var(--focus-ring)}
input[type="checkbox"]{appearance:none;-webkit-appearance:none;width:1.25rem;height:1.25rem;background:var(--bg3);border:1px solid var(--bd2);border-radius:4px;cursor:pointer;flex-shrink:0;transition:background .12s,border-color .12s;vertical-align:middle;margin:0;position:relative}
input[type="checkbox"]:checked{background:var(--accent);border-color:var(--accent);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='4,11 8,15 16,6' fill='none' stroke='%23fff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:1rem}
input[type="checkbox"]:hover:not(:checked){border-color:var(--bd3)}
input[type="checkbox"]:focus-visible{outline:none;border-color:var(--focus-clr);box-shadow:var(--focus-ring)}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:3px}

html,body{height:100%;height:100dvh;overflow:hidden}
.app{display:grid;grid-template-columns:minmax(0,1fr);grid-template-rows:var(--header-h) minmax(0,1fr);height:100dvh}

/* === HEADER ===
   Three-column grid: left auto (hamburger/logo/breadcrumb), middle 1fr (Discard/Apply/toggles
   right-aligned inside), right auto (admin/timer). The 1fr middle grows to push the action
   buttons against the right side of their zone — just left of .gh-right. */
.g-header{grid-column:1/-1;display:grid;grid-template-columns:auto 1fr auto;align-items:center;padding:0 24px 0 0;background:var(--bg);border-bottom:1px solid var(--bd);z-index:10;min-width:0}
.gh-left{justify-self:start;display:flex;align-items:center;height:100%;min-width:0;overflow:hidden}
.gh-logo{width:40px;height:100%;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:2px;padding:0;border-right:1px solid var(--bd);flex-shrink:0;transition:width .3s cubic-bezier(.4,0,.2,1),padding .3s cubic-bezier(.4,0,.2,1);overflow:hidden;box-sizing:border-box}
.gh-logo-link{display:flex;flex-direction:column;align-items:flex-start;text-decoration:none;color:inherit}
.gh-logo-img{height:24px;width:auto;flex-shrink:0;transition:opacity .3s ease,max-width .3s ease,max-height .3s ease;opacity:0;max-width:0;max-height:0;overflow:hidden}
.gh-logo-sub{font-size:var(--fs-xs);line-height:1;color:var(--t3);text-decoration:none;transition:opacity .3s ease,max-width .3s ease,max-height .3s ease,color .2s ease;white-space:nowrap;opacity:0;max-width:0;max-height:0;overflow:hidden}
.gh-logo-sub:hover{color:var(--accent)}
.gh-logo-icon{width:28px;height:28px;object-fit:contain;display:block;margin-right:1rem}
.gh-breadcrumb{display:none;align-items:center;gap:8px;padding:0 20px;font-size:1rem;color:var(--t3);min-width:0;overflow:hidden}
@media (min-width:992px){.gh-breadcrumb{display:flex}}
.gh-breadcrumb a{color:var(--t2);text-decoration:none;cursor:pointer;transition:color .12s;white-space:nowrap}
.gh-breadcrumb a:hover{color:var(--t1)}
.gh-breadcrumb .active{color:var(--t1);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gh-sep{color:var(--t4);font-size:1rem;flex-shrink:0}
.gh-device-name{color:var(--t2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gh-right{justify-self:end;display:none;align-items:center;gap:16px}
@media (min-width:1200px){.gh-right{display:flex}}
/* Sidebar admin + timer (mirrors part of .gh-right) — visible only <1200px */
.nav-meta-block{flex-shrink:0}
.nav-meta{display:flex;flex-direction:column;gap:8px;padding:8px 1rem}
@media (min-width:1200px){.nav-meta-block{display:none}}
/* Dashboard nav item picks up system state — warn/err tint the icon.
   Targets .ico (mask-image span) since icons were converted from inline <svg>. */
.nav-item[data-sys="warn"] .ico{color:var(--warn)}
.nav-item[data-sys="err"] .ico{color:var(--err);animation:pulse 2.5s ease-in-out infinite}
.gh-user{display:flex;align-items:center;gap:6px;font-size:var(--fs-sm);color:var(--t2);padding:4px 10px;background:var(--bg3);border-radius:var(--r);white-space:nowrap}
.gh-timer{font-family:var(--mono);font-size:var(--fs-sm);color:var(--t3);padding:4px 10px;background:var(--bg3);border-radius:var(--r);white-space:nowrap;min-width:4.5ch;text-align:center}
.gh-timer-warn{color:var(--warn)}
.gh-timer-err{color:var(--err);animation:pulse 1s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* === HAMBURGER (header button to open sidenav on mobile) === */
.gh-hamburger{margin:0 1rem;width:36px;height:36px;padding:0;background:transparent;border:1px solid var(--bd2);border-radius:var(--r);color:var(--t2);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .12s,background .12s,border-color .12s}
.gh-hamburger:hover{color:var(--t1);background:var(--bg4);border-color:var(--bd3)}
/* Animated hamburger bars → X when .sidebar-open */
.hb-box{position:relative;width:20px;height:20px;display:inline-block}
.hb-bar{position:absolute;left:0;right:0;height:2px;background:currentColor;border-radius:1px;transform-origin:center;transition:top .25s cubic-bezier(.4,0,.2,1),transform .25s cubic-bezier(.4,0,.2,1),opacity .18s ease}
.hb-bar:nth-child(1){top:2px}
.hb-bar:nth-child(2){top:9px}
.hb-bar:nth-child(3){top:16px}
.sidebar-open .hb-bar:nth-child(1){top:8px;transform:rotate(45deg)}
.sidebar-open .hb-bar:nth-child(2){opacity:0}
.sidebar-open .hb-bar:nth-child(3){top:8px;transform:rotate(-45deg)}

/* === SIDE NAV === */
/* Mobile-first: hidden off-canvas, slides in when .sidebar-open on <html>. Desktop: static grid column. */
.sidenav{position:fixed;left:0;top:var(--header-h);bottom:0;width:var(--sidebar-w);background:var(--bg);border-right:1px solid var(--bd);display:flex;flex-direction:column;padding:4px 0;overflow-y:auto;overflow-x:hidden;box-sizing:border-box;transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:50}
.sidebar-open .sidenav{transform:translateX(0)}
/* Backdrop behind the slid-in sidebar (mobile only) */
body::before{content:'';position:fixed;inset:var(--header-h) 0 0 0;background:rgba(0,0,0,.4);opacity:0;pointer-events:none;transition:opacity .3s cubic-bezier(.4,0,.2,1);z-index:40}
.sidebar-open body::before{opacity:1;pointer-events:auto}
/* Section labels: uppercase, structural — not body text */
.nav-group-label{font-size:var(--fs-xs);font-weight:500;color:var(--t4);text-transform:uppercase;letter-spacing:1px;padding:0.25rem 1rem 0.125rem;margin-top:2vh;user-select:none;flex-shrink:0}
.nav-label{overflow:hidden;white-space:nowrap}
.nav-item{display:flex;align-items:center;gap:10px;padding:var(--padding-sidenav-sm);font-size:1rem;color:var(--t2);cursor:pointer;transition:color .1s,background .1s;border-left:3px solid transparent;margin:1px 0;text-decoration:none;flex-shrink:0}
.nav-item:hover{background:var(--bg4);color:var(--t1)}
.nav-item.active{color:var(--accent);background:var(--abg);border-left-color:var(--accent)}
.nav-item .ico{width:18px;height:18px;flex-shrink:0}
.nav-spacer{flex:1;min-height:0}
.nav-divider{height:1px;background:var(--bd);margin:0.25rem 1rem;flex-shrink:0}
.nav-item.bottom{color:var(--t3)}

/* === PAGE === */
.page{grid-column:1/-1;grid-row:2;overflow:hidden;display:flex;flex-direction:column}

/* === OVERVIEW / DASHBOARD === */
.p-overview{padding:clamp(16px,1.5vw,32px);overflow-y:auto;height:100%;display:flex;flex-direction:column;gap:16px}
.ov-metrics{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:8px}
@media (min-width:501px){.ov-metrics{grid-template-columns:repeat(2,1fr)}}
@media (min-width:901px){.ov-metrics{grid-template-columns:repeat(4,1fr)}}
.ov-metric{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r2);padding:10px 14px;display:flex;flex-direction:column}
.ov-metric .ov-mode-row:first-of-type{margin-top:auto}
/* Uppercase metric label — decorative, short */
.ov-m-label{font-size:var(--fs-sm);color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.ov-m-val{font-size:var(--fs-lg);font-weight:500}
.ov-m-unit{font-size:1rem;color:var(--t3);font-weight:400}
.ov-m-sub{font-size:var(--fs-sm);color:var(--t3);margin-top:4px}
.ov-mode-row{display:flex;justify-content:space-between;align-items:center;gap:8px}
.ov-alarm-row{display:flex;align-items:baseline;gap:10px;padding:6px 0;border-bottom:1px solid var(--bd)}
.ov-alarm-row:last-child{border-bottom:none}
.ov-alarm-time{font-family:var(--mono);font-size:var(--fs-sm);color:var(--t3);flex-shrink:0}
.ov-alarm-msg{font-size:var(--fs-sm);color:var(--t1)}
.ov-alarm-level{font-size:var(--fs-sm);font-weight:500;flex-shrink:0;padding:1px 6px;border-radius:3px}
.ov-alarm-level.err{color:var(--err);background:var(--ebg)}
.ov-alarm-level.warn{color:var(--warn);background:var(--wbg)}
.ov-alarm-empty{font-size:var(--fs-sm);color:var(--t3);padding:6px 0}

/* Dashboard metric card color tints — named classes */
.ov-metric-temps{background:color-mix(in srgb,var(--coral) 6%,var(--bg2))}
.ov-metric-tuners{background:color-mix(in srgb,var(--blue) 6%,var(--bg2))}
.ov-metric-streams{background:color-mix(in srgb,var(--accent) 8%,var(--bg2))}
.ov-metric-bitrate{background:color-mix(in srgb,var(--ok) 6%,var(--bg2))}

/* Dashboard lower card accent borders */
#ov-alarms{border-left:3px solid var(--warn)}
#ov-alarms .ov-card-t::before{background:var(--warn)}
#ov-cam{border-left:3px solid var(--purple)}
#ov-cam .ov-card-t::before{background:var(--purple)}
.ov-tables-row>.ov-card:first-child{border-left:3px solid var(--blue)}
.ov-tables-row>.ov-card:first-child .ov-card-t::before{background:var(--blue)}
.ov-tables-row>.ov-card:last-child{border-left:3px solid var(--accent)}

.ov-tables-row{display:flex;flex-wrap:wrap;gap:16px;align-items:start}
.ov-tables-row>.ov-card{flex:0 0 100%;min-width:0}
.ov-card{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r2);padding:18px 20px}
.ov-card-t{font-size:1rem;font-weight:500;color:var(--t2);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.ov-card-t::before{content:'';width:3px;height:14px;border-radius:2px;background:var(--accent);flex-shrink:0}

/* Badge — 2-4 chars, color-coded, decorative */
.ov-t-type{font-size:var(--fs-sm);font-weight:500;padding:2px 6px;border-radius:3px}

/* Card title count pill */
.ov-ct-count{font-size:var(--fs-sm);font-weight:500;padding:2px 8px;background:var(--bg3);color:var(--t3);border-radius:10px;margin-left:4px}
/* Tuner overview table */
.tt{width:100%;border-collapse:collapse;font-size:var(--fs-sm);min-width:800px}
.tt thead th{padding:0.375rem 0.375rem;text-align:left;font-size:var(--fs-sm);font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--bd);white-space:nowrap}
.tt tbody td{padding:0.375rem 0.375rem;border-bottom:1px solid var(--bd);vertical-align:middle}
.tt tbody tr:last-child td{border-bottom:none}
.tt tbody tr:hover td{background:var(--bg4)}
.tt-standby{opacity:.35}
.tt-id{display:inline-flex;align-items:center;gap:7px;font-weight:500;color:var(--t1);text-decoration:underline;text-underline-offset:2px;white-space:nowrap}
.tt-id:hover{color:var(--accent)}
.tt-id.warn{color:var(--warn)}
.tt-id.err{color:var(--err)}
.tt-mono{font-family:var(--mono);color:var(--t1);white-space:nowrap}
.tt-mono.ok{color:var(--ok)}
.tt-mono.warn{color:var(--warn)}
.tt-mono.err{color:var(--err)}
.tt-pol{font-family:var(--mono);font-weight:500;color:var(--t1)}
.tt-lnb{white-space:nowrap;color:var(--t1)}
.tt-na{color:var(--t4);text-align:center;font-size:var(--fs-sm)}

/* Active streams table */
.st-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.st{width:100%;border-collapse:collapse;font-size:var(--fs-sm);min-width:600px}
.st thead th{padding:0.375rem 0.375rem;text-align:left;font-size:var(--fs-sm);font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--bd);white-space:nowrap}
.st tbody td{padding:0.375rem 0.375rem;border-bottom:1px solid var(--bd);vertical-align:middle}
.st tbody tr:last-child td{border-bottom:none}
.st tbody tr:hover td{background:var(--bg4)}
.st .st-name{font-weight:500;color:var(--t1)}
.st .st-mono{font-family:var(--mono);color:var(--t1);white-space:nowrap}
.st .st-br{font-family:var(--mono);color:var(--t1);white-space:nowrap}
.st .st-br small{color:var(--t3);font-size:var(--fs-sm)}

.ov-ci-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(72px,1fr));gap:.5rem}
.ov-ci{background:var(--bg3);border-radius:var(--r);padding:.375rem .5rem;display:flex;align-items:center;justify-content:center;text-decoration:none;color:inherit;transition:background .12s}
a.ov-ci:hover{filter:brightness(1.08)}
.ov-ci-id{font-size:var(--fs-sm);font-weight:500;color:var(--t2)}
.ov-ci.ci-active{background:var(--okbg)}
.ov-ci.ci-active .ov-ci-id{color:var(--ok)}
.ov-ci.ci-warn{background:var(--wbg)}
.ov-ci.ci-warn .ov-ci-id{color:var(--warn)}
.ov-ci.ci-empty{opacity:.4}

/* === INPUT RF PAGE === */
.p-tuner{display:flex;flex-direction:column;flex:1;min-height:0}
/* Action bar moved into header; `.tu-actionbar` is removed from the DOM at load time.
   `.gh-actions` occupies the middle 1fr track and aligns its buttons to the right edge. */
.gh-actions{justify-self:center;display:flex;align-items:center;gap:12px;min-width:0;max-width:100%}
#btn-apply,#btn-discard{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media (min-width:1200px){#btn-apply{padding-left:2rem;padding-right:2rem}}
.ab-next-hint{display:none;align-items:center;gap:6px;font-size:var(--fs-sm);font-weight:500;color:var(--accent);border:1px solid var(--abr);background:var(--abg);padding:4px 12px;border-radius:var(--r);text-decoration:none;white-space:nowrap;transition:background .12s,border-color .12s}
.ab-next-hint:hover{background:var(--abg2);border-color:var(--accent)}
/* Shown only after ≥3 Apply actions (class added by bumpApplyCount) and on wide viewports */
@media (min-width:1400px){.ab-next-hint.visible{display:inline-flex}}
.tu-aside-disabled #sig-services{opacity:.35}
.tu-aside-disabled #sig-monitor .sig-l{color:var(--t4)}
.btn-ghost{background:transparent;border:1px solid var(--bd2);color:var(--t2);padding:.375rem .75rem;font-size:1rem;border-radius:var(--r)}
.btn-ghost:hover{border-color:var(--t3);color:var(--t1)}
.btn-accent{background:var(--accent);color:#fff;padding:.375rem .75rem;font-size:1rem}
.btn-accent:hover{background:var(--accent-dark)}
.cd{width:8px;height:30px;border-radius:999px;background:var(--warn);display:none;flex-shrink:0}

.tu-body{display:grid;grid-template-columns:80px minmax(0,1fr);flex:1;min-height:0;overflow:hidden;position:relative}

/* Tuner sidebar */
.tu-sidebar{background:var(--bg);border-right:1px solid var(--bd);overflow-y:auto;padding:10px 0}
/* Uppercase section label */
.tu-sb-title{font-size:var(--fs-sm);font-weight:500;color:var(--t4);text-transform:uppercase;letter-spacing:.8px;padding:6px 16px 10px;display:none}
.tl-row{display:grid;grid-template-columns:30px minmax(0,1fr) 12px;align-items:center;gap:6px;padding:10px 14px;cursor:pointer;transition:background .1s}
.tl-row:hover{background:var(--bg4)}
.tl-row.active{background:var(--abg);border-right:3px solid var(--accent)}
.tl-row.standby{opacity:.35;cursor:pointer}
.tl-row.standby.active{opacity:.6;background:var(--bg4)}
.tl-id{font-weight:500;font-size:1rem}
.tl-info{min-width:0;display:none}
.tl-freq{font-family:var(--mono);font-size:var(--fs-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.pip{width:11px;height:11px;border-radius:50%;justify-self:center;flex-shrink:0;background:var(--t3)}
.pip-ok-pulse{background:var(--ok);animation:pulse 2.5s ease-in-out infinite}
.type-s2{background:var(--bbg);color:var(--blue)}.type-s2x{background:var(--pbg);color:var(--purple)}.type-t2{background:var(--cbg);color:var(--coral)}.type-c{background:rgba(139,148,158,.08);color:var(--t2)}

/* Tuner main form */
.tu-main{padding:clamp(16px,1.5vw,22px);overflow-y:auto;display:flex;flex-direction:column;gap:14px}
.tu-form{display:grid;grid-template-columns:1fr;gap:14px;flex:1;align-content:start}
@media (min-width:768px){.tu-form{grid-template-columns:1fr 1fr}}
.tu-panel{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r2);padding:clamp(16px,1.5vw,20px)}
.tu-enable{display:flex;flex-direction:row;align-items:center;gap:.5rem;color:var(--t1);cursor:pointer;margin-bottom:1rem}
.tu-panel-t{font-size:1rem;font-weight:500;color:var(--t2);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.tu-panel-t::before{content:'';width:3px;height:14px;border-radius:2px;background:var(--accent);flex-shrink:0}
.field{margin-bottom:14px}.field:last-child{margin-bottom:0}
/* Form field labels — secondary to the input value below */
.fl{display:block;font-size:var(--fs-sm);color:var(--t2);margin-bottom:6px;letter-spacing:.1px}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* SAT-DB lookup */
.satdb-mode-group{display:flex;margin-bottom:8px}
.satdb-mode-btn{flex:1;padding:6px 12px;border:1px solid var(--bd2);background:transparent;color:var(--t2);font-family:inherit;font-size:var(--fs-sm);font-weight:500;cursor:pointer;transition:all .15s}
.satdb-mode-btn:first-child{border-radius:var(--r) 0 0 var(--r)}
.satdb-mode-btn:last-child{border-radius:0 var(--r) var(--r) 0;margin-left:-1px}
.satdb-mode-btn.active{background:var(--abg2);color:var(--accent);border-color:var(--accent);z-index:1;position:relative}
.satdb-mode-btn:hover:not(.active){background:var(--bg4);color:var(--t1)}
.satdb-search-wrap{position:relative}
.satdb-search-input{width:100%;padding-left:2rem;padding-right:2rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%238b949e' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='7' cy='7' r='4.5'/%3E%3Cline x1='10.5' y1='10.5' x2='14' y2='14'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:.625rem center;background-size:16px}
.satdb-clear-btn{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--t3);font-size:1.1rem;cursor:pointer;padding:2px 6px;line-height:1}
.satdb-clear-btn:hover{color:var(--t1)}
.satdb-menu{display:none;position:absolute;left:0;right:0;top:100%;margin-top:4px;background:var(--bg2);border:1px solid var(--bd2);border-radius:var(--r);max-height:300px;overflow-y:auto;z-index:5;box-shadow:0 8px 24px rgba(0,0,0,.25)}
.satdb-search-wrap.open .satdb-menu{display:block}
.satdb-group-title{padding:6px 12px;font-size:var(--fs-sm);font-weight:500;color:var(--accent);text-transform:uppercase;letter-spacing:.04em;position:sticky;top:0;background:var(--bg3);border-bottom:1px solid var(--bd)}
.satdb-option{display:block;width:100%;padding:8px 12px;border:none;background:transparent;text-align:left;cursor:pointer;font-family:inherit;font-size:var(--fs-sm);color:var(--t1);border-bottom:1px solid var(--bd)}
.satdb-option:hover{background:var(--abg);color:var(--accent)}
.satdb-option:last-child{border-bottom:none}
.satdb-option-sub{font-size:var(--fs-sm);color:var(--t3);margin-top:2px}
.satdb-no-match{padding:12px;font-size:var(--fs-sm);color:var(--t3);text-align:center}
.satdb-overflow{padding:6px 12px;font-size:var(--fs-sm);color:var(--t3);text-align:center;font-style:italic}


.toggle{position:relative;width:40px;height:22px;background:var(--bg4);border:1px solid var(--bd2);border-radius:11px;cursor:pointer;transition:all .2s;flex-shrink:0}
.toggle:has(input:checked){background:var(--accent);border-color:var(--accent)}
.toggle input{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer;margin:0}

/* Tuner aside */
.tu-aside{background:var(--bg);border-left:1px solid var(--bd);overflow-y:auto;box-shadow:-4px 0 24px rgba(0,0,0,.4);position:absolute;right:0;top:0;height:100%;width:clamp(280px,21vw,380px);transform:translateX(100%);transition:transform .35s cubic-bezier(0.4,0,0.2,1);z-index:20}
.tu-aside.open{transform:translateX(0)}
.tu-aside-sec{padding:16px 18px;border-bottom:1px solid var(--bd)}
.tu-aside-sec:last-child{border-bottom:none}
.sig-row{display:flex;align-items:center;gap:10px;margin-bottom:.25rem}
.sig-l{font-size:var(--fs-sm);color:var(--t2);width:44px;flex-shrink:0;white-space:nowrap}
.sig-track{flex:1;height:5px;background:var(--bg4);border-radius:3px;overflow:hidden}
.sig-fill{width:0;height:100%;border-radius:3px}
.sig-v{font-family:var(--mono);font-size:var(--fs-sm);font-weight:500;min-width:64px;text-align:right;margin-left:auto;white-space:nowrap;color:var(--t3)}
.sig-v-disabled{color:var(--t4)}
.sig-v-val{color:var(--t1)}
.scan-progress{display:flex;align-items:center;gap:10px;padding:1rem 0;color:var(--t2);font-size:var(--fs-sm)}
.scan-step{transition:opacity .15s}
.scan-spinner{width:16px;height:16px;border:2px solid var(--bd2);border-top-color:var(--accent);border-radius:50%;animation:scan-spin .8s linear infinite;flex-shrink:0}
@keyframes scan-spin{to{transform:rotate(360deg)}}

/* Overlay tiers: drawers 20 · header 10 · sidenav 50 · modals 1000 · toasts 2000 */
/* Toast notifications (global — built by showToast in shell.js, `toast toast-<type>`) */
.toast-container{position:fixed;bottom:1rem;right:1rem;z-index:2000;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none}
.toast{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--r);font-size:var(--fs-sm);font-weight:500;box-shadow:0 4px 16px rgba(0,0,0,.25);pointer-events:auto;opacity:0;transform:translateX(100%);transition:opacity .3s,transform .3s cubic-bezier(.4,0,.2,1)}
.toast.show{opacity:1;transform:translateX(0)}
.toast.hide{opacity:0;transform:translateX(100%)}
.toast-icon{display:flex;flex-shrink:0}
.toast-msg{white-space:nowrap}
.toast-ok{background:var(--bg2);border:1px solid var(--ok);color:var(--ok)}
.toast-warn{background:var(--bg2);border:1px solid var(--warn);color:var(--warn)}
.toast-err{background:var(--bg2);border:1px solid var(--err);color:var(--err)}
.toast-info{background:var(--bg2);border:1px solid var(--accent);color:var(--accent)}

.pr{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:8px;padding:.25rem 0;border-bottom:1px solid var(--bd);font-size:1rem}
.pr:last-child{border-bottom:none}
/* Signal-monitor service-row badges (TV/Radio/FTA/CA — built by renderBadge/renderCryptBadge) */
.pr-name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pr-fta{font-size:var(--fs-sm);font-weight:500;padding:2px 6px;border-radius:3px;background:var(--okbg);color:var(--ok)}
.pr-ca{font-size:var(--fs-sm);font-weight:500;padding:2px 6px;border-radius:3px;background:var(--wbg);color:var(--warn)}
.pr-type{font-size:var(--fs-sm);font-weight:500;padding:2px 6px;border-radius:3px;white-space:nowrap}
.pr-tv{background:var(--bbg);color:var(--blue)}
.pr-radio{background:var(--pbg);color:var(--purple)}

/* === NETWORK PAGE === */
.nw-body{display:flex;flex:1;min-height:0;overflow:hidden}
.nw-sidebar{width:52px;flex-shrink:0;background:var(--bg);border-right:1px solid var(--bd);overflow-y:auto;padding:10px 0;transition:width .3s cubic-bezier(.4,0,.2,1);overflow-x:hidden}
.nw-nav-item{display:flex;align-items:center;justify-content:center;gap:10px;padding:var(--padding-sidenav-sm);cursor:pointer;font-size:1rem;color:var(--t2);transition:background .1s,color .1s,padding .3s cubic-bezier(.4,0,.2,1);border-left:3px solid transparent}
.nw-nav-item .ico{width:18px;height:18px;flex-shrink:0}
.nw-nav-label{overflow:hidden;white-space:nowrap;transition:opacity .3s ease,max-width .3s ease;opacity:0;max-width:0}
.nw-nav-item:hover{background:var(--bg4);color:var(--t1)}
.nw-nav-item.active{color:var(--accent);background:var(--abg);border-left-color:var(--accent)}
.nw-section{display:none}
.nw-section.active{display:block}
.p-network{flex:1;overflow-y:auto;min-height:0;padding:clamp(16px,1.5vw,32px);display:flex;flex-direction:column}
.nw-section-fill{display:none}
.nw-section-fill.active{display:flex;flex-direction:column;flex:1;min-height:0}
.nw-section-fill .ov-card{flex:1;min-height:0;display:flex;flex-direction:column}
.nw-form-card{max-width:432px}
.kv-rows{display:flex;flex-direction:column;gap:1rem}
.kv-rows-tight{gap:.375rem}
.kv-row{display:flex;align-items:center;gap:12px}
.kv-col{display:flex;flex-direction:column}
.kv-row-label{font-size:var(--fs-sm);color:var(--t3);white-space:nowrap;min-width:170px}
.kv-row-value{flex:1;min-width:0}
.kv-row .tu-enable{margin-bottom:0}
.nw-eth-table{border-collapse:collapse;min-width:480px}
.nw-eth-table thead th{padding:0 12px 10px;font-size:var(--fs-sm);font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;text-align:left}
.nw-eth-table thead th:first-child{padding-left:0;width:140px}
.nw-eth-table td:not(:first-child),.nw-eth-table th:not(:first-child){max-width:400px}
.nw-eth-table tbody td{padding:6px 12px;border-bottom:1px solid var(--bd);vertical-align:middle}
.nw-eth-table tbody td:first-child{padding-left:0;font-size:var(--fs-sm);color:var(--t3);white-space:nowrap}
.nw-eth-table tbody tr:last-child td{border-bottom:none}
.nw-eth-table input[type="text"]{font-family:var(--mono)}
.nw-link{display:inline-flex;align-items:center;gap:7px;font-size:var(--fs-sm);font-weight:500}
.nw-link-up{color:var(--ok)}
.nw-ro-val{font-size:var(--fs-sm);color:var(--t2);display:block;padding:.375rem 0}
.nw-mac{font-family:var(--mono);font-size:var(--fs-sm);color:var(--t2);display:block;padding:.375rem 0}
.nw-nb{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}
.nw-nb th{padding:6px 10px;text-align:left;font-size:var(--fs-sm);font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--bd);white-space:nowrap}
.nw-nb td{padding:9px 10px;border-bottom:1px solid var(--bd);vertical-align:middle}
.nw-nb tr:last-child td{border-bottom:none}
.nw-nb tr:hover td{background:var(--bg4)}
.nw-kv{width:100%;border-collapse:collapse}
.nw-kv td{padding:4px 0 4px 12px;border-bottom:1px solid var(--bd);vertical-align:middle}
.nw-kv select{padding:2px 8px;font-size:var(--fs-sm)}
.nw-kv .nw-mac,.nw-kv .nw-ro-val,.nw-kv .dev-status-val{padding:2px 4px}
.nw-kv td:first-child{padding-left:0;font-size:var(--fs-sm);color:var(--t3);white-space:nowrap;width:80px}
.nw-kv tr:last-child td{border-bottom:none}
input:disabled,select:disabled{opacity:.45;cursor:not-allowed}

/* === DEVICE PAGE === */
.nw-kv-wide td:first-child{width:170px}
.nw-kv-scroll{min-width:320px}
.dev-status-val{font-family:var(--mono);font-size:var(--fs-sm);color:var(--t1)}
.dev-status-ok{color:var(--ok)}.dev-status-warn{color:var(--warn)}
.dev-log{width:100%;flex:1;min-height:0;background:color-mix(in srgb,var(--bg2),var(--bg3));border:1px solid var(--bd2);border-radius:var(--r);padding:10px 14px;font-family:var(--mono);font-size:var(--fs-sm);color:var(--t3);resize:none;overflow-y:auto;line-height:1.7;white-space:pre}
.dev-fw-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.dev-action-desc{font-size:var(--fs-sm);color:var(--t3);line-height:1.5}
.dev-action-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:auto}
.dev-action-mb{margin-bottom:12px}
.dev-reboot-actions{margin-top:12px}
.dev-cfg-name{flex:1;min-width:120px}
.dev-sap-interval{width:100px}
.kv-row-inline{display:flex;align-items:center;gap:8px}
.btn-danger{background:color-mix(in srgb,var(--err) 10%,transparent);border:1px solid color-mix(in srgb,var(--err) 25%,transparent);color:var(--err);padding:.375rem .75rem;border-radius:var(--r);font-size:1rem;font-weight:500;cursor:pointer;transition:all .12s;line-height:1.375;display:inline-flex;align-items:center;gap:6px}
.btn-danger:hover{background:color-mix(in srgb,var(--err) 20%,transparent);border-color:var(--err)}
.btn-danger:focus-visible{outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--err) 30%,transparent)}
.btn-block{width:100%}
/* !important on .text-center: utility must beat any component's text-align */
.text-t2{color:var(--t2)}.text-t3{color:var(--t3)}.text-err{color:var(--err)}.text-ok{color:var(--ok)}.text-warn{color:var(--warn)}.text-center{text-align:center!important}
.fw-500{font-weight:500}
.btn-file{display:inline-flex;align-items:center;gap:6px;cursor:pointer}
.file-name-hint{font-size:var(--fs-sm);color:var(--t3);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.select-auto{width:auto}
.card-danger{border-color:rgba(232,93,111,.2)}
.dev-action-desc{font-size:var(--fs-sm);color:var(--t3);line-height:1.5;margin:6px 0 10px}
.dev-notice{font-size:1rem;color:var(--t3);margin-top:12px}
.cfg-row{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px}
.cfg-row>.ov-card{width:100%;max-width:416px;display:flex;flex-direction:column}
.cfg-export-grid{display:flex;flex-direction:column;gap:0;margin-top:12px}
.cfg-export-item{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--bd)}
.cfg-export-item:last-child{border-bottom:none}
.cfg-export-label{min-width:100px;font-weight:500;color:var(--t2);font-size:var(--fs-sm)}
.cfg-export-btns{display:flex;gap:6px}
.log-card{display:flex;flex-direction:column;gap:12px}
.log-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.log-header .ov-card-t{margin:0}
.log-controls{display:flex;gap:1rem;flex-wrap:wrap}
.fw-table{margin-bottom:20px}
.lic-list{margin-bottom:16px}
.dev-lic-item{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--bd);font-size:var(--fs-sm)}
.dev-lic-item:last-child{border-bottom:none}
.dev-lic-name{color:var(--t2)}
.dev-lic-badge-ok{font-size:var(--fs-sm);font-weight:500;color:var(--ok);background:var(--okbg);padding:2px 8px;border-radius:3px}
.dev-lic-badge-no{font-size:var(--fs-sm);font-weight:500;color:var(--t3);background:var(--bg3);padding:2px 8px;border-radius:3px}

/* === TS PROCESSING PAGE === */
/* Split layout: left 65% services, right 35% assignment panel */
.tsp-split-fill{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}
.tsp-split-layout{flex:1;min-height:0;display:flex;overflow:hidden;padding:clamp(16px,1.5vw,32px)}
.tsp-split-left{flex:1 1 0%;min-height:0;min-width:200px;display:flex}
.tsp-services-layout{flex:1;min-height:0;display:flex;flex-direction:column;background:var(--bg2);border:1px solid var(--bd);border-radius:10px;overflow:hidden}
/* MPTS drawer — on-demand, pushes the table aside when open (MPTS mode only) */
.tsp-mpts-drawer{flex:0 0 0;min-width:0;overflow:hidden;transition:flex-basis .35s cubic-bezier(0.4,0,0.2,1),margin-left .35s cubic-bezier(0.4,0,0.2,1);display:flex;flex-direction:column}
.tsp-mpts-drawer.open{flex:0 0 clamp(320px,28vw,420px);margin-left:clamp(12px,2vw,20px)}
.tsp-mpts-drawer > .tsp-assign-panel{width:clamp(320px,28vw,420px)}
/* Assignment panel */
.tsp-assign-panel{flex:1;display:flex;flex-direction:column;background:var(--bg2);border:1px solid var(--bd);border-radius:10px;overflow:hidden}
.tsp-assign-tabs{display:flex;flex-wrap:wrap;gap:0;flex-shrink:0;overflow:visible}
.tsp-assign-tabs:empty{display:none}
.tsp-assign-panel-title{flex:1;padding:10px 14px;font-size:var(--fs-sm);font-weight:500;color:var(--accent);background:var(--abg);border-bottom:1px solid var(--abr);text-transform:uppercase;letter-spacing:.04em}
.tsp-assign-body{flex:1;overflow-y:auto;padding:0}
/* SPTS mode: hide the MPTS column (no modulator assignment) */
.tsp-split-layout.spts .tsp-col-mpts{display:none}
.tsp-adv-btn{display:inline-flex;align-items:center;gap:6px}
.tsp-mpts-toggle{display:inline-flex;align-items:center}
.tsp-mpts-toggle.active{background:var(--abg);border-color:var(--abr);color:var(--accent)}
/* Advanced settings modal — wider scrollable variant of the confirm modal */
.adv-modal-overlay{position:fixed;inset:0;background:var(--backdrop-modal);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}
.adv-modal{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r);box-shadow:var(--shadow-modal);width:98%;max-width:960px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}
.adv-modal-hd{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--bd);flex-shrink:0;background:var(--bg);gap:8px}
.adv-modal-title{font-size:1rem;font-weight:500;color:var(--t1);line-height:1.3}
.adv-modal-close{background:var(--bg4);border:1px solid var(--bd2);color:var(--t2);cursor:pointer;padding:5px;border-radius:var(--r);flex-shrink:0;line-height:1;display:inline-flex;align-items:center}
.adv-modal-close:hover{color:var(--t1);background:var(--bg5);border-color:var(--bd3)}
.adv-modal-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}
.adv-modal-actions{padding:12px 18px;border-top:1px solid var(--bd);display:flex;justify-content:flex-end;gap:8px;flex-shrink:0}
/* Assignment panel item list (MPTS modulators / CAM slots) */
.tsp-assign-items{display:flex;flex-direction:column}
.tsp-assign-item{padding:10px 14px;border-bottom:1px solid var(--bd);cursor:pointer;transition:background .1s}
.tsp-assign-item:hover{background:var(--bg4)}
.tsp-assign-item.active{background:var(--abg);border-left:3px solid var(--accent)}
.tsp-assign-item-hd{display:flex;align-items:center;justify-content:space-between;gap:8px}
.tsp-assign-item-id{font-weight:500;color:var(--t1);font-size:var(--fs-sm)}
.tsp-assign-item-count{font-size:var(--fs-sm);color:var(--t3)}
/* Assignment detail (selected MPTS/CAM) */
.tsp-assign-detail{padding:14px}
.tsp-assign-detail-hd{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:12px}
.tsp-assign-detail-title{font-size:1rem;font-weight:500;color:var(--t1)}
.tsp-assign-detail-back{background:var(--bg4);border:1px solid var(--bd2);color:var(--t2);cursor:pointer;padding:4px 10px;border-radius:var(--r);font-size:var(--fs-sm);font-family:inherit;display:inline-flex;align-items:center;gap:4px}
.tsp-assign-detail-back:hover{background:var(--bg5);color:var(--t1)}
.tsp-assign-svc-table{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}
.tsp-assign-svc-table th{padding:6px 10px;text-align:left;font-size:var(--fs-sm);font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--bd)}
.tsp-assign-svc-table td{padding:6px 10px;border-bottom:1px solid var(--bd);vertical-align:middle;white-space:nowrap}
.tsp-assign-svc-table tr:last-child td{border-bottom:none}
.tsp-assign-svc-table tr:hover td{background:var(--bg4)}
.tsp-assign-remove-btn{background:transparent;border:none;color:var(--t3);cursor:pointer;padding:2px;border-radius:3px;display:inline-flex;align-items:center;line-height:1}
.tsp-assign-remove-btn:hover{color:var(--err);background:var(--ebg)}
.tsp-assign-hint{padding:10px 14px;font-size:1rem;color:var(--accent);border-bottom:1px solid var(--bd)}
.tsp-assign-sipsi{padding:clamp(12px,1.5vw,20px);display:flex;flex-direction:column;gap:16px}
.tsp-assign-empty{padding:24px 14px;text-align:center;font-size:var(--fs-sm);color:var(--t3)}
/* Capacity bar inside assignment detail */
.tsp-assign-capacity{padding:10px 14px;border-top:1px solid var(--bd);background:var(--bg)}
.tsp-assign-capacity-bar{height:8px;background:var(--bg4);border-radius:4px;overflow:visible;margin-top:6px;position:relative}
.tsp-assign-capacity-fill{height:100%;border-radius:4px;transition:width .2s;max-width:100%}
.tsp-assign-capacity-ref{position:absolute;top:-2px;width:2px;height:12px;background:var(--t3);border-radius:1px}
.tsp-assign-capacity-label{display:flex;justify-content:space-between;font-size:var(--fs-sm);color:var(--t3);margin-top:4px}
.tsp-tuner-tabs{display:flex;flex-direction:column;gap:8px;padding:10px 14px;flex-shrink:0;border-bottom:1px solid var(--bd);background:var(--bg)}
.mpts-bar-ok{background:var(--ok)}
.mpts-bar-warn{background:var(--warn)}
.mpts-bar-err{background:var(--err)}
.tsp-tab-filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.tsp-tab-filters select{width:auto}
.tsp-tuner-btns{display:flex;flex-wrap:wrap;gap:4px}
.tsp-tuner-btn{background:transparent;border:1px solid var(--bd2);border-radius:var(--r);padding:.25rem .625rem;font-size:var(--fs-sm);color:var(--t2);cursor:pointer;font-family:inherit;transition:background .15s,color .15s,border-color .15s,opacity .15s}
.tsp-tuner-btn:hover:not(:disabled){background:var(--bg4);color:var(--t1);border-color:var(--bd3)}
.tsp-tuner-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.tsp-tuner-btn.active:hover:not(:disabled){background:var(--accent-dark);color:#fff;border-color:var(--accent-dark)}
.tsp-tuner-btn:disabled{opacity:.4;cursor:not-allowed}
#streams-container{flex:1;min-height:0;display:flex;flex-direction:column}
#streams-container>.ov-card{flex:1;min-height:0;display:flex;flex-direction:column;padding:0;overflow:hidden}
#streams-container .ov-card-t-actions{padding:10px 14px;margin-bottom:0;border-bottom:1px solid var(--bd)}
.tsp-table-drawer-row{display:flex;flex:1;min-height:0;position:relative}
.tsp-table-wrap{flex:1;overflow-y:auto;overflow-x:auto;min-width:0}
.tsp-svc-table{width:100%;border-collapse:collapse;font-size:1rem}
.tsp-svc-table>thead{position:sticky;top:0;z-index:1;box-shadow:0 3px 18px -6px rgba(0,0,0,.1)}
.tsp-svc-table>thead>tr>th{padding:7px 12px;text-align:left;font-size:var(--fs-sm);font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--bd);background:var(--bg);white-space:nowrap;box-shadow:inset 0 -1px 0 var(--bd)}
/* On taller viewports: filter row pins at top; thead stacks below it.
   Small negative offset (-1px) on thead's top absorbs any sub-pixel gap between
   the two sticky elements so row content can't peek through at the seam. */
@media (min-height:768px) and (min-width:1200px){
  .tsp-services-layout .tsp-tuner-tabs{position:sticky;top:0;z-index:2}
  .tsp-services-layout .tsp-svc-table>thead{top:calc(var(--sticky-filters-h,57px) - 1px)}
}
.tsp-svc-table>thead>tr>th:first-child,.tsp-svc-table>tbody>tr>td:first-child{padding-left:1.5rem;padding-right:1rem}
.tsp-svc-table>thead>tr>th:last-child,.tsp-svc-table>tbody>tr>td:last-child{padding-right:1.5rem}
.tsp-svc-table td{padding:6px 12px;border-bottom:1px solid var(--bd);vertical-align:middle;white-space:nowrap}
.tsp-group-row td{padding:5px 12px;background:var(--bg3);border-bottom:1px solid var(--bd);border-top:1px solid var(--bd);vertical-align:middle}
.tsp-group-row td:first-child{padding-left:1.5rem}
.tsp-group-row td:last-child{padding-right:1.5rem}
.tsp-group-row:first-child td{border-top:none}
.tsp-group-hd{display:flex;align-items:center;gap:1rem}
.tsp-group-badge{display:inline-flex;align-items:center;gap:.5rem;padding:1px 7px;border-radius:3px;font-size:var(--fs-sm);font-weight:500;background:var(--bg4);color:var(--t1);text-decoration:none}
.tsp-group-info{color:var(--t3);font-family:var(--mono);font-size:var(--fs-sm)}
.tsp-svc-row{cursor:default}
.tsp-svc-row:hover td{background:var(--bg4)}
.tsp-svc-row.row-active td{background:var(--abg);border-bottom-color:transparent}
.tsp-svc-row.row-active td:first-child{box-shadow:inset 3px 0 0 var(--accent)}
.tsp-svc-row.row-active:hover td{background:var(--abg2)}
.tsp-svc-row.row-last td{background:var(--abg)}
.tsp-svc-row.row-last td:first-child{box-shadow:inset 3px 0 0 var(--accent)}
/* !important widths below: override base `input[type=text]{width:100%}` rule */
.tsp-lcn-in{width:5rem !important;font-family:var(--mono);text-align:center}
.tsp-search-wrap{position:relative;display:inline-flex;align-items:center;margin-left:8px;text-transform:none;letter-spacing:normal}
.tsp-name-search{background:var(--bg3);border:1px solid var(--bd2);border-radius:var(--r);padding:.25rem 1.5rem .25rem .5rem;outline:none;transition:border-color .15s,box-shadow .15s;width:7rem;line-height:1.25;color:var(--t1);font-family:var(--font);font-size:var(--fs-sm);font-weight:400;box-sizing:border-box;height:30px}
.tsp-name-search:focus-visible{border-color:var(--focus-clr);box-shadow:var(--focus-ring)}
.tsp-name-search::-webkit-search-cancel-button{-webkit-appearance:none;appearance:none}
.tsp-search-clear{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:18px;height:18px;display:none;align-items:center;justify-content:center;background:none;border:none;color:var(--t3);cursor:pointer;font-size:var(--fs-sm);line-height:1;padding:0;border-radius:50%}
.tsp-search-clear:hover{color:var(--t1);background:var(--bg4)}
.tsp-search-wrap input.tsp-name-search:not(:placeholder-shown)+.tsp-search-clear{display:inline-flex}
.tsp-svc-name{color:var(--t1)}
.tsp-svc-name.dimmed{color:var(--t2)}
.tsp-th-lock,.tsp-lock-cell{width:20px;text-align:center;padding:0 2px}
.tsp-lock-icon{color:var(--warn);vertical-align:middle}
.tsp-lock-ok{color:var(--ok)}
.tsp-lock-err{color:var(--err)}
.tsp-svc-name-click{cursor:pointer;border-bottom:1px dashed var(--bd2);transition:color .15s,border-color .15s}
.tsp-svc-name-click:hover{color:var(--accent);border-color:var(--accent)}
.tsp-detail-row{display:none}
.tsp-detail-row.open{display:table-row}
.tsp-detail-row>td{padding:0 12px 12px;background:var(--bg);border-bottom:1px solid var(--bd)}
.tsp-detail-content{padding:10px 0 4px}
.tsp-detail-fields{display:flex;flex-direction:column;gap:12px}
.tsp-detail-sec{min-width:200px;flex:1}
.tsp-detail-row-fields{display:flex;gap:12px;flex-wrap:wrap}
.tsp-detail-row-fields .tsp-drawer-field{flex:1;min-width:140px;margin-bottom:0}
.tsp-detail-close{text-align:center;margin-top:10px}
.lcn-modal-overlay,.confirm-modal-overlay{position:fixed;inset:0;background:var(--backdrop-modal);display:flex;align-items:center;justify-content:center;z-index:1000}
.lcn-modal,.confirm-modal{position:relative;background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r);padding:24px;min-width:320px;max-width:420px}
.lcn-modal-close{position:absolute;top:10px;right:10px;background:none;border:none;color:var(--t3);font-size:var(--fs-lg);line-height:1;cursor:pointer;padding:4px 8px;border-radius:var(--r)}
.lcn-modal-close:hover{color:var(--t1);background:var(--bg4)}
.lcn-modal-title,.confirm-modal-title{font-size:1rem;font-weight:500;color:var(--t1);margin-bottom:12px}
.confirm-modal-message{margin-bottom:16px;color:var(--t2);white-space:pre-line}
.confirm-modal-actions{display:flex;gap:8px;justify-content:flex-end}
.lcn-message{font-size:var(--fs-sm);color:var(--t2);margin:0 0 20px}
.lcn-modal-actions{display:flex;flex-direction:column;gap:8px}
.lcn-modal-actions button{width:100%;text-align:center}
.svc-badge{display:inline-flex;align-items:center;padding:2px 6px;border-radius:3px;font-size:var(--fs-sm);font-weight:500;line-height:1.4;white-space:nowrap}
.svc-badge-tv{background:var(--abg);color:var(--accent)}
.svc-badge-radio{background:var(--pbg);color:var(--purple)}
.svc-badge-data{background:var(--bbg);color:var(--blue)}
.svc-badge-fta{background:var(--okbg);color:var(--ok)}
.svc-badge-ca{background:var(--wbg);color:var(--warn)}
.tsp-cam-sel{width:auto}
/* !important: override base `select{padding-right:2.25rem}` — inline column selects use tighter chevron room */
.tsp-svc-cam-sel,.tsp-svc-mpts-sel{width:auto;min-width:5rem;padding-right:1.5rem!important}
.tsp-edit-btn,.tsp-spts-detail-btn,.tsp-row-del-btn{background:transparent;border:none;color:var(--t3);cursor:pointer;padding:3px;border-radius:4px;display:inline-flex;align-items:center;line-height:1}
.tsp-edit-btn:hover,.tsp-spts-detail-btn:hover{background:var(--bg4);color:var(--t1)}
.tsp-row-del-btn:hover{background:color-mix(in srgb, var(--err) 10%, transparent);color:var(--err)}
.tsp-drawer-action{display:inline-flex;align-items:center;justify-content:center;gap:6px}
.tsp-drawer-actions{display:flex;flex-direction:column;gap:8px}
/* Drawer — used by Output IP MPTS detail */
.tsp-drawer{position:absolute;right:0;top:0;height:100%;width:0;overflow:hidden;border-left:1px solid var(--bd);transition:width .3s cubic-bezier(.4,0,.2,1);z-index:20;box-shadow:-4px 0 16px rgba(0,0,0,.08)}
.tsp-drawer.open{width:100%;max-width:500px}
.tsp-drawer-inner{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden;background:var(--bg2)}
.tsp-drawer-hd{display:flex;align-items:flex-start;justify-content:space-between;padding:12px 14px 10px;border-bottom:1px solid var(--bd);gap:8px;flex-shrink:0;background:var(--bg)}
.tsp-drawer-title{font-size:1rem;font-weight:500;color:var(--t1);line-height:1.3}
.tsp-drawer-sub{font-size:var(--fs-sm);color:var(--t3);margin-top:2px}
.tsp-drawer-close{background:var(--bg4);border:1px solid var(--bd2);color:var(--t2);cursor:pointer;padding:5px;border-radius:var(--r);flex-shrink:0;line-height:1;display:inline-flex;align-items:center}
.tsp-drawer-close:hover{color:var(--t1);background:var(--bg5);border-color:var(--bd3)}
.tsp-drawer-body{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:24px}
.tsp-drawer-sec-lbl{font-size:var(--fs-sm);font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}
.tsp-drawer-field{margin-bottom:10px}
.tsp-drawer-field:last-child{margin-bottom:0}
.tsp-drawer-field .fl{margin-bottom:4px}
.tsp-hint{color:var(--t3)}
.tsp-pid-table{width:100%;border-collapse:collapse;font-size:1rem;margin-bottom:6px}
.tsp-pid-table col:nth-child(2){width:7rem}
.tsp-pid-table col:nth-child(3){width:7rem}
.tsp-pid-table col:nth-child(4){width:6rem}
.tsp-pid-table col:nth-child(5){width:6rem}
.tsp-pid-table col:nth-child(6){width:7rem}
.tsp-pid-table th{font-size:var(--fs-sm);font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;padding:4px 6px;border-bottom:1px solid var(--bd);text-align:left;background:var(--bg3)}
.tsp-pid-table td{padding:5px 6px;border-bottom:1px solid var(--bd)}
.tsp-pid-table tr:last-child td{border-bottom:none}
.tsp-pid-type{color:var(--t2)}
.tsp-pid-table .tsp-pid-num-in{width:100%;font-family:var(--mono)}
/* !important widths below: override base `input[type=text]{width:100%}` rule */
.tsp-mcast-in{width:11rem !important;font-family:var(--mono)}
.tsp-br-in{width:6rem !important;font-family:var(--mono)}
.tsp-port-in{width:5rem !important;font-family:var(--mono)}
.tsp-pid-actions{white-space:nowrap}
.tsp-pid-actions .tsp-edit-btn{margin-left:2px}
.tsp-pid-ok{color:var(--ok)}
.tsp-pid-ok:hover{color:var(--ok);background:var(--okbg)}
.tsp-pid-cancel{color:var(--warn)}
.tsp-pid-cancel:hover{color:var(--warn);background:var(--wbg)}
.tsp-bulk-row{display:flex;flex-direction:row;column-gap:2rem; row-gap: 1rem; align-items:flex-start; flex-wrap: wrap;}
.tsp-bulk-row select,.tsp-bulk-row input,.tsp-bulk-row button{flex:none}
.tsp-bulk-group{display:flex;flex-direction:column}
.tsp-bulk-group .fl{margin-bottom:4px}
.tsp-bulk-inline{display:inline-flex;align-items:center;gap:8px}
.tsp-bulk-ip{display:inline-flex;align-items:stretch;border:1px solid var(--bd2);border-radius:6px;background:var(--bg3);overflow:hidden}
.tsp-bulk-ip:focus-within{border-color:var(--focus-clr);box-shadow:var(--focus-ring)}
.tsp-bulk-row .tsp-bulk-proto{width:6rem}
.tsp-bulk-row .tsp-bulk-ip .tsp-bulk-octet{font-family:var(--mono);width:3.5rem;text-align:center;border:none;border-radius:0;background:transparent;box-shadow:none}
.tsp-bulk-row .tsp-bulk-ip .tsp-bulk-octet:not(:last-child){border-right:1px solid var(--bd2)}
.tsp-bulk-row .tsp-bulk-ip .tsp-bulk-octet:focus{background:var(--bg4);box-shadow:none;border-color:transparent}
.tsp-bulk-row .tsp-bulk-ip .tsp-bulk-octet:focus:not(:last-child){border-right-color:var(--bd2)}
.tsp-bulk-row .tsp-bulk-ip .tsp-bulk-octet.invalid{background:var(--ebg);color:var(--err);box-shadow:none}
.tsp-bulk-row .tsp-bulk-ip:has(.tsp-bulk-octet.invalid){border-color:var(--err)}
.tsp-bulk-row .tsp-bulk-octet{font-family:var(--mono);width:4rem;text-align:center}
.tsp-bulk-row .tsp-bulk-port{font-family:var(--mono);width:5rem}
.tsp-bulk-action{width:auto;cursor:pointer;background-color:transparent}
.tsp-bulk-action option{background:var(--bg2);color:var(--t1)}
[data-theme="dark"] .tsp-bulk-action{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%238b949e' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='4 6 8 10 12 6'/%3E%3C/svg%3E")}
.tsp-streams-table{width:100%;border-collapse:collapse;font-size:1rem}
.tsp-streams-table>thead{position:sticky;top:0;z-index:1;box-shadow:0 3px 18px -6px rgba(0,0,0,.1)}
.tsp-streams-table>thead>tr>th{padding:7px 12px;text-align:left;font-size:var(--fs-sm);font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--bd);background:var(--bg);white-space:nowrap;box-shadow:inset 0 -1px 0 var(--bd)}
/* On taller viewports: keep card title + batch button pinned too; stack thead below */
@media (min-height:768px) and (min-width:992px){
  #streams-container .ov-card-t-actions{position:sticky;top:0;z-index:2;background:var(--bg2)}
  #streams-container .tsp-streams-table>thead{top:calc(var(--sticky-actions-h,52px) - 1px)}
}
.th-sort{cursor:pointer;user-select:none;transition:background .15s,color .15s}
.th-sort:hover{color:var(--t1);background:var(--bg4)}
.th-sort:hover .th-sort-ind{color:var(--t2)}
.th-sort-ind{margin-left:4px;color:var(--t4);font-size:var(--fs-sm);transition:color .15s}
.th-sort-ind.active{color:var(--accent)}
/* Per-column filter toggle (funnel icon next to sort arrow).
   Active state = solid/filled icon (same neutral color), inactive = outline. */
.th-filter-btn{background:transparent;border:none;color:var(--t4);cursor:pointer;padding:2px;border-radius:3px;display:inline-flex;align-items:center;vertical-align:middle;margin-left:4px;transition:color .15s,background .15s}
.th-filter-btn:hover{color:var(--t1);background:var(--bg4)}
.th-filter-btn.active{color:var(--t1)}
.th-filter-btn.active:hover{background:var(--bg4)}
/* Narrow cell for single-checkbox columns */
.tsp-streams-table th.col-cb,.tsp-streams-table td.col-cb{white-space:nowrap;text-align:center}
.tsp-streams-table>thead>tr>th:first-child,.tsp-streams-table>tbody>tr>td:first-child{padding-left:1.5rem;text-align:left}
.tsp-streams-table>thead>tr>th:last-child,.tsp-streams-table>tbody>tr>td:last-child{padding-right:1.5rem}
.tsp-streams-table td{padding:6px 12px;border-bottom:1px solid var(--bd);vertical-align:middle;white-space:nowrap}
.tsp-streams-table tr:last-child td{border-bottom:none}
.tsp-streams-table>tbody>tr:not(.tsp-detail-row):hover>td{background:var(--bg4)}
.tsp-streams-table tr.row-active td{background:var(--abg)}
.tsp-streams-table tr.row-active td:first-child{box-shadow:inset 3px 0 0 var(--accent)}
.tsp-streams-table tr.row-last td{background:var(--abg)}
.tsp-streams-table tr.row-last td:first-child{box-shadow:inset 3px 0 0 var(--accent)}
.tsp-streams-table tr.stream-off td:not(:first-child){opacity:.7}
.tsp-stream-svc-btn{background:transparent;border:none;color:var(--accent);cursor:pointer;font-family:inherit;font-size:inherit;padding:0;display:inline-flex;align-items:center;gap:4px}
.tsp-stream-svc-btn:hover{color:var(--accent-light)}
.tsp-stream-svc-tbl{width:100%;border-collapse:collapse}
.tsp-stream-svc-tbl th{padding:5px 8px;text-align:left;font-size:var(--fs-sm);font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--bd)}
.tsp-stream-svc-tbl td{padding:6px 8px;border-bottom:1px solid var(--bd);vertical-align:middle;white-space:nowrap}
.tsp-stream-svc-tbl tr:last-child td{border-bottom:none}
.tsp-stream-svc-tbl tr:hover td{background:var(--bg4)}
.nw-form-card.nw-form-card-wide{max-width:none}
.tsp-nit-mod-table{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}
.tsp-nit-mod-table th{padding:6px 10px;text-align:left;font-size:var(--fs-sm);font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--bd);white-space:nowrap}
.tsp-nit-mod-table td{padding:5px 10px;border-bottom:1px solid var(--bd);vertical-align:middle}
.tsp-nit-mod-table tr:last-child td{border-bottom:none}
.tsp-nit-mod-table .tsp-nit-mod-id{font-weight:500;color:var(--t1);font-size:var(--fs-sm)}
.tsp-nit-mod-table select{width:auto}
.tsp-nit-mod-table input[type="number"]{width:6rem;font-family:var(--mono)}
.tsp-radio-group{display:flex;flex-direction:column;gap:7px;margin-top:4px}
.tsp-radio-row{display:flex;align-items:center;gap:8px;font-size:var(--fs-sm);color:var(--t1)}
.tsp-nit-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.tsp-nit-auto-row{display:flex;align-items:center;gap:8px}
.tsp-nit-auto-row select{width:auto}
.tsp-nit-auto-row input{flex:1}
.tsp-pid-unreg-tbl{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}
.tsp-pid-unreg-tbl th{padding:6px 10px;text-align:left;font-size:var(--fs-sm);font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--bd);white-space:nowrap}
.tsp-pid-unreg-tbl td{padding:5px 10px;border-bottom:1px solid var(--bd);vertical-align:middle}
.tsp-pid-unreg-tbl tr:last-child td{border-bottom:none}
.ov-card-t-actions{display:flex; flex-wrap: wrap; gap:0.5rem; align-items:center;justify-content:space-between;margin-bottom:16px}
.ov-card-t-actions .ov-card-t{margin-bottom:0}
.ov-card-t-btns{display:flex;gap:1rem; flex-wrap: wrap;}
.btn-sm{font-size:var(--fs-sm);padding:4px 10px}
/* !important: compact modifier must beat per-component paddings (.btn-accent etc.);
   select.element-sm restores chevron room (base select has padding-right:2.25rem);
   .text-sm utility must beat element-level font-size rules */
.element-sm{line-height:1.25!important;padding:.25rem .75rem!important}
select.element-sm{padding:.25rem 2.25rem .25rem .75rem!important}
.text-sm{font-size:var(--fs-sm)!important}
.tsp-empty-cell{text-align:center;padding:16px 10px;font-size:var(--fs-sm);color:var(--t3)}
.tsp-unref-desc{width:120px}

/* === CAM PAGE === */
.cam-slot-hint{font-size:var(--fs-sm);color:var(--t3);padding:8px 0}
.cam-slot-badge{font-size:var(--fs-sm);font-weight:500;color:var(--accent);background:var(--abg);padding:2px 6px;border-radius:3px}
.cam-svc-tabs{display:flex;gap:4px;margin-bottom:12px}
.cam-svc-card{flex:1;display:flex;flex-direction:column;overflow:hidden}
.cam-svc-scroll{flex:1;overflow-y:auto}
.cam-svc-table{width:100%;border-collapse:collapse;font-size:1rem}
.cam-svc-table th{text-align:left;font-size:var(--fs-sm);text-transform:uppercase;color:var(--t3);font-weight:500;padding:8px 10px;border-bottom:1px solid var(--bd)}
.cam-svc-table td{padding:8px 10px;border-bottom:1px solid var(--bd)}
.cam-menu-title{font-size:1rem;font-weight:500;color:var(--t1);margin-bottom:12px}
.cam-menu-list{display:flex;flex-direction:column;gap:2px}
.cam-menu-item{padding:10px 14px;background:var(--bg3);border-radius:var(--r);cursor:pointer;color:var(--t1);font-size:var(--fs-sm);transition:background .1s;display:flex;align-items:center}
.cam-menu-item:hover{background:var(--bg4)}
.cam-menu-chevron{margin-left:auto;opacity:.5}
/* CAM PID expand/collapse */
.cam-pid-toggle{background:transparent;border:none;color:var(--t3);cursor:pointer;padding:2px;border-radius:3px;display:inline-flex;align-items:center;line-height:1;transition:transform .2s,color .1s}
.cam-pid-toggle:hover{color:var(--t1)}
.cam-pid-toggle.open{transform:rotate(90deg);color:var(--accent)}
.cam-pid-detail-row>td{padding:0 12px 10px;border-bottom:1px solid var(--bd)}
.cam-pid-table{width:auto;border-collapse:collapse;font-size:var(--fs-sm);margin:6px 0 2px 20px}
.cam-pid-table th{padding:4px 12px;text-align:left;font-size:var(--fs-sm);font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--bd);vertical-align:middle}
.cam-pid-table td{padding:5px 12px;border-bottom:1px solid var(--bd);vertical-align:middle;white-space:nowrap}
.cam-pid-table tr:last-child td{border-bottom:none}
.cam-pid-table select{width:auto;font-size:var(--fs-sm);vertical-align:middle}
.cam-svc-table th:first-child,.cam-svc-table td:first-child{width:28px;padding-right:0}
/* !important: CI-menu slot picker uses full form-control sizing, overriding compact .cam-pid-table select rules that would otherwise cascade here */
.cam-menu-slot-sel{padding:.375rem .75rem !important;font-size:1rem !important}
.cam-menu-back{margin-top:12px}

/* === RESPONSIVE === */
.btn-aside-toggle{display:inline-flex;align-items:center}
/* === RESPONSIVE SIDEBAR ===
   Mobile-first: sidenav is an off-canvas drawer opened by the header hamburger.
   At ≥992px the sidenav becomes a static grid column; hamburger + backdrop hidden. */
@media (min-width:992px){
  .app{grid-template-columns:var(--sidebar-w) minmax(0,1fr)}
  .page{grid-column:2}
  .sidenav{position:static;transform:none;transition:none;grid-column:1;grid-row:2;z-index:auto}
  .gh-hamburger{display:none}
  body::before{display:none}
  .gh-logo{width:var(--sidebar-w);align-items:flex-start;padding:0 1rem}
  .gh-logo-img{opacity:1;max-width:120px;max-height:24px}
  .gh-logo-sub{opacity:1;max-width:9rem;max-height:1.2em}
  .gh-logo-icon{display:none}
  .tl-info,.tu-sb-title{display:block}
  .nw-sidebar{width:11rem}
  .nw-nav-item{justify-content:flex-start}
  .nw-nav-label{opacity:1;max-width:10rem}
  .tu-body{grid-template-columns:160px minmax(0,1fr)}
}
/* Input RF aside: becomes a static grid column at ≥1200px; below, it stays a drawer. */
@media (min-width:1200px){
  .btn-aside-toggle{display:none}
  .tu-body{grid-template-columns:160px minmax(0,1fr) clamp(280px,21vw,380px);position:static}
  .tu-aside,.tu-aside.open{position:static;right:auto;top:auto;height:auto;width:auto;transform:none;transition:none;z-index:auto;box-shadow:-4px 0 24px rgba(0,0,0,.12)}
}
/* Roomier nav padding on taller viewports */
@media (min-height:630px){
  .nav-item,.theme-btn,.nw-nav-item{padding:var(--padding-sidenav)}
}

/* === THEME TOGGLE BUTTON === */
.theme-btn{background:none;width:100%;text-align:left;border:none;border-left:3px solid transparent;border-radius:0;padding:var(--padding-sidenav-sm);font-size:1rem;font-weight:400;color:var(--t3);display:flex;align-items:center;gap:10px;cursor:pointer;transition:color .1s,background .1s;margin:1px 0;flex-shrink:0}
.theme-btn:hover{background:var(--bg4);color:var(--t1)}
.theme-btn:active{transform:none}
.theme-icon{display:flex;align-items:center;flex-shrink:0}
.lang-icon{min-width:18px;font-weight:600;text-align:center;letter-spacing:-.02em}

/* === HELP MODAL === */
.help-modal-overlay{position:fixed;inset:0;background:var(--backdrop-modal);display:flex;align-items:center;justify-content:center;z-index:1000}
.help-modal{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r);width:90%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-modal)}
.help-modal-hd{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--bd)}
.help-modal-title{font-size:1rem;font-weight:500;color:var(--t1)}
.help-modal-close{background:none;border:none;color:var(--t3);font-size:1.25rem;cursor:pointer;padding:0 4px;line-height:1}
.help-modal-close:hover{color:var(--t1)}
.help-modal-body{padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}
.help-modal-sec-title{font-size:var(--fs-sm);font-weight:500;text-transform:uppercase;color:var(--t3);letter-spacing:.04em;margin-bottom:8px}
.help-modal-list{margin:0;padding-left:1.25rem;color:var(--t2);font-size:var(--fs-sm);line-height:1.7}
.help-modal-list b{color:var(--t1);font-weight:500}
.help-modal-body p{margin:0;font-size:var(--fs-sm);color:var(--t2);line-height:1.5}
.help-modal-note{color:var(--t2);line-height:1.6}
.help-modal-note b{color:var(--t1);font-weight:500}
.help-modal-link{display:block;text-align:center;padding:10px 16px;background:var(--bg3);border:1px solid var(--bd2);border-radius:6px;color:var(--accent);font-size:var(--fs-sm);font-weight:500;text-decoration:none;transition:background .15s,border-color .15s}
.help-modal-link:hover{background:var(--bg4);border-color:var(--bd3)}

/* === DARK THEME — component overrides === */
[data-theme="dark"] select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23565e68' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='4 6 8 10 12 6'/%3E%3C/svg%3E")}
[data-theme="dark"] .btn-accent{background:var(--accent-dark);color:white}
[data-theme="dark"] .btn-accent:hover{background:var(--accent)}
[data-theme="dark"] .tu-aside{box-shadow:none}
[data-theme="dark"] .tsp-drawer{box-shadow:-4px 0 16px rgba(0,0,0,.2)}

/* === ROOMY NAVBAR — tall viewports === */
@media (min-height:800px){
  .sidenav{padding:8px 0}
  .nav-group-label{padding:0.5rem 1rem 0.25rem}
}

/* === ICONS (mask-image, single-color, coloured via currentColor) ===
   HTML usage: <span class="ico ico-NAME"></span>    (default 16×16)
               <span class="ico ico-NAME ico-14"></span>  (smaller)
               <span class="ico ico-NAME ico-18|22|48"></span>  (larger)
   Each icon sets a CSS custom property --ico; the base .ico rule wires
   it up to both the prefixed and un-prefixed mask-image declarations. */
.ico{display:inline-block;width:16px;height:16px;background-color:currentColor;flex-shrink:0;vertical-align:-3px;
     -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
     -webkit-mask-position:center;mask-position:center;
     -webkit-mask-size:contain;mask-size:contain;
     -webkit-mask-image:var(--ico);mask-image:var(--ico)}
.ico-12{width:12px;height:12px}
.ico-13{width:13px;height:13px}
.ico-14{width:14px;height:14px}
.ico-15{width:15px;height:15px}
.ico-18{width:18px;height:18px}
.ico-20{width:20px;height:20px}
.ico-22{width:22px;height:22px}
.ico-48{width:48px;height:48px}

.ico-arrow-right{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><line x1='5' y1='12' x2='19' y2='12'/><polyline points='12 5 19 12 12 19'/></svg>")}
.ico-aside{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='4' width='18' height='16' rx='2'/><line x1='15' y1='4' x2='15' y2='20'/></svg>")}
.ico-sliders{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><line x1='4' y1='6' x2='7' y2='6'/><line x1='11' y1='6' x2='20' y2='6'/><circle cx='9' cy='6' r='2'/><line x1='4' y1='12' x2='13' y2='12'/><line x1='17' y1='12' x2='20' y2='12'/><circle cx='15' cy='12' r='2'/><line x1='4' y1='18' x2='9' y2='18'/><line x1='13' y1='18' x2='20' y2='18'/><circle cx='11' cy='18' r='2'/></svg>")}
.ico-chevron-right{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='9 18 15 12 9 6'/></svg>")}
.ico-chevron-down{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>")}
.ico-upload{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><path d='M21 15v4a2 2 0 01-2 2H5a2 2 0 01-2-2v-4'/><polyline points='17 8 12 3 7 8'/><line x1='12' y1='3' x2='12' y2='15'/></svg>")}
.ico-refresh{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='23 4 23 10 17 10'/><path d='M20.49 15a9 9 0 1 1-2.12-9.36L23 10'/></svg>")}
.ico-info{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='10'/><line x1='12' y1='8' x2='12' y2='8'/><polyline points='11 12 12 12 12 16'/></svg>")}
.ico-activity{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><path d='M22 12h-4l-3 9L9 3l-3 9H2'/></svg>")}
.ico-split{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><line x1='3' y1='12' x2='9' y2='12'/><polyline points='9 12 13 7 21 7'/><polyline points='9 12 13 17 21 17'/><polyline points='18 4 21 7 18 10'/><polyline points='18 14 21 17 18 20'/></svg>")}
.ico-eye{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><path d='M1 12s4-8 11-8 11 8 11 8-4 8-11 8-11-8-11-8z'/><circle cx='12' cy='12' r='3'/></svg>")}
.ico-file-export{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><path d='M14 2H6a2 2 0 00-2 2v16a2 2 0 002 2h12a2 2 0 002-2V8z'/><polyline points='14 2 14 8 20 8'/><line x1='7' y1='15' x2='15' y2='15'/><polyline points='10 12 7 15 10 18'/><polyline points='12 12 15 15 12 18'/></svg>")}
.ico-package{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><path d='M21 16V8a2 2 0 00-1-1.73l-7-4a2 2 0 00-2 0l-7 4A2 2 0 002 8v8a2 2 0 001 1.73l7 4a2 2 0 002 0l7-4A2 2 0 0021 16z'/><polyline points='3.27 6.96 12 12.01 20.73 6.96'/><line x1='12' y1='22.08' x2='12' y2='12'/></svg>")}
.ico-database{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><ellipse cx='12' cy='5' rx='9' ry='3'/><path d='M21 12c0 1.66-4 3-9 3s-9-1.34-9-3'/><path d='M3 5v14c0 1.66 4 3 9 3s9-1.34 9-3V5'/></svg>")}
.ico-key{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><path d='M21 2l-2 2m-7.61 7.61a5.5 5.5 0 1 1-7.78 7.78 5.5 5.5 0 0 1 7.78-7.78zm0 0L15.5 7.5m0 0l3 3L22 7l-3-3m-3.5 3.5L19 4'/></svg>")}
.ico-file-text{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><path d='M14 2H6a2 2 0 00-2 2v16a2 2 0 002 2h12a2 2 0 002-2V8z'/><polyline points='14 2 14 8 20 8'/><line x1='8' y1='13' x2='16' y2='13'/><line x1='8' y1='17' x2='16' y2='17'/><line x1='8' y1='9' x2='10' y2='9'/></svg>")}
.ico-lock-list{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='11' width='18' height='11' rx='2'/><path d='M7 11V7a5 5 0 0 1 5-5 5 5 0 0 1 5 5'/><line x1='9' y1='16' x2='15' y2='16'/><line x1='9' y1='19' x2='15' y2='19'/></svg>")}
.ico-ci-menu{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='4 17 10 11 4 5'/><line x1='12' y1='19' x2='20' y2='19'/></svg>")}
.ico-router{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='5' width='18' height='14' rx='2'/><rect x='6' y='8' width='12' height='8' rx='1'/><path d='M9 12v3M11 11v4M13 11v4M15 12v3'/></svg>")}
.ico-neighbors{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><rect x='2' y='2' width='7' height='7' rx='1'/><rect x='15' y='2' width='7' height='7' rx='1'/><rect x='2' y='15' width='7' height='7' rx='1'/><rect x='15' y='15' width='7' height='7' rx='1'/><path d='M9 5.5h6M9 18.5h6M5.5 9v6M18.5 9v6'/></svg>")}
.ico-smartportal{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='16 16 12 12 8 16'/><line x1='12' y1='12' x2='12' y2='21'/><path d='M20.39 18.39A5 5 0 0018 9h-1.26A8 8 0 103 16.3'/></svg>")}
.ico-snmp{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><rect x='8' y='2' width='8' height='5' rx='1'/><line x1='12' y1='7' x2='12' y2='10'/><line x1='6' y1='10' x2='18' y2='10'/><line x1='6' y1='10' x2='6' y2='13'/><line x1='18' y1='10' x2='18' y2='13'/><rect x='3' y='13' width='6' height='5' rx='1'/><rect x='15' y='13' width='6' height='5' rx='1'/></svg>")}

/* Action icons */
.ico-x{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><line x1='18' y1='6' x2='6' y2='18'/><line x1='6' y1='6' x2='18' y2='18'/></svg>")}
.ico-check{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>")}
.ico-funnel{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><polygon points='22 3 2 3 10 12.46 10 19 14 21 14 12.46 22 3'/></svg>")}
.ico-funnel-solid{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black' stroke='black' stroke-width='1.5' stroke-linejoin='round'><polygon points='22 3 2 3 10 12.46 10 19 14 21 14 12.46 22 3'/></svg>")}
.ico-chevron-left{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='15 18 9 12 15 6'/></svg>")}
.ico-external-link{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><path d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'/><polyline points='15 3 21 3 21 9'/><line x1='10' y1='14' x2='21' y2='3'/></svg>")}
.ico-trash{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='3 6 5 6 21 6'/><path d='M19 6l-1 14a2 2 0 0 1-2 2H8a2 2 0 0 1-2-2L5 6'/><path d='M10 11v6'/><path d='M14 11v6'/><path d='M9 6V4a2 2 0 0 1 2-2h2a2 2 0 0 1 2 2v2'/></svg>")}
.ico-undo{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='4 7 4 12 9 12'/><path d='M5.5 17a8 8 0 1 0 1.7-8.3L4 12'/></svg>")}
.ico-dots-v{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black' stroke='none'><circle cx='12' cy='6' r='1.6'/><circle cx='12' cy='12' r='1.6'/><circle cx='12' cy='18' r='1.6'/></svg>")}
.ico-user{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='8' r='4'/><path d='M4 20c0-4 3.6-7 8-7s8 3 8 7'/></svg>")}

/* Lock icons (two states) */
.ico-lock-open{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='11' width='18' height='11' rx='2' fill='black'/><path d='M7 11V7a5 5 0 0 1 5-5 5 5 0 0 1 5 5'/></svg>")}
.ico-lock-closed{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='11' width='18' height='11' rx='2'/><path d='M7 11V7a5 5 0 0 1 10 0v4'/></svg>")}

/* Theme toggle icons */
.ico-theme-system{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='2' y='3' width='20' height='14' rx='2'/><path d='M8 21h8M12 17v4'/></svg>")}
.ico-theme-dark{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M21 12.79A9 9 0 1 1 11.21 3 7 7 0 0 0 21 12.79z'/></svg>")}
.ico-theme-light{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='5'/><line x1='12' y1='1' x2='12' y2='3'/><line x1='12' y1='21' x2='12' y2='23'/><line x1='4.22' y1='4.22' x2='5.64' y2='5.64'/><line x1='18.36' y1='18.36' x2='19.78' y2='19.78'/><line x1='1' y1='12' x2='3' y2='12'/><line x1='21' y1='12' x2='23' y2='12'/><line x1='4.22' y1='19.78' x2='5.64' y2='18.36'/><line x1='18.36' y1='5.64' x2='19.78' y2='4.22'/></svg>")}

/* Main-nav icons (sidenav) */
.ico-grid{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='3' width='7' height='7' rx='1'/><rect x='14' y='3' width='7' height='7' rx='1'/><rect x='3' y='14' width='7' height='7' rx='1'/><rect x='14' y='14' width='7' height='7' rx='1'/></svg>")}
.ico-input-arrow{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><path d='M15 3h4a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2h-4'/><polyline points='10 17 15 12 10 7'/><line x1='15' y1='12' x2='3' y2='12'/></svg>")}
.ico-cross-split{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><line x1='4' y1='5' x2='20' y2='19'/><polyline points='15 18 20 19 18 14'/><line x1='4' y1='19' x2='20' y2='5'/><polyline points='18 10 20 5 15 6'/></svg>")}
.ico-logout{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><path d='M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4'/><polyline points='16 17 21 12 16 7'/><line x1='21' y1='12' x2='9' y2='12'/></svg>")}
.ico-cam-slot{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round'><rect x='2' y='5' width='20' height='14' rx='2'/><path d='M12 5v14M7 9h3M7 12h3M7 15h2'/></svg>")}
.ico-globe{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='10'/><line x1='2' y1='12' x2='22' y2='12'/><path d='M12 2a15.3 15.3 0 0 1 4 10 15.3 15.3 0 0 1-4 10 15.3 15.3 0 0 1-4-10 15.3 15.3 0 0 1 4-10z'/></svg>")}
.ico-gear{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round'><circle cx='12' cy='12' r='3'/><path d='M19.4 15a1.65 1.65 0 00.33 1.82l.06.06a2 2 0 01-2.83 2.83l-.06-.06a1.65 1.65 0 00-1.82-.33 1.65 1.65 0 00-1 1.51V21a2 2 0 01-4 0v-.09A1.65 1.65 0 009 19.4a1.65 1.65 0 00-1.82.33l-.06.06a2 2 0 01-2.83-2.83l.06-.06A1.65 1.65 0 004.68 15a1.65 1.65 0 00-1.51-1H3a2 2 0 010-4h.09A1.65 1.65 0 004.6 9a1.65 1.65 0 00-.33-1.82l-.06-.06a2 2 0 112.83-2.83l.06.06A1.65 1.65 0 009 4.68a1.65 1.65 0 001-1.51V3a2 2 0 014 0v.09a1.65 1.65 0 001 1.51 1.65 1.65 0 001.82-.33l.06-.06a2 2 0 012.83 2.83l-.06.06A1.65 1.65 0 0019.4 9a1.65 1.65 0 001.51 1H21a2 2 0 010 4h-.09a1.65 1.65 0 00-1.51 1z'/></svg>")}

/* Toast / status icons */
.ico-triangle-warn{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M10.29 3.86L1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z'/><line x1='12' y1='9' x2='12' y2='13'/><line x1='12' y1='17' x2='12.01' y2='17'/></svg>")}
.ico-circle-x{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='10'/><line x1='15' y1='9' x2='9' y2='15'/><line x1='9' y1='9' x2='15' y2='15'/></svg>")}
.ico-circle-i{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='10'/><line x1='12' y1='16' x2='12' y2='12'/><line x1='12' y1='8' x2='12.01' y2='8'/></svg>")}
.ico-help{--ico:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='10'/><path d='M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3'/><line x1='12' y1='17' x2='12.01' y2='17'/></svg>")}

/* === UTILITY CLASSES (layout primitives + initial-state hiding) === */
/* !important on .is-hidden: standard utility must beat any component's display:block/flex/grid */
.is-hidden{display:none!important}
.pr-empty .pr-name{color:var(--t3)}
.pr-name.is-disabled{color:var(--t4)}
/* Reboot button: centered icon + wider gap than default .btn-danger */
.btn-danger.btn-center-lg{justify-content:center;gap:1rem}
/* Spacing utilities — prefer adjusting parent flex/grid gap; use these only
   where a single child needs a one-off offset that can't be solved that way. */
.mt-6{margin-top:6px}
.mt-10{margin-top:10px}
.mt-12{margin-top:12px}
.mb-12{margin-bottom:12px}
.mb-16{margin-bottom:16px}
.ml-4{margin-left:4px}
.fw-400{font-weight:400}
.w-100{width:100px}

/* === REBOOT OVERLAY (System > Reboot) === */
@keyframes spin{to{transform:rotate(360deg)}}
.reboot-overlay{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.85);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}
.reboot-overlay-icon{animation:spin 2s linear infinite;color:var(--warn)}
.reboot-overlay-msg{color:#e6edf3;font-size:1.125rem;font-weight:500}
.reboot-overlay-bar{width:280px;height:6px;border-radius:3px;background:rgba(255,255,255,.12)}
.reboot-overlay-barfill{width:0;height:100%;border-radius:3px;background:var(--warn);transition:width .5s linear}
.reboot-overlay-barfill.done{background:var(--ok)}
.reboot-overlay-timer{color:var(--t3);font-size:.875rem;font-family:var(--mono)}
