@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}
*{margin:0;padding:0;box-sizing:border-box}
::selection{background:var(--accent);color:white}
:root{
  --bg0:#0a0d12;--bg:#0e1117;--bg2:#161b22;--bg3:#1c2129;--bg4:#242b35;--bg5:#2d3545;
  --t1:#e6edf3;--t2:#8b949e;--t3:#565e68;--t4:#3a424d;
  --bd:#222a35;--bd1:#293240;--bd2:#2e3844;--bd3:#3a4555;
  --accent:#239591;--accent-dark:hsl(178,62%,28%);--accent-light:hsl(178,58%,46%);--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);--wbr:rgba(240,173,78,.2);
  --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);
  --font:'Inter',system-ui,sans-serif;
  --mono:'Cascadia Code','JetBrains Mono','Fira Code',monospace;
  --r:6px;--r2:10px;
  --sidebar-w:11rem;
  --header-h:56px;
}
html,body{height:100%;height:100dvh;overflow:hidden;font-family:var(--font);background:var(--bg0);color:var(--t1);font-size:16px;-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='%23565e68' 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}
input:focus-visible,select:focus-visible{border-color:var(--focus-clr);box-shadow:var(--focus-ring)}
.dup{color:var(--warn) !important;border-color:var(--warn) !important}
.dup-icon{color:var(--warn);margin-left:4px;font-size:.875rem}
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:.875rem;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:.875rem;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)}
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}

.app{display:grid;grid-template-columns:auto minmax(0,1fr);grid-template-rows:var(--header-h) minmax(0,1fr);height:100vh;height:100dvh}

