/* ============================================================
   Silver Lining Intranet — design system
   Dark / premium. Tokens are the canonical Silver Lining set
   (mirrors 12-people-risk/reporters/templates + design-system).
   Host Grotesk 800 · DM Sans 700 · DM Mono 400/500
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Host+Grotesk:ital,wght@0,300..800;1,300..800&family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&family=DM+Mono:ital,wght@0,300;0,400;0,500;1,400&display=swap');
/* Loading / empty / error component library (spinners, skeletons, empty + error
   states, progress bar, chips). Imported first so intranet.css tokens win on the
   few shared names; states.css scopes its one differing token as --fg-soft. */
@import url('states.css');

:root {
  /* surfaces — elevation by shift, not shadow */
  --bg-0:#16181d;            /* page */
  --bg-1:#1b1e24;            /* card / tile */
  --bg-2:#222631;            /* hover / menu */
  --bg-3:#2a2f3b;            /* popover / tooltip */
  --bg-inset:#121419;        /* wells, code, table head */

  /* text */
  --fg-1:#fefefe;
  --fg-2:#7f7f7f;
  --fg-3:rgba(254,254,254,0.55);

  /* borders */
  --border:rgba(255,255,255,0.06);
  --border-strong:rgba(255,255,255,0.12);
  --border-loud:rgba(255,255,255,0.20);

  /* blue accent ramp */
  --blue:#175dd6;
  --blue-2:#296de0;
  --blue-3:#3b80e0;
  --blue-4:#4a92e3;
  --blue-deep:#083279;
  --blue-mid:#0e4ab0;
  --blue-tint:#c8e1fe;
  --blue-glow:rgba(23,93,214,0.22);

  /* semantic */
  --pos:#1f9d55;
  --neg:#d6341a;

  /* risk bands — tuned for dark surface */
  --healthy:#3ad17e;
  --watch:#e3b341;
  --coach:#f08a3c;
  --escalate:#f0584a;

  /* metallic silver — brand chrome, used sparingly */
  --silver-1:#f4f5f7;
  --silver-2:#c9ccd4;
  --silver-3:#9aa0ab;
  --silver-4:#6f757f;
  --chrome:linear-gradient(135deg,#f4f5f7 0%,#c9ccd4 22%,#8b909b 46%,#eef0f3 58%,#a3a8b2 74%,#d8dade 100%);
  --chrome-soft:linear-gradient(135deg,#dfe1e6 0%,#b6bac3 50%,#e9ebee 100%);

  /* type */
  --font-display:'Host Grotesk','Inter',system-ui,sans-serif;
  --font-body:'DM Sans','Inter',system-ui,sans-serif;
  --font-mono:'DM Mono',ui-monospace,'SF Mono',Menlo,monospace;

  /* spacing — 8pt grid + 4pt minor */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:24px;
  --s6:32px; --s7:48px; --s8:64px; --s9:96px;

  /* radii */
  --r-sm:6px; --r-md:10px; --r-lg:16px; --r-xl:22px; --r-pill:999px;

  /* motion */
  --ease:cubic-bezier(0.2,0.8,0.2,1);
  --d-micro:120ms; --d-sm:200ms; --d-md:320ms;

  /* elevation */
  --shadow-1:0 1px 0 rgba(255,255,255,0.03) inset, 0 8px 24px -16px rgba(0,0,0,0.6);
  --shadow-pop:0 24px 56px -20px rgba(0,0,0,0.65);
  --shadow-glow:0 0 0 1px rgba(23,93,214,0.35), 0 8px 30px -8px rgba(23,93,214,0.35);

  /* chrome dims */
  --topbar-h:62px;
  --sidebar-w:256px;
}

*,*::before,*::after{box-sizing:border-box;}
html,body{height:100%;}
body{
  margin:0;
  font-family:var(--font-body);
  font-weight:500;
  /* Solid background — the prototype had radial gradients here, but on
     real-world viewports they brightened the right half (main) more than
     the left (sidebar), creating a visible "cut" between the two areas. */
  background:var(--bg-0);
  color:var(--fg-1);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-size:15px;
  line-height:1.55;
}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;color:inherit;background:none;border:none;padding:0;}
img{max-width:100%;display:block;}
::selection{background:rgba(23,93,214,0.4);color:#fff;}

/* scrollbars */
*{scrollbar-width:thin;scrollbar-color:#333a47 transparent;}
*::-webkit-scrollbar{width:10px;height:10px;}
*::-webkit-scrollbar-thumb{background:#2c3340;border-radius:99px;border:2px solid transparent;background-clip:content-box;}
*::-webkit-scrollbar-thumb:hover{background:#3a4150;background-clip:content-box;}

/* ---------- typography ---------- */
.display{font-family:var(--font-display);font-weight:800;letter-spacing:-0.025em;line-height:1.02;}
h1,.h1{font-family:var(--font-display);font-weight:800;font-size:30px;letter-spacing:-0.02em;line-height:1.08;margin:0;}
h2,.h2{font-family:var(--font-display);font-weight:800;font-size:21px;letter-spacing:-0.015em;line-height:1.15;margin:0;}
h3,.h3{font-family:var(--font-display);font-weight:700;font-size:16px;letter-spacing:-0.01em;line-height:1.2;margin:0;}
.kpi{font-family:var(--font-display);font-weight:800;font-size:40px;letter-spacing:-0.02em;line-height:1;font-variant-numeric:tabular-nums;}
.kpi-lg{font-size:56px;}
.body{font-family:var(--font-body);font-weight:500;font-size:15px;line-height:1.6;}
.lead{font-size:16px;color:var(--fg-3);font-weight:500;line-height:1.6;}
.mono{font-family:var(--font-mono);font-weight:400;font-size:12.5px;letter-spacing:0.02em;color:var(--fg-2);font-variant-numeric:tabular-nums;}
.micro{font-family:var(--font-mono);font-weight:500;font-size:11px;letter-spacing:0.07em;text-transform:uppercase;color:var(--fg-2);}
.muted{color:var(--fg-2);}
.faint{color:var(--fg-3);}
.tnum{font-variant-numeric:tabular-nums;}
.pos{color:var(--pos);} .neg{color:var(--neg);}
.t-healthy{color:var(--healthy);} .t-watch{color:var(--watch);}
.t-coach{color:var(--coach);} .t-escalate{color:var(--escalate);}

/* brand wordmark */
.wordmark{font-family:var(--font-display);font-weight:800;letter-spacing:-0.03em;}
.silvr{font-family:var(--font-display);font-weight:800;letter-spacing:-0.04em;}
.silvr .eq{color:var(--blue);}

/* metallic brand emblem (ring) */
.emblem{
  width:34px;height:34px;border-radius:50%;flex:none;position:relative;
  background:var(--chrome);
  box-shadow:0 0 0 1px rgba(255,255,255,0.18), 0 4px 12px -4px rgba(0,0,0,0.7);
}
.emblem::before{
  content:"";position:absolute;inset:5px;border-radius:50%;
  background:var(--bg-0);
  box-shadow:inset 0 1px 2px rgba(0,0,0,0.8);
}
.emblem::after{
  content:"SL";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:800;font-size:11px;letter-spacing:-0.02em;
  background:var(--chrome);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.emblem.sm{width:26px;height:26px;}
.emblem.sm::after{font-size:9px;}
.emblem.lg{width:46px;height:46px;}
.emblem.lg::after{font-size:15px;}

/* ============================================================
   APP SHELL
   ============================================================ */
.app{min-height:100vh;display:flex;flex-direction:column;}

.topbar{
  position:sticky;top:0;z-index:60;height:var(--topbar-h);
  display:flex;align-items:center;gap:var(--s5);
  padding:0 var(--s5);
  background:var(--bg-inset);  /* same panel tone as sidebar — they read as a continuous chrome */
  border-bottom:1px solid var(--border);
}
.topbar-brand{display:flex;align-items:center;gap:var(--s3);min-width:var(--sidebar-w);}
.topbar-brand .lock{display:flex;flex-direction:column;line-height:1;}
.topbar-brand .lock b{font-family:var(--font-display);font-weight:800;font-size:15px;letter-spacing:-0.02em;}
.topbar-brand .lock span{font-family:var(--font-mono);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--fg-2);margin-top:3px;}

.searchbar{
  flex:1;max-width:520px;display:flex;align-items:center;gap:var(--s3);
  background:var(--bg-1);border:1px solid var(--border-strong);
  border-radius:var(--r-pill);padding:9px 16px;color:var(--fg-2);
  transition:border-color var(--d-sm),box-shadow var(--d-sm);
}
.searchbar:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-glow);}
.searchbar input{flex:1;background:none;border:none;outline:none;color:var(--fg-1);font-family:var(--font-body);font-size:14px;font-weight:500;}
.searchbar input::placeholder{color:var(--fg-2);}
.searchbar kbd{font-family:var(--font-mono);font-size:10px;color:var(--fg-2);border:1px solid var(--border-strong);border-radius:5px;padding:2px 6px;}

.topbar-right{margin-left:auto;display:flex;align-items:center;gap:var(--s3);}

.icon-btn{
  width:38px;height:38px;display:grid;place-items:center;border-radius:var(--r-md);
  background:transparent;border:1px solid transparent;color:var(--fg-2);position:relative;
  transition:background var(--d-sm),color var(--d-sm),border-color var(--d-sm);
}
.icon-btn:hover{background:var(--bg-2);color:var(--fg-1);border-color:var(--border-strong);}
.icon-btn .dot{position:absolute;top:7px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--escalate);box-shadow:0 0 0 2px var(--bg-0);}

/* role switcher */
.roleswitch{position:relative;}
.roleswitch>button{
  display:flex;align-items:center;gap:10px;background:var(--bg-1);
  border:1px solid var(--border-strong);border-radius:var(--r-pill);
  padding:5px 8px 5px 5px;color:var(--fg-1);transition:border-color var(--d-sm);
}
.roleswitch>button:hover{border-color:var(--border-loud);}
.roleswitch .who{display:flex;flex-direction:column;align-items:flex-start;line-height:1.1;padding-right:4px;}
.roleswitch .who b{font-family:var(--font-body);font-weight:700;font-size:13px;}
.roleswitch .who span{font-family:var(--font-mono);font-size:10px;color:var(--fg-2);text-transform:uppercase;letter-spacing:0.06em;}
.roleswitch .caret{color:var(--fg-2);margin-right:4px;}

.menu{
  position:absolute;right:0;top:calc(100% + 10px);min-width:300px;
  background:var(--bg-3);border:1px solid var(--border-strong);border-radius:var(--r-lg);
  box-shadow:var(--shadow-pop);padding:8px;z-index:80;
  opacity:0;transform:translateY(-6px) scale(0.98);pointer-events:none;
  transition:opacity var(--d-sm) var(--ease),transform var(--d-sm) var(--ease);
}
.menu.open{opacity:1;transform:none;pointer-events:auto;}
.menu-label{font-family:var(--font-mono);font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:var(--fg-2);padding:8px 10px 6px;}
.menu-item{
  display:flex;align-items:center;gap:12px;padding:9px 10px;border-radius:var(--r-md);
  color:var(--fg-1);transition:background var(--d-micro);width:100%;text-align:left;background:none;border:none;
}
.menu-item:hover{background:var(--bg-2);}
.menu-item.active{background:rgba(23,93,214,0.16);}
.menu-item .mi-txt{display:flex;flex-direction:column;line-height:1.2;}
.menu-item .mi-txt b{font-weight:700;font-size:13.5px;}
.menu-item .mi-txt span{font-size:11.5px;color:var(--fg-2);}
.menu-sep{height:1px;background:var(--border);margin:6px 4px;}

/* layout body */
.shell{flex:1;display:flex;align-items:flex-start;}
.sidebar{
  width:var(--sidebar-w);flex:none;position:sticky;top:var(--topbar-h);
  height:calc(100vh - var(--topbar-h));overflow-y:auto;
  padding:var(--s5) var(--s4) var(--s7);
  border-right:1px solid var(--border);
  background:var(--bg-inset);  /* opaque panel — reads as a defined surface, not transparent */
  display:flex;flex-direction:column;gap:6px;
}
.side-group{font-family:var(--font-mono);font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--fg-2);padding:14px 12px 7px;}
.side-group:first-child{padding-top:0;}
.nav-item{
  display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r-md);
  color:var(--fg-3);font-weight:600;font-size:14px;transition:background var(--d-sm),color var(--d-sm);position:relative;
  white-space:nowrap;
}
.nav-item > span:not(.tag):not(.ic){flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;}
.nav-item svg{flex:none;opacity:0.8;width:16px;height:16px;}
.nav-item .ic{flex:none;display:inline-flex;align-items:center;justify-content:center;}
.nav-item:hover{background:var(--bg-1);color:var(--fg-1);}
.nav-item.active{background:linear-gradient(90deg,rgba(23,93,214,0.20),rgba(23,93,214,0.06));color:var(--fg-1);}
.nav-item.active::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;background:var(--blue);}
.nav-item .tag{margin-left:auto;}
.side-foot{margin-top:auto;padding-top:var(--s5);}
.side-switch{
  display:flex;align-items:center;gap:10px;width:100%;padding:11px 12px;border-radius:var(--r-md);
  background:var(--bg-1);border:1px solid var(--border-strong);color:var(--fg-1);font-weight:700;font-size:13px;
  transition:border-color var(--d-sm),background var(--d-sm);
}
.side-switch:hover{border-color:var(--blue);background:var(--bg-2);}
.side-switch .arrow{margin-left:auto;color:var(--fg-2);}

