﻿/* ============================================================
   NeiraOps — Port Mapping Generator (Neira Systems)
   Module: Port Mapping Generator v0.4 Beta
   Design: light-first enterprise SaaS, Neira navy/teal palette
   ============================================================ */

/* ---- Design tokens ---------------------------------------- */
:root{
  --font-sans:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,"SFMono-Regular",monospace;
  --s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:24px;--s6:32px;--s7:48px;
  --radius:8px;--radius-lg:12px;
  --neira-navy:#081F39;
  --neira-navy-deep:#010E29;
  --neira-navy-soft:#152D47;
  --neira-teal:#15899B;
  --neira-teal-bright:#48A2B0;
  --neira-teal-soft:#B8CED5;
  --neira-slate:#32435A;
  --neira-muted:#5D687B;
  --neira-bg:#F8FAFC;
  --neira-surface:#FFFFFF;
  --neira-border:#E2E8F0;
  --site-header-height:68px;
}

html[data-theme="light"]{
  --bg:#F8FAFC;
  --surface:#FFFFFF;
  --surface-2:#F1F5F9;
  --surface-3:#EAF6F8;
  --border:#E2E8F0;
  --border-strong:#CBD5E1;
  --border-faint:#EEF2F6;
  --text:#081F39;
  --text-2:#32435A;
  --text-3:#5D687B;
  --text-faint:#94A3B0;
  --accent:#15899B;
  --accent-soft:#EAF6F8;
  --accent-border:#B8CED5;
  --accent-bright:#48A2B0;
  --ok:#15803D;   --ok-soft:#EAF6EE;   --ok-border:#BFE3C9;
  --warn:#B7791F; --warn-soft:#FBF3E6; --warn-border:#F0DCB4;
  --err:#C2410C;  --err-soft:#FBEEE7; --err-border:#F2D2C0;
  --info:#0369A1; --info-soft:#E7F1F8; --info-border:#BBD7E8;
  --shadow:0 1px 2px rgba(8,31,57,.04),0 1px 3px rgba(8,31,57,.06);
  --shadow-md:0 4px 12px -2px rgba(8,31,57,.08),0 2px 6px -2px rgba(8,31,57,.05);
  color-scheme:light;
}

html[data-theme="dark"]{
  --bg:#010E29;
  --surface:#081F39;
  --surface-2:#0D2745;
  --surface-3:#152D47;
  --border:#1E3A56;
  --border-strong:#2A4D6C;
  --border-faint:#13314D;
  --text:#F8FAFC;
  --text-2:#B8CED5;
  --text-3:#8EA4B1;
  --text-faint:#5D7385;
  --accent:#48A2B0;
  --accent-soft:rgba(21,137,155,.16);
  --accent-border:rgba(72,162,176,.36);
  --accent-bright:#48A2B0;
  --ok:#4ADE80;   --ok-soft:#11241A;   --ok-border:#1F4030;
  --warn:#E0A93B; --warn-soft:#2A2310; --warn-border:#4A3D1A;
  --err:#F2855A;  --err-soft:#2C1810;  --err-border:#4D2C1B;
  --info:#48A2B0; --info-soft:#0C2735; --info-border:#1F4655;
  --shadow:0 1px 2px rgba(0,0,0,.3);
  --shadow-md:0 6px 18px -4px rgba(0,0,0,.5);
  color-scheme:dark;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden}