/* === HEADER === */
.g-header{grid-column:1/-1;display:flex;align-items:center;justify-content:space-between;padding:0 24px 0 0;background:var(--bg);border-bottom:1px solid var(--bd);z-index:10;min-width:0}
.gh-left{display:flex;align-items:center;height:100%;min-width:0}
.gh-logo{width:var(--sidebar-w);height:100%;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:2px;padding:0 20px;border-right:1px solid var(--bd);flex-shrink:0;text-decoration:none;color:inherit;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-img{height:24px;width:auto;flex-shrink:0;transition:opacity .3s ease,max-width .3s ease,max-height .3s ease;max-width:120px;max-height:24px}
.gh-logo-sub{font-size:.75rem;color:var(--t3);transition:opacity .3s ease,max-width .3s ease,max-height .3s ease;white-space:nowrap;max-width:120px;max-height:1.2em;overflow:hidden}
.gh-logo-icon{width:28px;height:28px;object-fit:contain;display:none}
.gh-breadcrumb{display:flex;align-items:center;gap:8px;padding:0 20px;font-size:1rem;color:var(--t3);min-width:0;overflow:hidden}
.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{display:flex;align-items:center;gap:16px;flex-shrink:0}
.gh-tag{font-size:.875rem;color:var(--t3);display:flex;align-items:center;gap:6px;white-space:nowrap}
.gh-tag-label{color:var(--t3)}
.gh-user{display:flex;align-items:center;gap:6px;font-size:.875rem;color:var(--t2);padding:4px 10px;background:var(--bg3);border-radius:var(--r);white-space:nowrap}
.gh-timer{font-family:var(--mono);font-size:.875rem;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}
.gh-dot{width:11px;height:11px;border-radius:50%;animation:pulse 2.5s ease-in-out infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* === SIDEBAR COLLAPSE TOGGLE (inside nav) === */
.nav-collapse-toggle{background:none;border:none;color:var(--t3);cursor:pointer;display:flex;align-items:center;gap:10px;padding:10px 20px;font-size:1rem;width:100%;border-left:3px solid transparent;transition:color .12s,background .12s,padding .3s cubic-bezier(.4,0,.2,1)}
.nav-collapse-toggle:hover{color:var(--t1);background:var(--bg3)}
.nav-collapse-toggle svg{width:18px;height:18px;flex-shrink:0;transition:transform .3s cubic-bezier(.4,0,.2,1)}
.sidebar-collapsed .nav-collapse-toggle{justify-content:center;padding:10px 0}
.sidebar-collapsed .nav-collapse-toggle svg{transform:scaleX(-1)}

/* Manual sidebar collapse */
.sidebar-collapsed .sidenav{width:52px}
.sidebar-collapsed .gh-logo{width:52px;align-items:center;justify-content:center;padding:0}
.sidebar-collapsed .nav-group-label{opacity:0;max-height:0;padding-top:0;padding-bottom:0}
.sidebar-collapsed .nav-label{opacity:0;max-width:0}
.sidebar-collapsed .gh-logo-img,.sidebar-collapsed .gh-logo-sub{opacity:0;max-width:0;max-height:0;overflow:hidden}
.sidebar-collapsed .gh-logo-icon{display:block}
.sidebar-collapsed .nav-item{justify-content:center;padding:10px 0}
.sidebar-collapsed .theme-btn{justify-content:center;padding:10px 0}
.sidebar-collapsed .nw-sidebar{width:52px}
.sidebar-collapsed .nw-nav-item{justify-content:center;padding:10px 0}
.sidebar-collapsed .nw-nav-label{opacity:0;max-width:0}
.sidebar-collapsed .tl-info,.sidebar-collapsed .tu-sb-title{display:none}
.sidebar-collapsed .tu-body{grid-template-columns:80px minmax(0,1fr) clamp(280px,21vw,380px)}

/* === SIDE NAV === */
.sidenav{grid-column:1;grid-row:2;background:var(--bg);border-right:1px solid var(--bd);display:flex;flex-direction:column;padding:8px 0;overflow-y:auto;width:var(--sidebar-w);transition:width .3s cubic-bezier(.4,0,.2,1);overflow-x:hidden;box-sizing:border-box}
/* Section labels: uppercase, structural — not body text */
.nav-group-label{font-size:.75rem;font-weight:500;color:var(--t4);text-transform:uppercase;letter-spacing:1px;padding:18px 20px 6px;user-select:none;overflow:hidden;transition:opacity .3s ease,max-height .3s ease,padding .3s ease;max-height:3em}
.nav-label{overflow:hidden;white-space:nowrap;transition:opacity .3s ease,max-width .3s ease;max-width:10rem}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;font-size:1rem;color:var(--t2);cursor:pointer;transition:color .1s,background .1s,padding .3s cubic-bezier(.4,0,.2,1);border-left:3px solid transparent;margin:1px 0;text-decoration:none}
.nav-item:hover{background:var(--bg3);color:var(--t1)}
.nav-item.active{color:var(--accent);background:var(--abg);border-left-color:var(--accent)}
.nav-item svg{width:18px;height:18px;flex-shrink:0}
.nav-spacer{flex:1}
.nav-divider{height:1px;background:var(--bd);margin:8px 16px}
.nav-item.bottom{color:var(--t3)}

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

/* === OVERVIEW / DASHBOARD === */
.p-overview{padding:clamp(16px,2vw,24px);overflow-y:auto;height:100%;display:flex;flex-direction:column;gap:16px}
.ov-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:8px}
.ov-metric{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r2);padding:16px 18px;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:.75rem;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.ov-m-val{font-size:28px;font-weight:500}
.ov-m-unit{font-size:1rem;color:var(--t3);font-weight:400}
.ov-m-sub{font-size:.875rem;color:var(--t3);margin-top:4px}
.ov-mode-row{display:flex;justify-content:space-between;align-items:center;gap:8px}
.ov-mode-badges{display:flex;gap:4px}
.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:'Cascadia Code','JetBrains Mono','Fira Code',monospace;font-size:.875rem;color:var(--t3);flex-shrink:0}
.ov-alarm-msg{font-size:.875rem;color:var(--t1)}
.ov-alarm-level{font-size:.75rem;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:.875rem;color:var(--t3);padding:6px 0}

/* Dashboard metric card color tints */
.ov-metric:nth-child(1){background:color-mix(in srgb,var(--accent) 6%,var(--bg2))}
.ov-metric:nth-child(2){background:color-mix(in srgb,var(--blue) 6%,var(--bg2))}
.ov-metric:nth-child(3){background:color-mix(in srgb,var(--purple) 6%,var(--bg2))}
.ov-metric:nth-child(4){background:color-mix(in srgb,var(--accent) 8%,var(--bg2))}
.ov-metric:nth-child(5){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;column-gap:16px;row-gap:24px;align-items:start;margin-top:24px}
.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:.75rem;font-weight:500;padding:2px 6px;border-radius:3px}