.main{flex:1;min-width:0;padding:var(--s6) var(--s7) var(--s9);}
.main-narrow{max-width:1180px;margin:0 auto;}
/* Wide pages (tables, kanbans, dense grids) — flat full-width edge-to-edge.
   Pages opt in via `window.SL_PAGE.wide = true`. Previously every wide page
   inlined `.main{padding:24px 28px;max-width:none;width:100%}`; promoted here
   so chrome.js can apply it via class instead. */
.main.wide-edge{padding:24px 28px var(--s8);max-width:none;width:100%;}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--s5);margin-bottom:var(--s6);flex-wrap:wrap;}
.page-head .ph-l{min-width:0;}
.eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--blue-4);margin-bottom:10px;display:flex;align-items:center;gap:8px;}
.page-head h1{margin-bottom:8px;}
.page-head .sub{color:var(--fg-3);font-size:15px;max-width:62ch;}
.page-actions{display:flex;gap:var(--s3);flex-wrap:wrap;}

.breadcrumb{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--fg-2);margin-bottom:18px;font-family:var(--font-mono);}
.breadcrumb a:hover{color:var(--fg-1);}
.breadcrumb .sep{opacity:0.5;}

/* ============================================================
   COMPONENTS
   ============================================================ */
.card{
  background:linear-gradient(180deg,rgba(255,255,255,0.018),transparent 40%),var(--bg-1);
  border:1px solid var(--border);border-radius:var(--r-lg);
  box-shadow:var(--shadow-1);
}
.card.pad{padding:var(--s5);}
.card.pad-lg{padding:var(--s6);}
.card-hover{transition:border-color var(--d-sm),transform var(--d-sm),box-shadow var(--d-sm);}
.card-hover:hover{border-color:var(--border-loud);transform:translateY(-2px);box-shadow:var(--shadow-pop);}
a.card-hover:hover{border-color:var(--blue);}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px var(--s5);border-bottom:1px solid var(--border);}
.card-head h2,.card-head h3{display:flex;align-items:center;gap:10px;}
.card-body{padding:var(--s5);}
.card-foot{padding:14px var(--s5);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--fg-2);font-size:12.5px;}