body{font-family:var(--font-sans);background:var(--bg);color:var(--text);
  font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
.mono{font-family:var(--font-mono)}
.app{display:grid;grid-template-columns:224px 1fr;height:calc(100vh - var(--site-header-height));
  margin-top:var(--site-header-height)}
.hide{display:none!important}


/* ---- Sidebar ---------------------------------------------- */
.side{display:flex;flex-direction:column;min-height:0;overflow:hidden;
  background:var(--surface);border-right:1px solid var(--border)}
.brand{display:flex;align-items:center;gap:var(--s3);padding:var(--s3) var(--s4);
  margin:var(--s3) var(--s3) var(--s2);border-radius:var(--radius-lg);
  background:var(--neira-navy);color:#fff}
.brand .logo{position:relative;overflow:hidden;width:54px;height:34px;border-radius:7px;
  flex:none;display:grid;place-items:center;background:#fff;border:1px solid rgba(255,255,255,.2)}
.brand .logo img{display:block;width:100%;height:100%;object-fit:contain}
.logo-fallback{display:grid;place-items:center;width:100%;height:100%;font-weight:800;font-size:14px;
  letter-spacing:.04em;color:var(--neira-navy);background:#fff}
.logo-fallback[hidden]{display:none}
.brand .name{font-weight:700;font-size:14px;letter-spacing:-.1px;line-height:1;color:#fff}
.nav{display:flex;flex-direction:column;padding:var(--s2) var(--s3);overflow-y:auto;flex:1;min-height:0;gap:1px}
.nav-group{font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--text-faint);
  font-weight:600;padding:var(--s4) var(--s2) var(--s1)}
.nav-group:first-child{padding-top:var(--s2)}
.nav-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;
  padding:7px 10px;border-radius:7px;border:none;cursor:pointer;background:none;
  color:var(--text-2);font-family:inherit;font-size:13px;font-weight:500;
  transition:background .12s,color .12s;white-space:nowrap}
.nav-item:hover{background:var(--surface-3);color:var(--text)}
.nav-item.on{background:var(--accent-soft);color:var(--accent)}
.nav-item .ti{font-size:17px;flex-shrink:0;opacity:.85}
.nav-item.on .ti{opacity:1}
.nav-item .lbl{flex:1;overflow:hidden;text-overflow:ellipsis}
.nav-item .cnt{font-size:11px;font-weight:600;font-family:var(--font-mono);
  min-width:20px;text-align:center;background:var(--surface-3);border-radius:20px;
  padding:1px 7px;color:var(--text-3);flex-shrink:0}
.nav-item.on .cnt{background:#fff;color:var(--accent)}
html[data-theme="dark"] .nav-item.on .cnt{background:var(--accent-border)}

/* ---- Main + topbar ---------------------------------------- */
.main{display:flex;flex-direction:column;min-height:0;overflow:hidden}
.topbar{display:flex;flex-direction:column;align-items:stretch;gap:0;padding:0;
  border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}
.modbar-row{display:flex;align-items:center;gap:var(--s3);padding:11px var(--s5) 0;flex-wrap:wrap}
.context-row{display:flex;align-items:center;gap:var(--s4);padding:var(--s3) var(--s5);flex-wrap:wrap}
.topbar .device{font-size:15px;font-weight:600;letter-spacing:-.2px;line-height:1.2}
.topbar .meta{font-size:12px;color:var(--text-3);margin-top:2px;display:flex;align-items:center;gap:var(--s2)}
.spacer{flex:1}

/* modbar tabs */
.modbar{display:flex;gap:2px;background:var(--surface-2);border:1px solid var(--border);
  border-radius:var(--radius);padding:3px}
.modtab{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:6px;border:none;
  background:none;color:var(--text-3);font-family:inherit;font-size:12.5px;font-weight:500;
  cursor:pointer;transition:all .12s;white-space:nowrap}
.modtab:hover{color:var(--text-2);background:var(--surface)}
.modtab.on{background:var(--surface);color:var(--accent);font-weight:600;
  box-shadow:var(--shadow)}
.modtab .ti{font-size:15px}
.modtab.soon{opacity:.45;cursor:default}
.modtab.soon:hover{background:none;color:var(--text-3)}

/* pills */
.pill{display:inline-flex;align-items:center;gap:7px;padding:5px 12px;border-radius:20px;
  border:1px solid var(--border);font-size:12px;font-weight:600;color:var(--text-2);background:var(--surface-2)}
.pill .dot{width:7px;height:7px;border-radius:50%;background:var(--text-faint)}
.pill.ok{border-color:var(--ok-border);background:var(--ok-soft);color:var(--ok)}.pill.ok .dot{background:var(--ok)}
.pill.warn{border-color:var(--warn-border);background:var(--warn-soft);color:var(--warn)}.pill.warn .dot{background:var(--warn)}
.pill.info{border-color:var(--info-border);background:var(--info-soft);color:var(--info)}.pill.info .dot{background:var(--info)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius);
  border:1px solid var(--border);background:var(--surface);color:var(--text-2);
  font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all .12s;white-space:nowrap}
.btn:hover{border-color:var(--border-strong);color:var(--text);background:var(--surface-2)}
.btn.pri{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.pri:hover{background:color-mix(in srgb,var(--accent) 88%,#000);color:#fff}
.btn.ghost{border-color:transparent;background:none;color:var(--text-3)}
.btn.ghost:hover{background:var(--surface-3);color:var(--text)}
.btn.sm{padding:5px 10px;font-size:12px}
.btn.danger{border-color:var(--err-border);color:var(--err)}
.btn.danger:hover{background:var(--err-soft)}

/* scroll / pane */
.scroll{flex:1;overflow-y:auto;min-height:0}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:20px;border:3px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:var(--text-faint);background-clip:padding-box;border:3px solid transparent}
.pane{padding:var(--s5);max-width:1400px;margin:0 auto;animation:fade .18s ease}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.pane-head{margin-bottom:var(--s5)}
.pane-head .kick{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  color:var(--accent);margin-bottom:6px}
.pane-head h2{font-size:20px;font-weight:600;letter-spacing:-.3px;margin-bottom:6px}
.pane-head p{font-size:13.5px;color:var(--text-2);line-height:1.6;max-width:620px}

/* ---- KPI summary cards ------------------------------------ */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s3);margin-bottom:var(--s5)}
@media(max-width:1100px){.kpi-grid{grid-template-columns:repeat(4,1fr)}}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:var(--s4);box-shadow:var(--shadow);position:relative;overflow:hidden;cursor:default}
.kpi::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--text-faint)}
.kpi.ok::before{background:var(--ok)}.kpi.warn::before{background:var(--warn)}
.kpi.info::before{background:var(--info)}.kpi.accent::before{background:var(--accent)}
.kpi-label{font-size:11.5px;font-weight:600;color:var(--text-3);letter-spacing:.01em;margin-bottom:var(--s2)}
.kpi-value{font-size:26px;font-weight:700;letter-spacing:-.5px;line-height:1.1}
.kpi-sub{font-size:11.5px;color:var(--text-3);margin-top:4px;font-family:var(--font-mono)}
.kpi-row2{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s3);margin-bottom:var(--s5)}

