:root{
  /* Brand palette — Salus product red (primary accent) + Kryptus corporate blue (chrome/links). */
  --salus-red:#D8231F; --charcoal:#2D2D3A; --kryptus-blue-1:#2EA7DE; --kryptus-blue-2:#1C75BC;
  --bg:#f7f6f8; --surface:#ffffff; --surface-2:#eef0f4; --on:#1c1b1f; --muted:#5d5b62;
  --primary:var(--salus-red); --on-primary:#fff; --outline:#cdd1da; --info-bg:#e1f0fa; --info:var(--kryptus-blue-2);
  --link:var(--kryptus-blue-2); --chrome:var(--charcoal);
  --good-bg:#def7e3; --good:#0f6b2e; --warn-bg:#fef0d6; --warn:#8a5a00; --bad-bg:#fbdcdc; --bad:#8c1d18;
  --radius:16px; --shadow:0 1px 2px rgba(0,0,0,.08),0 2px 8px rgba(0,0,0,.06);
}
@media (prefers-color-scheme: dark){:root{
  --bg:#16151c; --surface:#1f1e26; --surface-2:#2b2a35; --on:#e9e7ef; --muted:#c4c2cf;
  --primary:#f0524e; --on-primary:#2a0908; --outline:#454353; --info-bg:#15314a; --info:#7cc6f0;
  --link:#7cc6f0; --chrome:#23222c;
  --good-bg:#0c3a1c; --good:#7fe0a0; --warn-bg:#3a2c0c; --warn:#f0c879; --bad-bg:#4a1411; --bad:#f2b8b5;
}}
*{box-sizing:border-box} html,body{margin:0}
body{font:15px/1.5 system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;background:var(--bg);color:var(--on)}
/* R96: the fixed sidenav lives at left:0; the whole in-flow document (sticky topbar +
   panels + footer) is pushed right by the rail/drawer width via body padding. Fixed
   elements (sidenav, scrim, terminal overlay) set their own offsets and ignore this. */