.grid{display:grid;gap:var(--s4);}
.g2{grid-template-columns:repeat(2,1fr);}
.g3{grid-template-columns:repeat(3,1fr);}
.g4{grid-template-columns:repeat(4,1fr);}
.g5{grid-template-columns:repeat(5,1fr);}
.g-auto{grid-template-columns:repeat(auto-fill,minmax(248px,1fr));}
.g-auto-lg{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));}
.row{display:flex;align-items:center;gap:var(--s3);}
.row.wrap{flex-wrap:wrap;}
.col{display:flex;flex-direction:column;gap:var(--s3);}
.spread{display:flex;align-items:center;justify-content:space-between;gap:var(--s3);}
.stack>*+*{margin-top:var(--s4);}
.spacer{flex:1;}

/* stat / KPI tile */
.stat{padding:var(--s5);border-radius:var(--r-lg);background:var(--bg-1);border:1px solid var(--border);position:relative;overflow:hidden;}
.stat .lab{font-family:var(--font-mono);font-size:11px;letter-spacing:0.08em;text-transform:uppercase;color:var(--fg-2);}
.stat .val{font-family:var(--font-display);font-weight:800;font-size:34px;letter-spacing:-0.02em;margin-top:10px;line-height:1;font-variant-numeric:tabular-nums;}
.stat .delta{font-family:var(--font-mono);font-size:12px;margin-top:8px;display:flex;align-items:center;gap:6px;}
.stat .spark{position:absolute;right:0;bottom:0;left:0;height:46px;opacity:0.55;}
.stat.accent{background:linear-gradient(135deg,rgba(23,93,214,0.16),rgba(23,93,214,0.02)),var(--bg-1);border-color:rgba(23,93,214,0.3);}