/* ---- Input section ---------------------------------------- */
.section-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  box-shadow:var(--shadow);margin-bottom:var(--s4);overflow:hidden}
.section-hd{display:flex;align-items:center;gap:9px;padding:var(--s3) var(--s4);
  border-bottom:1px solid var(--border-faint);font-size:13px;font-weight:600}
.section-hd .ti{font-size:17px;color:var(--accent)}
.section-hd .sub{font-size:12px;color:var(--text-3);font-weight:500;margin-left:auto}
.section-body{padding:var(--s4)}

/* fast import area */
.fast-import{background:var(--surface-2);border:2px dashed var(--border-strong);border-radius:var(--radius-lg);
  padding:var(--s4);margin-bottom:var(--s4);transition:border-color .12s}
.fast-import:focus-within{border-color:var(--accent);background:var(--accent-soft)}
.import-actions{display:flex;align-items:center;gap:var(--s3);flex-wrap:wrap}
.file-btn{position:relative;overflow:hidden}
.file-btn input{position:absolute;inset:0;opacity:0;cursor:pointer}
.device-preview{display:flex;flex-wrap:wrap;gap:8px;margin-top:var(--s3)}
.device-chip{display:inline-flex;align-items:center;gap:7px;padding:6px 10px;border:1px solid var(--accent-border);
  border-radius:999px;background:var(--accent-soft);color:var(--text-2);font-size:12px}
.device-chip b{color:var(--accent)}
.fast-import-label{font-size:12px;font-weight:600;color:var(--accent);text-transform:uppercase;
  letter-spacing:.06em;margin-bottom:var(--s2);display:flex;align-items:center;gap:6px}
.fast-import-label .ti{font-size:15px}