/* Stream type badge (SPTS / MPTS) */
.ov-s-proto{font-size:.75rem;font-weight:500;padding:3px 7px;border-radius:3px;background:var(--abg);color:var(--accent);white-space:nowrap;display:inline-block}
.ov-s-proto.mpts{background:var(--pbg);color:var(--purple)}
/* Card title count pill */
.ov-ct-count{font-size:.75rem;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:.875rem;min-width:800px}
.tt thead th{padding:7px 10px;text-align:left;font-size:.75rem;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:8px 10px;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(--bg3)}
.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-pip{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.tt-pip.ok{background:var(--ok)}
.tt-pip.warn{background:var(--warn)}
.tt-pip.err{background:var(--err)}
.tt-pip.standby{background:var(--t4)}
.tt-mono{font-family:var(--mono);color:var(--t2);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(--t2)}
.tt-na{color:var(--t4);text-align:center;font-size:.875rem}

/* Active streams table */
.st-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.st{width:100%;border-collapse:collapse;font-size:.875rem;min-width:600px}
.st thead th{padding:7px 10px;text-align:left;font-size:.75rem;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:9px 10px;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(--bg3)}
.st .st-name{font-weight:500;color:var(--t1)}
.st .st-mono{font-family:var(--mono);color:var(--t2);white-space:nowrap}
.st .st-src{display:inline-block;font-size:.75rem;font-weight:500;padding:2px 6px;border-radius:3px;background:var(--bg4);color:var(--t1);font-family:var(--mono);text-decoration:none}
.st .st-src-link{color:var(--t1);text-decoration:none;font-family:var(--mono);font-weight:500;display:inline-flex;align-items:center;gap:4px}
.st .st-src-link:hover{color:var(--accent)}
.st .st-br{font-family:var(--mono);color:var(--t2);white-space:nowrap}
.st .st-br small{color:var(--t3);font-size:.75rem}

.ov-ci-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}
.ov-ci{background:var(--bg3);border-radius:var(--r);padding:10px 12px;display:flex;flex-direction:column;gap:4px;border-left:3px solid transparent;text-decoration:none;color:inherit;transition:background .12s}
a.ov-ci:hover{background:var(--bg4)}
.ov-ci-id{font-size:.875rem;color:var(--t2);font-weight:500}
.ov-ci-status{font-size:.75rem;font-weight:500}
.ov-ci.ci-active{border-left-color:var(--ok)}
.ov-ci.ci-warn{border-left-color:var(--warn)}
.ov-ci.ci-empty{opacity:.4}

/* === INPUT RF PAGE === */
.p-tuner{display:flex;flex-direction:column;flex:1;min-height:0}
.tu-actionbar{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:52px;background:var(--bg2);border-bottom:1px solid var(--bd);flex-shrink:0;gap:12px;min-width:0}
.tu-ab-left{display:flex;align-items:center;gap:10px;font-size:1rem;min-width:0;overflow:hidden}
.tu-ab-left span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tu-ab-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.ab-next-hint{display:none;align-items:center;gap:6px;font-size:.875rem;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,opacity .5s;opacity:0;pointer-events:none}
.ab-next-hint.visible{opacity:1;pointer-events:auto}
.ab-next-hint:hover{background:var(--abg2);border-color:var(--accent)}
.ab-next-hint svg{flex-shrink:0}
@media (min-width:1400px){.ab-next-hint{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-dark);color:var(--t1);padding:.375rem .75rem;font-size:1rem}
.btn-accent:hover{background:var(--accent)}
.cd{width:8px;align-self:stretch;border-radius:999px;background:var(--warn);display:none;flex-shrink:0}

.tu-body{display:grid;grid-template-columns:160px minmax(0,1fr) clamp(280px,21vw,380px);flex:1;min-height:0;overflow:hidden}

/* 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:.75rem;font-weight:500;color:var(--t4);text-transform:uppercase;letter-spacing:.8px;padding:6px 16px 10px}
.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}
/* Badge */
.tl-type{font-size:.75rem;font-weight:500;padding:2px 5px;border-radius:3px;text-align:center}
.tl-info{min-width:0}
.tl-freq{font-family:var(--mono);font-size:.875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.tl-src{font-size:.8125rem;color:var(--t3);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pip{width:11px;height:11px;border-radius:50%;justify-self:center;flex-shrink:0}
.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 1fr;gap:14px;flex:1;align-content:start}
.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:.875rem;color:var(--t3);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:.875rem;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:300;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:.75rem;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:.875rem;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:.75rem;color:var(--t3);margin-top:2px}
.satdb-no-match{padding:12px;font-size:.875rem;color:var(--t3);text-align:center}
.satdb-overflow{padding:6px 12px;font-size:.75rem;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}
.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:.875rem;color:var(--t3);width:44px;flex-shrink:0;white-space:nowrap}
.sig-track{flex:1;height:5px;background:var(--bg4);border-radius:3px;overflow:hidden}
.sig-fill{height:100%;border-radius:3px}
.sig-v{font-family:var(--mono);font-size:.875rem;font-weight:500;min-width:64px;text-align:right;margin-left:auto;white-space:nowrap}
.scan-progress{display:flex;align-items:center;gap:10px;padding:1rem 0;color:var(--t2);font-size:.875rem}
.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)}}