/* pills / badges / tags */
.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:var(--r-pill);font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:0.03em;line-height:1.6;}
.pill.solid{color:#fff;}
.tag{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:6px;font-family:var(--font-mono);font-size:11px;letter-spacing:0.03em;background:var(--bg-2);color:var(--fg-3);border:1px solid var(--border-strong);}
.tag.blue{background:rgba(23,93,214,0.16);color:var(--blue-4);border-color:rgba(23,93,214,0.3);}
.tag.silver{background:rgba(201,204,212,0.12);color:var(--silver-2);border-color:rgba(201,204,212,0.22);}
.dot-i{width:7px;height:7px;border-radius:50%;flex:none;}

.b-healthy,.pill-healthy{background:rgba(58,209,126,0.16);color:var(--healthy);}
.b-watch,.pill-watch{background:rgba(227,179,65,0.18);color:var(--watch);}
.b-coach,.pill-coach{background:rgba(240,138,60,0.18);color:var(--coach);}
.b-escalate,.pill-escalate{background:rgba(240,88,74,0.18);color:var(--escalate);}
.b-pos{background:rgba(31,157,85,0.16);color:var(--pos);}
.b-neg{background:rgba(214,52,26,0.16);color:#f0584a;}
.b-blue{background:rgba(23,93,214,0.18);color:var(--blue-4);}
.b-neutral{background:var(--bg-2);color:var(--fg-3);}

.bg-healthy{background:rgba(58,209,126,0.07);border-left:3px solid var(--healthy);}
.bg-watch{background:rgba(227,179,65,0.07);border-left:3px solid var(--watch);}
.bg-coach{background:rgba(240,138,60,0.08);border-left:3px solid var(--coach);}
.bg-escalate{background:rgba(240,88,74,0.09);border-left:3px solid var(--escalate);}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;border-radius:var(--r-md);font-family:var(--font-body);font-weight:700;font-size:14px;padding:11px 18px;border:1px solid transparent;transition:transform var(--d-micro),background var(--d-sm),border-color var(--d-sm),box-shadow var(--d-sm);white-space:nowrap;}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 6px 18px -8px var(--blue-glow);}
.btn-primary:hover{background:var(--blue-2);box-shadow:var(--shadow-glow);}
.btn-secondary{background:var(--bg-2);color:var(--fg-1);border-color:var(--border-strong);}
.btn-secondary:hover{border-color:var(--border-loud);background:var(--bg-3);}
.btn-ghost{background:transparent;color:var(--fg-2);}
.btn-ghost:hover{color:var(--fg-1);background:var(--bg-1);}
.btn-danger{background:rgba(240,88,74,0.14);color:var(--escalate);border-color:rgba(240,88,74,0.32);}
.btn-danger:hover{background:rgba(240,88,74,0.22);}
.btn-silver{background:var(--chrome-soft);color:#16181d;font-weight:800;}
.btn-silver:hover{filter:brightness(1.05);}
.btn.sm{padding:7px 13px;font-size:12.5px;border-radius:var(--r-sm);}
.btn.lg{padding:14px 24px;font-size:15px;}
.btn.block{width:100%;justify-content:center;}
.btn[disabled]{opacity:0.5;pointer-events:none;}

/* avatar */
.av{width:38px;height:38px;border-radius:50%;flex:none;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:13px;color:#fff;letter-spacing:-0.01em;background:var(--bg-3);position:relative;}
.av.sm{width:28px;height:28px;font-size:11px;}
.av.lg{width:56px;height:56px;font-size:19px;}
.av.xl{width:84px;height:84px;font-size:28px;}
.av .ring{position:absolute;inset:-3px;border-radius:50%;border:2px solid var(--bg-0);}
.av-stack{display:flex;}
.av-stack .av{box-shadow:0 0 0 2px var(--bg-1);margin-left:-10px;}
.av-stack .av:first-child{margin-left:0;}

/* inputs */
.field{display:flex;flex-direction:column;gap:8px;}
.field label,.flabel{font-weight:700;font-size:13px;color:var(--fg-1);}
.field .hint{font-size:12px;color:var(--fg-2);}
.input,.select,.textarea{
  width:100%;background:var(--bg-inset);border:1px solid var(--border-strong);
  border-radius:var(--r-md);padding:12px 14px;color:var(--fg-1);font-family:var(--font-body);
  font-size:14px;font-weight:500;transition:border-color var(--d-sm),box-shadow var(--d-sm);outline:none;
}
.input::placeholder,.textarea::placeholder{color:var(--fg-2);}
.input:focus,.select:focus,.textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-glow);}
.textarea{min-height:108px;resize:vertical;line-height:1.6;}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%237f7f7f' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;}
/* Native date/time inputs: render the picker (glyph + popup) in dark mode so the calendar
   icon is visible on our dark surfaces (was dark-on-dark). Covers every type=date field. */