/* supported command workflow */
.supported-commands{margin-bottom:var(--s4)}
.supported-commands>summary{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;
  gap:var(--s3);padding:var(--s3) var(--s4);cursor:pointer;list-style:none}
.supported-commands>summary::-webkit-details-marker{display:none}
.supported-commands>summary:hover{background:var(--surface-2)}
.supported-title{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:650;color:var(--text)}
.supported-title .ti{font-size:17px;color:var(--accent)}
.supported-helper{font-size:12px;color:var(--text-3)}
.supported-chev{font-size:14px;color:var(--text-3);transition:transform .16s}
.supported-commands[open] .supported-chev{transform:rotate(180deg)}
.supported-commands .section-body{display:grid;gap:var(--s3);padding-top:0}
.supported-commands:not([open]) .section-body{display:none}
.command-guidance{font-size:12.5px;color:var(--text-3);line-height:1.6;max-width:760px}
.command-list{margin:0;padding:var(--s3) var(--s4);border:1px solid var(--border);
  border-radius:var(--radius);background:var(--surface-2);color:var(--text);
  font:12px/1.75 var(--font-mono);white-space:pre-wrap;overflow:auto}

textarea{display:block;width:100%;padding:var(--s3) var(--s4);border:none;
  background:var(--surface);color:var(--text);font-family:var(--font-mono);font-size:11.5px;
  resize:vertical;outline:none;line-height:1.7;min-height:140px}
textarea::placeholder{color:var(--text-faint)}

@media(max-width:560px){
  .supported-commands>summary{grid-template-columns:1fr auto;gap:var(--s2)}
  .supported-title,.supported-helper{grid-column:1 / -1}
  .supported-commands .btn{justify-content:center}
}

/* ---- Import summary --------------------------------------- */
.import-summary{display:flex;align-items:center;gap:var(--s3);background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius-lg);padding:10px var(--s3);
  box-shadow:var(--shadow);margin-bottom:var(--s4);min-height:0}
.import-summary-hd{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;
  color:var(--text-3);white-space:nowrap;margin:0;padding-right:var(--s3);border-right:1px solid var(--border)}
.import-items{display:flex;flex-wrap:wrap;gap:6px;min-width:0}
.import-item{display:inline-flex;align-items:center;gap:5px;padding:4px 9px;border-radius:999px;
  font-size:11.5px;font-weight:500;line-height:1.35;border:1px solid var(--border);
  background:var(--surface-2);color:var(--text-2);white-space:nowrap}
.import-item.ok{border-color:var(--ok-border);background:var(--ok-soft);color:var(--ok)}
.import-item.warn{border-color:var(--warn-border);background:var(--warn-soft);color:var(--warn)}
.import-summary .import-item.empty{display:inline-flex;text-align:left;padding:4px 9px;max-width:none;
  margin:0;border-color:var(--border-faint);background:transparent;color:var(--text-3)}
.import-item .ti{font-size:12px;flex:none}
.import-item b{font-weight:650}
@media(max-width:760px){
  .import-summary{display:block;padding:var(--s3)}
  .import-summary-hd{border-right:0;border-bottom:1px solid var(--border);padding:0 0 8px;margin-bottom:8px}
  .import-items{gap:6px}
  .import-item{white-space:normal}
}

/* ---- Filters bar ------------------------------------------ */
.filter-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:var(--s3) var(--s4);box-shadow:var(--shadow);margin-bottom:var(--s4);
  display:flex;align-items:center;gap:var(--s3);flex-wrap:wrap}
.filter-bar input,.filter-bar select{font-family:inherit;font-size:12.5px;color:var(--text);
  background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);
  padding:6px 10px;outline:none;transition:border-color .12s}
.filter-bar input:focus,.filter-bar select:focus{border-color:var(--accent-border)}
.filter-bar input{min-width:220px;flex:1}
.filter-bar select{cursor:pointer}
.filter-label{font-size:11.5px;font-weight:600;color:var(--text-3);white-space:nowrap}

/* ---- Results table ---------------------------------------- */
.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  box-shadow:var(--shadow);overflow:hidden;margin-bottom:var(--s5)}
.table-toolbar{display:flex;align-items:center;gap:var(--s3);padding:var(--s3) var(--s4);
  border-bottom:1px solid var(--border-faint);flex-wrap:wrap}