body{padding-left:var(--rail-w);transition:padding-left .2s ease}
.mono{font-family:ui-monospace,"SF Mono",Menlo,Consolas,monospace;font-size:13px}
.muted{color:var(--muted)} .tiny{font-size:12px} .hidden{display:none!important} .spacer{flex:1}
.row{display:flex;align-items:center;gap:.6rem}
.brand{font-weight:700;font-size:20px;letter-spacing:.2px;display:flex;align-items:center;gap:.55rem;white-space:nowrap;color:#fff}
.brand .sub{color:rgba(255,255,255,.62);font-weight:500}
.brand .brand-mark{height:26px;width:26px;display:block}
.dot{width:12px;height:12px;border-radius:50%;background:var(--primary);display:inline-block;box-shadow:0 0 0 4px color-mix(in srgb,var(--primary) 22%,transparent)}
/* === R96: top bar — slimmed to just the right-side context (lang / operator / logout).
   The brand + nav moved into the left sidebar; the hamburger here is the mobile/rail toggle.
   Kept single-row (≤70px) so the terminal overlay (top:70px, lower z-index) is never overlapped. */
.appbar{display:flex;align-items:center;gap:1rem;padding:.7rem 1.4rem;background:var(--chrome);color:#fff;box-shadow:var(--shadow);position:sticky;top:0;z-index:30;flex-wrap:nowrap}
.appbar .chip{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.2)}
.appbar .btn.text{color:var(--kryptus-blue-1)}
.pill{display:inline-block;min-width:18px;margin-left:.4rem;padding:0 .35rem;border-radius:999px;background:var(--bad-bg);color:var(--bad);font-size:11px;font-weight:700;text-align:center}

/* === R96 left navigation (MD3 rail / drawer) ================================
   Layout is driven by two width vars + body state classes:
     --rail-w  : how far the chrome (topbar + content) is pushed right.
     .nav-collapsed → rail (icon-only); default → drawer (icon+label).
     .nav-open      → narrow-viewport modal drawer is showing (over a scrim).
   The sidenav itself is a fixed column; switchTab() toggles .active on the entries
   and the CSS below paints the active pill (Salus red / Kryptus blue accent). */
:root{--drawer-w:240px;--rail-w:72px}
body.nav-collapsed{--rail-w:72px}
body:not(.nav-collapsed){--rail-w:var(--drawer-w)}
.sidenav{position:fixed;top:0;left:0;bottom:0;width:var(--drawer-w);z-index:35;
  background:var(--chrome);color:#fff;display:flex;flex-direction:column;
  box-shadow:var(--shadow);overflow-x:hidden;
  transition:width .2s ease,transform .2s ease}
body.nav-collapsed .sidenav{width:72px}
.sidenav-top{display:flex;align-items:center;gap:.55rem;padding:.7rem .8rem;min-height:56px;flex:0 0 auto}
.nav-toggle{border:none;background:transparent;color:rgba(255,255,255,.78);cursor:pointer;
  display:grid;place-items:center;width:40px;height:40px;border-radius:999px;flex:0 0 auto;padding:0}
.nav-toggle:hover{background:rgba(255,255,255,.12);color:#fff}
.nav-brand{display:flex;align-items:center;gap:.55rem;font-weight:700;font-size:19px;letter-spacing:.2px;white-space:nowrap;color:#fff;overflow:hidden;min-width:0}
.nav-brand .brand-mark{height:24px;width:24px;display:block;flex:0 0 auto}
.nav-brand-text{transition:opacity .15s ease}
.nav-brand .sub{color:rgba(255,255,255,.6);font-weight:500;font-size:14px}
.sidenav-items{display:flex;flex-direction:column;gap:.15rem;padding:.4rem .7rem;overflow-y:auto;overflow-x:hidden;flex:1 1 auto;scrollbar-width:thin}
/* an entry = inline-SVG icon + label, an MD3 rounded "pill" row */
.sidenav .tab{display:flex;align-items:center;gap:.85rem;width:100%;
  border:none;background:transparent;color:rgba(255,255,255,.78);font:inherit;font-weight:600;
  padding:.62rem .8rem;border-radius:999px;cursor:pointer;text-align:left;white-space:nowrap;overflow:hidden;position:relative}
.sidenav .tab .nav-ic{flex:0 0 auto;width:22px;height:22px}
.sidenav .tab .nav-label{flex:1 1 auto;overflow:hidden;text-overflow:ellipsis;transition:opacity .15s ease}
.sidenav .tab:hover{background:rgba(255,255,255,.1);color:#fff}
.sidenav .tab:focus-visible{outline:2px solid var(--kryptus-blue-1);outline-offset:-2px}
/* active treatment: filled pill in Salus red + a Kryptus-blue left indicator */
.sidenav .tab.active{color:#fff;background:color-mix(in srgb,var(--primary) 86%,transparent)}
.sidenav .tab.active::before{content:"";position:absolute;left:-4px;top:18%;bottom:18%;width:4px;border-radius:0 4px 4px 0;background:var(--kryptus-blue-1)}
.sidenav .pill{margin-left:auto}
/* COLLAPSED rail: hide the brand text + labels, center the icon, drop the left indicator */
body.nav-collapsed .nav-brand-text{opacity:0;width:0}
body.nav-collapsed .sidenav .tab{justify-content:center;gap:0;padding:.62rem 0}
body.nav-collapsed .sidenav .tab .nav-label{opacity:0;width:0;flex:0 0 0}
body.nav-collapsed .sidenav .tab.active::before{display:none}
body.nav-collapsed .sidenav .pill{position:absolute;top:.25rem;right:.5rem;margin:0}
/* the topbar hamburger is only needed when there is no rail toggle in view (narrow vp) */
.topbar-toggle{color:rgba(255,255,255,.85);display:none}
.topbar-toggle:hover{background:rgba(255,255,255,.12);color:#fff}
/* scrim for the narrow-viewport modal drawer */
.nav-scrim{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:34;opacity:0;pointer-events:none;transition:opacity .2s ease}

/* === narrow viewport (<900px): the sidenav becomes a MODAL drawer ============ */
@media(max-width:899px){
  :root{--rail-w:0px}
  body{--rail-w:0px!important}
  .sidenav{transform:translateX(-100%);width:var(--drawer-w)!important}
  body.nav-open .sidenav{transform:translateX(0)}
  body.nav-collapsed .sidenav{width:var(--drawer-w)!important} /* always full drawer when modal */
  body.nav-collapsed .nav-brand-text{opacity:1;width:auto}
  body.nav-collapsed .sidenav .tab{justify-content:flex-start;gap:.85rem;padding:.62rem .8rem}
  body.nav-collapsed .sidenav .tab .nav-label{opacity:1;width:auto;flex:1 1 auto}
  body.nav-collapsed .sidenav .tab.active::before{display:block}
  body.nav-collapsed .sidenav .pill{position:static;margin-left:auto}
  body.nav-open .nav-scrim{opacity:1;pointer-events:auto}
  .topbar-toggle{display:grid}
}
.langtog{display:inline-flex;border:1px solid rgba(255,255,255,.28);border-radius:999px;overflow:hidden}
.langtog button{border:none;background:transparent;color:rgba(255,255,255,.7);font:inherit;font-size:12px;font-weight:700;padding:.25rem .55rem;cursor:pointer}
.langtog button.active{background:var(--kryptus-blue-2);color:#fff}
/* the login page shows the langtog on a light card, not the chrome bar */
.login-card .langtog{border-color:var(--outline)}
.login-card .langtog button{color:var(--muted)}
.login-card .langtog button.active{background:var(--kryptus-blue-2);color:#fff}
.panel{display:none} .panel.active{display:block}
.grid{max-width:min(1500px,90vw);margin:1.3rem auto;padding:0 1.2rem;display:grid;gap:1.1rem;grid-template-columns:1fr}
@media(min-width:900px){.grid{grid-template-columns:1fr 1fr}}
.span2{grid-column:1/-1}
.card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.1rem 1.2rem}
.card-h{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:.6rem}
h2{font-size:16px;font-weight:600;margin:0}
.toolbar{max-width:min(1500px,90vw);margin:1.3rem auto .6rem;padding:0 1.2rem;display:flex;align-items:center;gap:.8rem}
.search{flex:1;max-width:420px;padding:.55rem .9rem;border-radius:999px;border:1px solid var(--outline);background:var(--surface);color:var(--on);font:inherit}
.badges{display:flex;flex-wrap:wrap;gap:.4rem;margin:.2rem 0 .6rem}
.chip{display:inline-flex;align-items:center;padding:.18rem .6rem;border-radius:999px;background:var(--surface-2);color:var(--on);font-size:12.5px;font-weight:500;border:1px solid var(--outline)}
.chip.good{background:var(--good-bg);color:var(--good);border-color:transparent}
.chip.warn{background:var(--warn-bg);color:var(--warn);border-color:transparent}
.chip.bad{background:var(--bad-bg);color:var(--bad);border-color:transparent}
.chip.info{background:var(--info-bg);color:var(--info);border-color:transparent}
.cases{max-width:min(1500px,90vw);margin:0 auto 2rem;padding:0 1.2rem;display:grid;gap:.7rem}
.case-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:.85rem 1rem;cursor:pointer;border:1px solid transparent;transition:border-color .12s}
.case-card:hover{border-color:var(--primary)}
.case-card.archived{opacity:.58}
.case-card.archived .cc-btns{opacity:1}
.cc-meta{margin-top:.3rem}
.cc-top{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}
.cc-id{font-size:14px;font-weight:600}
.cc-title{margin:.25rem 0 .15rem;font-weight:500}
#case-detail{max-width:min(1500px,90vw);margin:0 auto}
#case-detail .toolbar{align-items:center}
#case-detail .grid{margin-top:.2rem}
.field{display:flex;flex-direction:column;gap:.25rem;font-size:12px;color:var(--muted);margin-bottom:.7rem}
.field input,.field select,.field textarea{padding:.5rem .6rem;border-radius:10px;border:1px solid var(--outline);background:var(--bg);color:var(--on);font:inherit}
.timeline{display:flex;flex-direction:column;gap:.4rem}
.beat{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:.45rem .2rem;border-bottom:1px solid color-mix(in srgb,var(--outline) 45%,transparent)}
.bt-act{flex:1;min-width:180px}
.bt-why{flex-basis:100%;margin-left:.2rem}
.sess{display:flex;align-items:center;gap:.5rem;padding:.4rem .1rem;border-bottom:1px solid color-mix(in srgb,var(--outline) 45%,transparent)}
table.data{width:100%;border-collapse:collapse}
table.data th{text-align:left;font-size:12px;color:var(--muted);font-weight:600;padding:.4rem .5rem;border-bottom:1px solid var(--outline)}
table.data td{padding:.5rem .5rem;border-bottom:1px solid color-mix(in srgb,var(--outline) 45%,transparent);vertical-align:top}
.btn{border:none;border-radius:999px;padding:.6rem 1.4rem;font:inherit;font-weight:600;cursor:pointer;text-decoration:none;display:inline-block}
.btn.filled{background:var(--primary);color:var(--on-primary)}
.btn.text{background:transparent;color:var(--primary);padding:.4rem .8rem}
.btn.sm{padding:.35rem .9rem;font-size:13px}
.banner{padding:.6rem .8rem;border-radius:10px;margin:.6rem auto;max-width:min(1500px,90vw);font-size:13.5px}
.banner.warn{background:var(--warn-bg);color:var(--warn)} .banner.err{background:var(--bad-bg);color:var(--bad)}
.prodwrap{overflow-x:auto}
.srchead,.srcrow{display:grid;grid-template-columns:92px minmax(170px,1.5fr) 84px 110px 120px 110px 110px auto;gap:.4rem;align-items:center;padding:.32rem 0;border-bottom:1px solid color-mix(in srgb,var(--outline) 45%,transparent)}
.srchead{border-bottom:1px solid var(--outline)}
.srcrow input,.srcrow select{padding:.4rem .5rem;border-radius:8px;border:1px solid var(--outline);background:var(--bg);color:var(--on);font:inherit;font-size:13px;min-width:0}
.srcbtns{display:flex;gap:.3rem;white-space:nowrap}
.cc-btns{display:flex;gap:.4rem;margin-top:.55rem;flex-wrap:wrap}
/* R96: clear the fixed sidebar (rail/drawer width) so the embedded terminal isn't hidden behind it. */
.term-overlay{position:fixed;left:calc(var(--rail-w) + 1rem);right:1rem;top:70px;bottom:1rem;background:#1d1b20;border-radius:12px;box-shadow:0 8px 40px rgba(0,0,0,.5);display:flex;flex-direction:column;z-index:20;overflow:hidden;transition:left .2s ease}
.term-head{display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;background:#2b2930;color:#e6e1e9;font-size:13px}
.term-head .btn.text{color:#cfbcff}
.term-tabs{display:flex;gap:.25rem;flex-wrap:wrap;align-items:center;min-width:0;overflow:auto}
.tterm{display:inline-flex;align-items:center;gap:.45rem;padding:.25rem .6rem;border-radius:8px;background:#1d1b20;color:#cac4d0;font-size:12.5px;white-space:nowrap;border:1px solid #49454f}
.tterm.active{background:color-mix(in srgb,var(--primary) 38%,#1d1b20);color:#fff;border-color:transparent}
.tterm .tt-label{cursor:pointer}
.tterm .tt-x{cursor:pointer;opacity:.6;font-size:11px}
.tterm .tt-x:hover{opacity:1}
.term-body{flex:1;min-height:0;padding:.4rem .5rem;position:relative}
.term-instance{height:100%}
.term-instance .xterm{height:100%}
.term-restore{position:fixed;right:1rem;bottom:1rem;z-index:25;border:none;border-radius:999px;background:color-mix(in srgb,var(--primary) 70%,#1d1b20);color:#fff;padding:.6rem 1.1rem;font:inherit;font-weight:600;cursor:pointer;box-shadow:0 4px 18px rgba(0,0,0,.45)}
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.45);display:grid;place-items:center;z-index:40}
.modal{background:var(--surface);color:var(--on);border-radius:16px;box-shadow:0 8px 40px rgba(0,0,0,.4);width:min(92vw,440px);max-height:90vh;overflow:auto}
.modal-h{padding:1rem 1.2rem .2rem}.modal-h h2{margin:0}
.modal-b{padding:.4rem 1.2rem 1rem}
.modal-f{display:flex;justify-content:flex-end;gap:.5rem;padding:.4rem 1.2rem 1.1rem}
.grp{padding:.5rem .1rem;border-bottom:1px solid color-mix(in srgb,var(--outline) 45%,transparent)}
.field .row{display:flex;gap:.4rem;margin-top:.3rem} .field .row input,.field .row select{flex:1;padding:.4rem .5rem;border-radius:8px;border:1px solid var(--outline);background:var(--bg);color:var(--on);font:inherit}
.field .chip a{color:var(--bad);text-decoration:none;margin-left:.2rem}
.clickable{cursor:pointer}
table.data tr.clickable:hover td{background:var(--surface-2)}
.beat.clickable:hover{background:var(--surface-2);border-radius:8px}
.kv{display:grid;grid-template-columns:max-content 1fr;gap:.32rem .9rem;font-size:13px;margin:.2rem 0 .6rem}
.kv dt{color:var(--muted)} .kv dd{margin:0;word-break:break-word}
.ed-blk{margin:.5rem 0}
.ed-pre{white-space:pre-wrap;word-break:break-word;background:var(--surface-2);border-radius:8px;padding:.55rem .7rem;margin:.2rem 0 0;max-height:240px;overflow:auto}
.ed-seal{margin-top:.5rem}
.login-bg{min-height:100vh;display:grid;place-items:center;background:radial-gradient(1200px 500px at 50% -10%,color-mix(in srgb,var(--primary) 18%,transparent),transparent)}
.login-card{background:var(--surface);border-radius:24px;box-shadow:var(--shadow);padding:2rem 2.2rem;width:min(92vw,380px)}
.login-head{align-items:center}
.login-lockup{height:48px;width:auto;max-width:70%}
.kryptus-product{font-size:12px;font-weight:600;letter-spacing:.3px;margin:.4rem 0 .2rem}
.login-card form{display:flex;flex-direction:column;gap:.9rem;margin-top:1rem}
.login-card label{display:flex;flex-direction:column;gap:.3rem;font-size:13px;color:var(--muted)}
.login-card input{padding:.7rem .8rem;border-radius:10px;border:1px solid var(--outline);background:var(--bg);color:var(--on);font:inherit}
.btn.filled[type=submit]{width:100%;margin-top:.4rem}
.foot{max-width:min(1500px,90vw);margin:1.5rem auto 2rem;padding:.9rem 1.2rem 0;border-top:1px solid color-mix(in srgb,var(--outline) 45%,transparent);display:flex;align-items:center;gap:.5rem}
.foot-sep{opacity:.5;margin:0 .1rem}
.foot-logo{height:16px;width:auto;opacity:.7;vertical-align:middle}

/* painel / dashboard (R82): dense, actionable */
.dash-kpis{display:flex;gap:1.4rem;flex-wrap:wrap;margin:.1rem 0 .5rem}
.dash-kpi{display:flex;flex-direction:column;line-height:1.05;margin-bottom:.3rem}
.dash-n{font-size:1.7rem;font-weight:700}
.dash-kpi.warn .dash-n{color:var(--warn)} .dash-kpi.good .dash-n{color:var(--good)}
.dash-list{display:flex;flex-direction:column;margin-top:.2rem}
.dash-row{display:flex;align-items:center;gap:.5rem;padding:.28rem .1rem;border-top:1px solid color-mix(in srgb,var(--outline) 40%,transparent);font-size:13.5px}
.dash-row:first-child{border-top:none}
.dash-row.clickable:hover{background:var(--surface-2);border-radius:6px}
.dash-strip{display:flex;gap:.7rem;flex-wrap:wrap;max-width:min(1500px,90vw);margin:.4rem auto 1rem;padding:0 1.2rem}
.dash-tile{flex:1 1 130px;background:var(--surface);border:1px solid var(--outline);border-radius:var(--radius);padding:.6rem .9rem;display:flex;flex-direction:column;gap:.05rem}
.dash-tile.clickable{cursor:pointer} .dash-tile.clickable:hover{background:var(--surface-2)}
.dash-tile.warn .dash-n{color:var(--warn)} .dash-tile.good .dash-n{color:var(--good)}

/* links — Kryptus corporate blue (chrome/links), distinct from the Salus red product accent */
a{color:var(--link)}
table.data td a{color:var(--link);text-decoration:none;font-weight:600}
table.data td a:hover{text-decoration:underline}

/* fleet table — sortable headers, star toggle, inline alias, suspended rows */
table.data th.sortable{cursor:pointer;user-select:none;white-space:nowrap}
table.data th.sortable:hover{color:var(--on)}
.sort-ind{font-size:10px;color:var(--primary)}
.col-star{width:1%;text-align:center}
.star{cursor:pointer;font-size:16px;line-height:1;color:var(--muted);transition:transform .1s}
.star:hover{transform:scale(1.18)}
.star.on{color:#e0a400}
.alias-edit{width:100%;max-width:160px;padding:.32rem .5rem;border-radius:8px;border:1px solid var(--outline);background:var(--bg);color:var(--on);font:inherit;font-size:13px}
.alias-edit:focus{outline:none;border-color:var(--kryptus-blue-2)}
table.data tr.row-blocked td{opacity:.55}
table.data tr.row-blocked td:nth-child(8){opacity:1}
/* security posture — full-width, laid out vertically below the fleet table */
.sec-posture-card .badges.vertical{flex-direction:column;align-items:flex-start;gap:.5rem}
.sec-posture-card .badges.vertical .chip{font-size:13.5px;padding:.32rem .8rem}
/* OIDC / Google sign-in on the login card */
.oidc-sep{display:flex;align-items:center;gap:.6rem;margin:.9rem 0 .6rem;color:var(--muted);font-size:12.5px}
.oidc-sep::before,.oidc-sep::after{content:"";flex:1;height:1px;background:var(--border,#ddd)}
.btn.google-signin{display:flex;align-items:center;justify-content:center;gap:.55rem;width:100%;
  background:#fff;color:#3c4043;border:1px solid #dadce0;font-weight:500}
.btn.google-signin:hover{background:#f7f8f8;border-color:#c6c9cc}