/* Toast notifications */
.toast-container{position:fixed;bottom:1rem;right:1rem;z-index:9999;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:.875rem;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}
/* Badges */
.pr-name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pr-fta{font-size:.75rem;font-weight:500;padding:2px 6px;border-radius:3px;background:var(--okbg);color:var(--ok)}
.pr-ca{font-size:.75rem;font-weight:500;padding:2px 6px;border-radius:3px;background:var(--wbg);color:var(--warn)}
.pr-type{font-size:.75rem;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)}
.btn-full{width:100%;margin-top:12px;background:var(--bg4);border:1px solid var(--bd2);color:var(--t2);padding:.375rem .75rem;font-size:1rem;text-decoration:none;display:block;text-align:center;border-radius:var(--r);line-height:1.375}
.btn-full:hover{border-color:var(--bd3);color:var(--t1)}

/* === PLACEHOLDER === */

/* === NETWORK PAGE === */
.nw-body{display:flex;flex:1;min-height:0;overflow:hidden}
.nw-sidebar{width:11rem;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;gap:10px;padding:10px 16px;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 svg{width:18px;height:18px;flex-shrink:0}
.nw-nav-label{overflow:hidden;white-space:nowrap;transition:opacity .3s ease,max-width .3s ease;max-width:10rem}
.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,2vw,24px);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:520px}
.kv-rows{display:flex;flex-direction:column;gap:1rem}
.kv-row{display:flex;align-items:center;gap:12px}
.kv-row-label{font-size:.875rem;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{width:100%;border-collapse:collapse;table-layout:fixed;min-width:480px}
.nw-eth-table thead th{padding:0 12px 10px;font-size:.75rem;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 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:.875rem;color:var(--t3);white-space:nowrap}
.nw-eth-table tbody tr:last-child td{border-bottom:none}
.nw-link{display:inline-flex;align-items:center;gap:7px;font-size:.875rem;font-weight:500}
.nw-link-up{color:var(--ok)}.nw-link-down{color:var(--err)}
.nw-ro-val{font-size:.875rem;color:var(--t2);display:block;padding:.375rem 0}
.nw-mac{font-family:var(--mono);font-size:.875rem;color:var(--t2);display:block;padding:.375rem 0}
.nw-nb{width:100%;border-collapse:collapse;font-size:.875rem}
.nw-nb th{padding:6px 10px;text-align:left;font-size:.75rem;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(--bg3)}
.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:.875rem}
.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:.875rem;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:.875rem;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:.875rem;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:.875rem;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}
.dev-action-equal>.btn-ghost{flex:1}
.btn-danger{background:rgba(232,93,111,.1);border:1px solid rgba(232,93,111,.25);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}
.btn-danger:hover{background:rgba(232,93,111,.2);border-color:var(--err)}
.btn-danger:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(232,93,111,.3)}
.btn-block{width:100%;display:block}
.ab-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;display:inline-block}
.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-right{text-align:right!important}
.fw-500{font-weight:500}
.btn-file{display:inline-flex;align-items:center;gap:6px;cursor:pointer}
.file-name-hint{font-size:.875rem;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:.875rem;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:520px;display:flex;flex-direction:column}
.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:.875rem}
.dev-lic-item:last-child{border-bottom:none}
.dev-lic-name{color:var(--t2)}
.dev-lic-badge-ok{font-size:.75rem;font-weight:500;color:var(--ok);background:var(--okbg);padding:2px 8px;border-radius:3px}
.dev-lic-badge-no{font-size:.75rem;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;padding:clamp(16px,2vw,24px)}
.tsp-split-layout{flex:1;min-height:0;display:flex;overflow:hidden}
.tsp-split-left{flex:1 1 50%;min-height:0;min-width:200px;display:flex}
.tsp-split-right{flex:1 1 50%;min-height:0;min-width:200px;display:flex}
.tsp-resizer{width:6px;cursor:col-resize;background:transparent;flex-shrink:0;position:relative;margin:0 4px;border-radius:3px;transition:background .15s}
.tsp-resizer::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:2px;height:32px;background:var(--bd2);border-radius:1px;transition:background .15s,height .15s}
.tsp-resizer:hover{background:var(--abg)}
.tsp-resizer:hover::after,.tsp-resizer.active::after{background:var(--accent);height:48px}
.tsp-resizer.active{background:var(--abg)}
.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}
/* 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;gap:0;flex-shrink:0;overflow:visible}
.tsp-assign-tab{flex:1;padding:10px 14px;text-align:center;font-size:.75rem;font-weight:500;color:var(--t3);background:var(--bg);border:1px solid var(--bd);border-radius:0;cursor:pointer;font-family:inherit;transition:color .15s,background .15s,font-size .15s}
.tsp-assign-tab:first-child{border-radius:10px 0 0 0}
.tsp-assign-tab:last-child{border-radius:0 10px 0 0}
.tsp-assign-tab:only-child{border-radius:10px 10px 0 0}
.tsp-assign-tab:hover{color:var(--t1);background:var(--bg3)}
.tsp-assign-tab:active{transform:none}
.tsp-assign-tab.active{font-size:.875rem}
.tsp-assign-tab.active[data-tab="mpts"]{color:var(--accent);background:var(--abg);border:1px solid var(--abr)}
.tsp-assign-tab.active[data-tab="cam"]{color:var(--warn);background:var(--wbg);border:1px solid var(--wbr,rgba(220,148,0,.22))}
.tsp-assign-tab.active[data-tab="lcn"]{color:var(--blue);background:var(--bbg);border:1px solid rgba(88,166,255,.22)}
.tsp-assign-tab.active[data-tab="sipsi"]{color:var(--purple);background:var(--pbg);border:1px solid rgba(188,140,255,.22)}
.tsp-assign-body{flex:1;overflow-y:auto;padding: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(--bg3)}
.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:.875rem}
.tsp-assign-item-count{font-size:.875rem;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:.875rem;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:.875rem}
.tsp-assign-svc-table th{padding:6px 10px;text-align:left;font-size:.75rem;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(--bg3)}
.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:.875rem;color:var(--t3);border-bottom:1px solid var(--bd)}
.tsp-assign-lcn-bulk{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--bd)}
.tsp-assign-lcn-bulk .tsp-bulk-start{width:4rem}
.tsp-assign-lcn-table-wrap{flex:1;overflow-y:auto}
.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:.875rem;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:.75rem;color:var(--t3);margin-top:4px}
/* Assign arrow button in table */
.tsp-assign-btn{background:var(--accent-dark);border:1px solid transparent;color:var(--t1);cursor:pointer;padding:.25rem .375rem;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;line-height:0;vertical-align:middle;transition:background .1s}
.tsp-assign-btn svg{display:block}
.tsp-assign-btn:hover{background:var(--accent)}
[data-theme="light"] .tsp-assign-btn{background:var(--accent);color:#fff}
[data-theme="light"] .tsp-assign-btn:hover{background:var(--accent-dark)}
.tsp-assign-btn-group{margin-left:auto;margin-right:12px}
.tsp-tuner-tabs{display:flex;align-items:flex-start;gap:8px;padding:10px 14px;flex-shrink:0;border-bottom:1px solid var(--bd);background:var(--bg)}
.tsp-tuner-rows{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}
.tsp-tuner-row{display:flex;gap:4px;flex-wrap:wrap}
.mpts-bar-ok{background:var(--ok)}
.mpts-bar-warn{background:var(--warn)}
.mpts-bar-err{background:var(--err)}
.tsp-tab{background:var(--bg3);border:1px solid transparent;color:var(--t2);font-size:.875rem;padding:3px 11px;border-radius:4px;cursor:pointer;font-family:inherit;transition:background .15s,color .15s}
.tsp-tuner-row .tsp-tab{min-width:2.5rem;text-align:center}
.tsp-tab:hover{background:var(--bg4);color:var(--t1)}
.tsp-tab.active{background:var(--bg4);color:var(--t1);border-color:var(--bd3);font-weight:500}
.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 th{padding:7px 12px;text-align:left;font-size:.75rem;font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--bd);background:var(--bg);position:sticky;top:0;z-index:1;white-space:nowrap}
.tsp-svc-table th:first-child,.tsp-svc-table td:first-child{width:36px;padding-right:0}
.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(--bg);border-bottom:1px solid var(--bd);border-top:1px solid var(--bd);vertical-align:middle}
.tsp-group-row:first-child td{border-top:none}
.tsp-group-hd{display:flex;align-items:center;gap:8px}
.tsp-group-badge{display:inline-flex;align-items:center;gap:.5rem;padding:1px 7px;border-radius:3px;font-size:.75rem;font-weight:500;background:var(--bg4);color:var(--t1);text-decoration:none}
.tsp-group-info{color:var(--t3);font-family:var(--mono);font-size:.75rem}
.tsp-sel-btn{background:var(--bg3);border:1px solid var(--bd);color:var(--t2);font-size:.75rem;cursor:pointer;padding:2px 8px;border-radius:4px;font-family:inherit}
.tsp-sel-btn:hover{background:var(--bg4);color:var(--t1);border-color:var(--bd2)}
.tsp-svc-row{cursor:default}
.tsp-svc-row:hover td{background:var(--bg3)}
.tsp-svc-row.row-active td{background:var(--abg)}
.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)}
.tsp-lcn-in{width:5rem !important;font-family:var(--mono);text-align:center}
.tsp-svc-name{color:var(--t1)}
.tsp-svc-name.dimmed{color:var(--t3)}
.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-th-detail,.tsp-detail-cell{width:28px;text-align:center;padding:0 2px}
.tsp-detail-btn{background:var(--bd1);border:1px solid var(--bd2);color:var(--t2);cursor:pointer;padding:2px 4px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;line-height:0;transition:color .15s,background .15s,border-color .15s}
.tsp-detail-btn:hover{color:var(--t1);background:var(--bd3)}
.tsp-detail-btn.open{color:var(--accent);background:var(--abg);border-color:var(--accent)}
.tsp-lcn-gap-row td{color:var(--t4);font-size:.875rem;font-style:italic;padding:4px 12px;border-bottom:1px solid var(--bd)}
.lcn-drag{cursor:grab;touch-action:none;user-select:none}
.lcn-drag:active{cursor:grabbing}
.lcn-dragging{position:fixed;z-index:50;background:var(--bg2);opacity:.9;box-shadow:0 4px 16px rgba(0,0,0,.3);pointer-events:none}
.lcn-dragging td{border:none}
.lcn-placeholder td{background:var(--abg);border:2px dashed var(--accent);border-radius:3px}
.lcn-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:100}
.lcn-modal{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r);padding:24px;min-width:320px;max-width:400px}
.lcn-modal-title{font-size:1rem;font-weight:500;color:var(--t1);margin-bottom:12px}
.lcn-message{font-size:.875rem;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:.75rem;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-sd{background:var(--abg);color:var(--accent)}
.svc-badge-hd{background:var(--bbg);color:var(--blue)}
.svc-badge-uhd{background:var(--pbg);color:var(--purple)}
.svc-badge-sradio{background:var(--bg3);color:var(--t2)}
.svc-badge-sdata{background:var(--bg3);color:var(--t3)}
.svc-badge-fta{background:var(--okbg);color:var(--ok)}
.svc-badge-ca{background:var(--wbg);color:var(--warn)}
.tsp-cam-sel{width:auto}
.tsp-edit-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{background:var(--bg4);color:var(--t1)}
.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:10;box-shadow:-4px 0 16px rgba(0,0,0,.2)}
.tsp-drawer.open{width:100%;max-width:500px}
/* Overlay variant — slides over the table from the left */
.tsp-drawer-overlay{position:absolute;left:0;top:0;height:100%;z-index:10;border-left:none;border-right:1px solid var(--bd);box-shadow:4px 0 16px rgba(0,0,0,.2)}
.tsp-drawer-overlay.open{width:100%;max-width:480px}
.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:.75rem;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:.75rem;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 th{font-size:.7rem;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-num-in{width:5rem !important;font-family:var(--mono)}
.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-mode-sel{width:auto}
.tsp-add-pid-btn{display:inline-flex;align-items:center;gap:5px;color:var(--accent);cursor:pointer;background:transparent;border:none;padding:4px 0 0;font-family:inherit}
.tsp-add-pid-btn:hover{color:var(--accent-light)}
.tsp-bulk-controls{display:flex;flex-direction:column;gap:1rem;padding:14px;margin-bottom:2rem;border-bottom:1px solid var(--bd)}
.tsp-bulk-row{display:flex;align-items:center;gap:8px}
.tsp-bulk-row .btn-ghost{margin-left:8px}
.tsp-bulk-row .fl{margin-bottom:0;min-width:70px;flex-shrink:0}
.tsp-bulk-row>:nth-child(2){width:8rem;flex:none}
.tsp-bulk-octet{font-family:var(--mono)}
.tsp-bulk-start{font-family:var(--mono)}
.bulk-mcast-start{width:7rem!important}
.tsp-sortable{cursor:pointer;user-select:none;color:var(--accent) !important}
.tsp-sortable:hover{color:var(--accent-light) !important}
.tsp-sort-icon{vertical-align:middle;margin-left:2px;opacity:.7}
.tsp-sortable:hover .tsp-sort-icon{opacity:1}
.tsp-th-filter{font-size:.75rem !important;padding:2px 1.5rem 2px 4px !important;height:auto;background-position:right .25rem center !important;background-size:10px !important;border-color:transparent;background-color:transparent;color:var(--accent);text-transform:uppercase;letter-spacing:.04em;font-weight:500;width:auto}
.tsp-th-filter:hover{color:var(--accent-light)}
.tsp-streams-table{width:100%;border-collapse:collapse;font-size:1rem}
.tsp-streams-table th{padding:7px 12px;text-align:left;font-size:.75rem;font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--bd);white-space:nowrap}
.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 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:.35}
.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:.75rem;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:.875rem}
.tsp-nit-mod-table th{padding:6px 10px;text-align:left;font-size:.75rem;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:.875rem}
.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:.875rem;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:.875rem}
.tsp-pid-unreg-tbl th{padding:6px 10px;text-align:left;font-size:.75rem;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}
.ab-count{font-size:.875rem;color:var(--t3);margin-left:8px}
.ov-card-t-actions{display:flex;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:6px}
.tsp-export-sel{cursor:pointer;width:auto;background:transparent;border:1px solid var(--bd2);color:var(--t2);padding:.375rem 2rem .375rem .75rem;font-size:1rem;border-radius:var(--r);font-family:var(--font);font-weight:500;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='%238b949e' 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 .5rem center;background-size:1rem}
.tsp-export-sel:hover{border-color:var(--t3);color:var(--t1)}
.tsp-export-sel option{background:var(--bg2);color:var(--t1)}
[data-theme="light"] .tsp-export-sel{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")}
.btn-sm{font-size:.875rem;padding:4px 10px}
.tsp-empty-cell{text-align:center;padding:16px 10px;font-size:.875rem;color:var(--t3)}
.tsp-unref-desc{width:120px}

/* === CAM PAGE === */
.cam-slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.cam-slot-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.cam-slot-id{font-size:1rem;font-weight:500;color:var(--t1)}
.cam-status-active{display:inline-flex;align-items:center;padding:2px 8px;border-radius:3px;font-size:.75rem;font-weight:500;background:var(--okbg);color:var(--ok)}
.cam-status-error{display:inline-flex;align-items:center;padding:2px 8px;border-radius:3px;font-size:.75rem;font-weight:500;background:var(--ebg);color:var(--err)}
.cam-status-init{display:inline-flex;align-items:center;padding:2px 8px;border-radius:3px;font-size:.75rem;font-weight:500;background:var(--wbg);color:var(--warn)}
.cam-status-empty{font-size:.75rem;font-weight:500;color:var(--t4)}
.cam-slot-empty{opacity:.4}
.cam-slot-hint{font-size:.875rem;color:var(--t3);padding:8px 0}
.cam-slot:not(.cam-slot-empty){display:flex;flex-direction:column}
.cam-slot-actions{margin-top:auto;padding-top:10px;border-top:1px solid var(--bd)}
.cam-slot-actions .btn-ghost{width:100%;color:var(--warn);border-color:var(--warn)}
.cam-slot-actions .btn-ghost:hover{background:var(--wbg)}
.cam-slot-badge{font-size:.75rem;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:.75rem;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:.875rem;transition:background .1s;display:flex;align-items:center}
.cam-menu-item:hover{background:var(--bg4)}
/* 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:.875rem;margin:6px 0 2px 20px}
.cam-pid-table th{padding:4px 12px;text-align:left;font-size:.75rem;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:.875rem;vertical-align:middle}
.cam-svc-table th:first-child,.cam-svc-table td:first-child{width:28px;padding-right:0}
.cam-menu-slot-sel{padding:.375rem .75rem !important;font-size:1rem !important}
.cam-menu-back{margin-top:12px}

/* === RESPONSIVE === */
@media (min-width:1920px){
  .ov-tables-row>.ov-card:first-child{flex:0 0 calc(55% - 8px)}
  .ov-tables-row>.ov-card:last-child{flex:0 0 calc(45% - 8px)}
}
@media (max-width:1360px){
  .gh-right .gh-tag:first-child{display:none}
}
@media (max-width:1100px){
  .tu-form{grid-template-columns:1fr}
}
.btn-aside-toggle{display:none}
@media (max-width:1200px){
  .btn-aside-toggle{display:inline-flex;align-items:center}
  .sidenav{width:52px}
  .gh-logo{width:52px;align-items:center;justify-content:center;padding:0}
  .nav-group-label{opacity:0;max-height:0;padding-top:0;padding-bottom:0}
  .nav-label{opacity:0;max-width:0}
  .gh-logo-img,.gh-logo-sub{opacity:0;max-width:0;max-height:0;overflow:hidden}
  .gh-logo-icon{display:block}
  .tl-info,.tu-sb-title{display:none}
  .nw-sidebar{width:52px}.nw-nav-item{justify-content:center;padding:10px 0}.nw-nav-label{opacity:0;max-width:0}
  .tu-body,.sidebar-collapsed .tu-body{grid-template-columns:80px minmax(0,1fr);position:relative}
  .tu-aside{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;box-shadow:-4px 0 24px rgba(0,0,0,.4)}
  .tu-aside.open{transform:translateX(0)}
  .nav-item{justify-content:center;padding:10px 0}
  .nav-collapse-toggle{justify-content:center;padding:10px 0}
  .theme-btn{justify-content:center;padding:10px 0}
}
/* Mobile: allow minimal scroll (header height) so browser chrome hides */
@media (max-height:768px){
  html,body{height:auto;overflow:auto;overflow-x:hidden}
  .app{height:calc(100dvh + var(--header-h))}
}

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

/* === HELP MODAL === */
.help-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;z-index:200}
.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:0 16px 48px rgba(0,0,0,.3)}
.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:.75rem;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:.875rem;line-height:1.7}
.help-modal-list b{color:var(--t1);font-weight:500}
.help-modal-keys{width:100%;font-size:.875rem;color:var(--t2)}
.help-modal-keys td{padding:4px 0}
.help-modal-keys td:first-child{width:100px;white-space:nowrap}
.help-modal-keys kbd{background:var(--bg3);border:1px solid var(--bd2);border-radius:4px;padding:1px 6px;font-family:var(--mono);font-size:.8rem}
.help-modal-body p{margin:0;font-size:.875rem;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:.875rem;font-weight:500;text-decoration:none;transition:background .15s,border-color .15s}
.help-modal-link:hover{background:var(--bg4);border-color:var(--bd3)}