.table-title{font-size:13px;font-weight:600;flex:1}
.table-count{font-size:12px;color:var(--text-3);font-family:var(--font-mono)}
.tbl-scroll{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:12.5px}
thead th{padding:9px 12px;text-align:left;font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);
  background:var(--surface-2);border-bottom:1px solid var(--border);
  white-space:nowrap;position:sticky;top:0;z-index:1}
thead th:first-child{padding-left:var(--s4)}
tbody tr{border-bottom:1px solid var(--border-faint);transition:background .1s}
tbody tr:hover{background:var(--surface-3)}
tbody tr:last-child{border-bottom:none}
tbody td{padding:8px 12px;vertical-align:top;color:var(--text-2);line-height:1.4}
tbody td:first-child{padding-left:var(--s4);font-weight:600;color:var(--text);font-family:var(--font-mono);font-size:12px}
.td-mono{font-family:var(--font-mono);font-size:11.5px}
.td-wrap{white-space:normal;min-width:120px}
.td-nowrap{white-space:nowrap}

/* confidence badges */
.conf{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;
  font-size:10.5px;font-weight:600;white-space:nowrap}
.conf.high{background:var(--ok-soft);color:var(--ok);border:1px solid var(--ok-border)}
.conf.medium{background:var(--info-soft);color:var(--info);border:1px solid var(--info-border)}
.conf.low{background:var(--warn-soft);color:var(--warn);border:1px solid var(--warn-border)}

/* status badges */
.status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;
  font-size:10.5px;font-weight:600;white-space:nowrap}
.status-badge.connected{background:var(--ok-soft);color:var(--ok);border:1px solid var(--ok-border)}
.status-badge.notconnect{background:var(--surface-2);color:var(--text-3);border:1px solid var(--border)}
.status-badge.disabled{background:var(--err-soft);color:var(--err);border:1px solid var(--err-border)}
.status-badge.err{background:var(--err-soft);color:var(--err);border:1px solid var(--err-border)}

/* multi-mac cell */
.mac-list{display:flex;flex-direction:column;gap:2px}
.mac-entry{display:flex;align-items:center;gap:5px;font-size:11px;font-family:var(--font-mono)}
.mac-vlan{font-size:10px;background:var(--surface-2);border:1px solid var(--border);
  border-radius:4px;padding:0 5px;color:var(--text-3)}

/* discovery proto badge */
.proto{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:5px;
  font-size:10.5px;font-weight:600;font-family:var(--font-mono);border:1px solid}