input[type="date"],input[type="time"],input[type="datetime-local"],input[type="month"]{color-scheme:dark;}
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator,
input[type="datetime-local"]::-webkit-calendar-picker-indicator{opacity:.85;cursor:pointer;transition:opacity var(--d-sm);}
input[type="date"]::-webkit-calendar-picker-indicator:hover{opacity:1;}
.checkline{display:flex;align-items:flex-start;gap:11px;padding:12px 14px;border:1px solid var(--border-strong);border-radius:var(--r-md);background:var(--bg-inset);cursor:pointer;transition:border-color var(--d-sm);}
.checkline:hover{border-color:var(--border-loud);}
.checkline input{margin-top:2px;accent-color:var(--blue);width:16px;height:16px;}
.seg{display:inline-flex;background:var(--bg-inset);border:1px solid var(--border-strong);border-radius:var(--r-md);padding:4px;gap:4px;}
.seg button{background:none;border:none;color:var(--fg-2);font-weight:700;font-size:13px;padding:7px 14px;border-radius:7px;transition:background var(--d-sm),color var(--d-sm);}
.seg button.on{background:var(--blue);color:#fff;}
.seg button:hover:not(.on){color:var(--fg-1);}

/* table */
.table{width:100%;border-collapse:collapse;}
.table th{font-family:var(--font-mono);font-size:10.5px;letter-spacing:0.09em;text-transform:uppercase;color:var(--fg-2);text-align:left;padding:13px 16px;border-bottom:1px solid var(--border-strong);background:var(--bg-inset);position:sticky;top:0;}
.table td{padding:14px 16px;border-bottom:1px solid var(--border);font-size:13.5px;vertical-align:middle;}
.table tbody tr{transition:background var(--d-micro);}
.table tbody tr:hover{background:var(--bg-1);}
.table tr.clickable{cursor:pointer;}
.table .num{font-family:var(--font-mono);font-variant-numeric:tabular-nums;text-align:right;}
.table-wrap{overflow:auto;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--bg-1);}