/* === LIGHT THEME === */
[data-theme="light"]{
  --bg0:#f0f2f5;--bg:#f9fbfd;--bg2:#ffffff;--bg3:#eaeef2;--bg4:#d0d7de;--bg5:#bbc1c9;
  --t1:#1f2328;--t2:#4e5660;--t3:#656d76;--t4:#9198a1;
  --bd:#d0d7de;--bd1:#e8ecf0;--bd2:#c8d0d9;--bd3:#bbc1c9;
  --abg:rgba(35,149,145,.06);--abg2:rgba(35,149,145,.12);--abr:rgba(35,149,145,.30);
  --ok:#1a9a6b;--okbg:rgba(26,154,107,.08);
  --warn:hsl(38,100%,46%);--wbg:rgba(220,148,0,.08);--wbr:rgba(220,148,0,.22);
  --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);
  --focus-clr:hsl(163,70%,38%);--focus-ring:0 0 0 3px hsla(163,70%,38%,.25);
}
[data-theme="light"] select{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")}
[data-theme="light"] .tu-aside{box-shadow:-4px 0 24px rgba(0,0,0,.12)}
[data-theme="light"] .btn-accent{background:var(--accent);color:#fff}
[data-theme="light"] .btn-accent:hover{background:var(--accent-dark)}
[data-theme="light"] .tsp-drawer-overlay{box-shadow:4px 0 16px rgba(0,0,0,.08)}
[data-theme="light"] .tsp-drawer{box-shadow:-4px 0 16px rgba(0,0,0,.08)}