.proto.cdp{background:#E7F1F8;color:#0369A1;border-color:#BBD7E8}
.proto.lldp{background:#EAF6F8;color:#15899B;border-color:#B8CED5}
html[data-theme="dark"] .proto.cdp{background:var(--info-soft);color:var(--info);border-color:var(--info-border)}
html[data-theme="dark"] .proto.lldp{background:var(--accent-soft);color:var(--accent);border-color:var(--accent-border)}

/* warning toast */
.warnings-box{background:var(--warn-soft);border:1px solid var(--warn-border);border-radius:var(--radius-lg);
  padding:var(--s3) var(--s4);margin-bottom:var(--s4);font-size:12.5px;color:var(--warn)}
.warnings-box .warn-hd{display:flex;align-items:center;gap:7px;font-weight:600;margin-bottom:var(--s2)}
.warnings-box ul{padding-left:20px;display:flex;flex-direction:column;gap:3px}

/* empty state */
.empty{text-align:center;padding:var(--s7) var(--s5);max-width:440px;margin:40px auto}
.empty .ic{width:56px;height:56px;border-radius:14px;margin:0 auto var(--s4);display:grid;
  place-items:center;font-size:26px;background:var(--accent-soft);color:var(--accent)}
.empty h3{font-size:16px;font-weight:600;margin-bottom:var(--s2)}
.empty p{font-size:13.5px;color:var(--text-2);line-height:1.6;margin-bottom:var(--s4)}

/* view tabs (Input / Results) */
.view-tabs{display:flex;gap:2px;background:var(--surface-2);border:1px solid var(--border);
  border-radius:var(--radius);padding:3px;margin-bottom:var(--s4)}
.view-tab{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:6px;
  border:none;background:none;color:var(--text-3);font-family:inherit;font-size:13px;
  font-weight:500;cursor:pointer;transition:all .12s}
.view-tab:hover{color:var(--text-2);background:var(--surface)}
.view-tab.on{background:var(--surface);color:var(--accent);font-weight:600;box-shadow:var(--shadow)}
.view-tab .ti{font-size:15px}
.view-tab .cnt{font-size:11px;font-weight:600;font-family:var(--font-mono);
  background:var(--surface-3);border-radius:20px;padding:1px 7px;color:var(--text-3)}
.view-tab.on .cnt{background:var(--accent-soft);color:var(--accent)}

/* standalone Port Mapping Generator shell */
.mobile-tool-title{display:none}

/* release notes */
.release-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  box-shadow:var(--shadow);overflow:hidden}
.release-head{display:flex;align-items:center;gap:var(--s4);padding:var(--s5);border-bottom:1px solid var(--border)}
.release-head h3{font-size:18px;font-weight:650;margin-top:5px}
.release-version{display:inline-flex;padding:3px 9px;border-radius:999px;background:var(--accent-soft);
  border:1px solid var(--accent-border);color:var(--accent);font:600 11px var(--font-mono)}
.release-head .pill{margin-left:auto}
.release-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0}
.release-grid section{padding:var(--s5);border-right:1px solid var(--border-faint);
  border-bottom:1px solid var(--border-faint)}
.release-grid section:nth-child(even){border-right:0}
.release-grid section:nth-last-child(-n+2){border-bottom:0}
.release-grid h4{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin-bottom:10px}
.release-grid ul{padding-left:18px;color:var(--text-2);font-size:13px;line-height:1.65}
.release-grid li+li{margin-top:4px}

@media(max-width:900px){
  html,body{height:auto;min-height:100%;overflow:auto}
  .app{display:block;height:auto;min-height:calc(100vh - var(--site-header-height))}
  .side{position:sticky;top:var(--site-header-height);z-index:20;display:flex;flex-direction:row;align-items:center;
    min-height:auto;border-right:0;border-bottom:1px solid var(--border);box-shadow:var(--shadow)}
  .brand{margin:8px;padding:8px 10px;min-width:0}
  .brand .logo{width:42px;height:30px}
  .nav-group{display:none}
  .nav{display:flex;flex-direction:row;align-items:center;justify-content:flex-end;padding:8px;overflow:visible;gap:4px}
  .nav-item{width:auto;padding:8px 10px}
  .nav-item .lbl{display:none}
  .topbar{position:sticky;top:calc(var(--site-header-height) + 55px);z-index:15}
  .context-row{padding:10px 14px}
  .context-row .device,.context-row .meta{display:none}
  .mobile-tool-title{display:block;font-size:13px;font-weight:700}
  .pane{padding:16px}
  .kpi-grid,.kpi-row2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .filter-bar{align-items:stretch}
  .filter-bar input,.filter-bar select{min-width:0;width:100%}
  .table-toolbar{align-items:flex-start}
  .table-toolbar .spacer{display:none}
  .release-grid{grid-template-columns:1fr}
  .release-grid section,.release-grid section:nth-child(even),.release-grid section:nth-last-child(-n+2){
    border-right:0;border-bottom:1px solid var(--border-faint)}
  .release-grid section:last-child{border-bottom:0}
}
@media(max-width:560px){
  .brand .name{font-size:12.5px}
  .context-row{gap:8px}
  .context-row>.btn.ghost{display:none}
  .context-row>.btn.pri{padding:7px 10px}
  .pill{display:none}
  .pane-head h2{font-size:19px}
  .kpi-grid,.kpi-row2{grid-template-columns:1fr 1fr;gap:8px}
  .kpi{padding:12px}
  .kpi-value{font-size:22px}
  .section-body{padding:12px}
  .table-toolbar{gap:8px}
  .table-toolbar .btn{flex:1;justify-content:center}
}