/* tabs */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:var(--s5);overflow-x:auto;}
.tab{padding:11px 16px;color:var(--fg-2);font-weight:700;font-size:14px;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--d-sm),border-color var(--d-sm);white-space:nowrap;background:none;border-top:none;border-left:none;border-right:none;}
.tab:hover{color:var(--fg-1);}
.tab.on{color:var(--fg-1);border-bottom-color:var(--blue);}

/* progress */
.bar{height:7px;border-radius:99px;background:var(--bg-3);overflow:hidden;}
.bar>i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--blue-3),var(--blue));}
.bar.healthy>i{background:linear-gradient(90deg,#2bbf6e,var(--healthy));}
.bar.watch>i{background:linear-gradient(90deg,#d8a531,var(--watch));}
.bar.coach>i{background:linear-gradient(90deg,#e07c2f,var(--coach));}
.bar.escalate>i{background:linear-gradient(90deg,#e0463a,var(--escalate));}
.bar.silver>i{background:var(--chrome-soft);}

/* signal grid (MN-249) */
.signals{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;}
.sig{background:var(--bg-inset);border:1px solid var(--border);border-radius:var(--r-md);padding:16px 14px;}
.sig .sl{font-family:var(--font-mono);font-size:10.5px;letter-spacing:0.07em;text-transform:uppercase;color:var(--fg-2);}
.sig .sv{font-family:var(--font-display);font-weight:800;font-size:24px;margin:9px 0 3px;letter-spacing:-0.01em;}
.sig .ss{font-size:11px;color:var(--fg-2);margin-bottom:12px;min-height:15px;}
.sig .sp{display:inline-flex;align-items:center;justify-content:center;min-width:46px;padding:5px 0;border-radius:6px;font-family:var(--font-mono);font-size:12px;font-weight:500;}

/* score ring */
.ring-score{position:relative;width:128px;height:128px;flex:none;}
.ring-score svg{transform:rotate(-90deg);}
.ring-score .rc{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.ring-score .rc b{font-family:var(--font-display);font-weight:800;font-size:34px;letter-spacing:-0.02em;line-height:1;}
.ring-score .rc span{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.1em;color:var(--fg-2);margin-top:5px;}

/* person card */
.pcard{display:flex;flex-direction:column;gap:14px;padding:var(--s5);border-radius:var(--r-lg);background:var(--bg-1);border:1px solid var(--border);transition:border-color var(--d-sm),transform var(--d-sm);}
.pcard:hover{border-color:var(--border-loud);transform:translateY(-2px);}
.pcard .top{display:flex;gap:14px;align-items:center;}
.pcard .nm{font-family:var(--font-display);font-weight:800;font-size:16px;letter-spacing:-0.01em;}
.pcard .rl{font-size:12.5px;color:var(--fg-2);margin-top:3px;}

/* silver star card */
.starcard{position:relative;overflow:hidden;border-radius:var(--r-xl);padding:30px;background:radial-gradient(120% 120% at 0% 0%,rgba(23,93,214,0.18),transparent 50%),linear-gradient(160deg,#20242e,#16181d);border:1px solid var(--border-strong);}
.starcard::after{content:"";position:absolute;right:-60px;top:-60px;width:240px;height:240px;background:var(--chrome);opacity:0.07;border-radius:50%;filter:blur(8px);}
.starcard .star{width:54px;height:54px;display:grid;place-items:center;border-radius:14px;background:var(--chrome);box-shadow:0 8px 22px -8px rgba(0,0,0,0.7);}
.starcard .star svg{filter:drop-shadow(0 1px 1px rgba(0,0,0,0.3));}

/* modal */
.scrim{position:fixed;inset:0;background:rgba(8,9,12,0.72);backdrop-filter:blur(4px);z-index:120;display:grid;place-items:center;padding:24px;opacity:0;pointer-events:none;transition:opacity var(--d-sm);}
.scrim.open{opacity:1;pointer-events:auto;}
.modal{width:min(720px,100%);max-height:88vh;overflow:auto;background:var(--bg-1);border:1px solid var(--border-strong);border-radius:var(--r-xl);box-shadow:var(--shadow-pop);transform:translateY(12px) scale(0.985);transition:transform var(--d-md) var(--ease);}
.scrim.open .modal{transform:none;}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:var(--s5);border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-1);z-index:2;}
.modal-body{padding:var(--s5);}
.modal-foot{padding:var(--s5);border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:12px;position:sticky;bottom:0;background:var(--bg-1);}

/* toast */
.toasts{position:fixed;right:24px;bottom:24px;z-index:200;display:flex;flex-direction:column;gap:10px;}
.toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-3);border:1px solid var(--border-strong);border-radius:var(--r-md);box-shadow:var(--shadow-pop);min-width:280px;animation:toastin var(--d-md) var(--ease);}
.toast .tk{width:8px;height:36px;border-radius:99px;background:var(--blue);flex:none;}
.toast.ok .tk{background:var(--healthy);}
@keyframes toastin{from{opacity:0;transform:translateX(20px);}to{opacity:1;transform:none;}}

/* misc */
.divider{height:1px;background:var(--border);margin:var(--s5) 0;}
.kbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.filterbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:14px 18px;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-lg);margin-bottom:var(--s5);}
.empty{text-align:center;padding:var(--s8) var(--s5);color:var(--fg-2);}
.empty .ei{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;background:var(--bg-2);margin:0 auto 16px;}
.linkrow{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:var(--r-md);transition:background var(--d-sm);}
.linkrow:hover{background:var(--bg-2);}
.legend{display:flex;gap:18px;flex-wrap:wrap;font-family:var(--font-mono);font-size:11px;color:var(--fg-2);}
.legend span{display:flex;align-items:center;gap:7px;}
.note-cb{padding:14px 16px;border-radius:var(--r-md);background:rgba(23,93,214,0.08);border:1px solid rgba(23,93,214,0.2);font-size:13px;color:var(--blue-tint);}
.demo-flag{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:10.5px;letter-spacing:0.06em;text-transform:uppercase;color:var(--watch);background:rgba(227,179,65,0.12);border:1px solid rgba(227,179,65,0.28);padding:5px 11px;border-radius:var(--r-pill);}
.timeline{position:relative;padding-left:26px;}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--border-strong);}
.tl-item{position:relative;padding-bottom:22px;}
.tl-item::before{content:"";position:absolute;left:-23px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--bg-3);border:2px solid var(--blue);}
.tl-item.done::before{background:var(--blue);}

.hide{display:none!important;}
.center{text-align:center;}
.right{text-align:right;}
.mt0{margin-top:0;} .mt1{margin-top:var(--s2);} .mt2{margin-top:var(--s4);} .mt3{margin-top:var(--s5);} .mt4{margin-top:var(--s6);}
.mb0{margin-bottom:0;} .mb1{margin-bottom:var(--s2);} .mb2{margin-bottom:var(--s4);} .mb3{margin-bottom:var(--s5);}
.w-full{width:100%;}
.nowrap{white-space:nowrap;}
.clip{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.fade-in{animation:fadein var(--d-md) var(--ease);}
@keyframes fadein{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}

/* responsive */
@media (max-width:1100px){
  :root{--sidebar-w:212px;}
  .main{padding:var(--s5) var(--s5) var(--s8);}
  .g4{grid-template-columns:repeat(2,1fr);}
  .g5,.signals{grid-template-columns:repeat(3,1fr);}
}
@media (max-width:980px){
  .hgrid{grid-template-columns:1fr!important;}
}
@media (max-width:820px){
  .topbar-brand{min-width:auto;}
  .searchbar{display:none;}
  .sidebar{position:fixed;left:0;top:var(--topbar-h);z-index:90;background:var(--bg-0);transform:translateX(-105%);transition:transform var(--d-md) var(--ease);box-shadow:var(--shadow-pop);}
  .sidebar.open{transform:none;}
  .g2,.g3,.g4{grid-template-columns:1fr;}
  .g5,.signals{grid-template-columns:repeat(2,1fr);}
  .roleswitch .who{display:none;}
  .menu-btn-m{display:grid!important;}
}
.menu-btn-m{display:none;place-items:center;width:38px;height:38px;flex:none;background:var(--bg-inset);border:1px solid var(--border-strong);border-radius:9px;color:var(--fg-1);cursor:pointer;margin-right:2px;}
.menu-btn-m svg{width:20px;height:20px;}
/* tap-away scrim behind the open mobile drawer */
.sidebar-scrim{display:none;position:fixed;inset:var(--topbar-h) 0 0 0;background:rgba(0,0,0,0.5);z-index:89;}
.sidebar-scrim.open{display:block;}
@media print{
  .topbar,.sidebar,.page-actions{display:none!important;}
  body{background:#fff;color:#000;}
  .card{box-shadow:none;border-color:#ddd;}
}
