@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;450;500;550;600;700&family=Instrument+Serif&display=swap');
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#FAFAF7; --surface:#FFFFFF; --ink:#0F1115; --ink2:#3A3F4A; --mute:#6B7280; --line:#ECECE7; --line2:#E5E5DF;
  --pri:#3B5BDB; --pri-ink:#22357A; --pri-soft:#EEF1FE;
  --good:#0E7C5A; --good-soft:#E5F4ED;
  --warn:#A66A00; --warn-soft:#FBEFD6;
  --bad:#B42318; --bad-soft:#FCEAE7;
}
html,body{background:var(--bg);color:var(--ink);font-family:'Inter',sans-serif;font-size:14px;-webkit-font-smoothing:antialiased;letter-spacing:-.005em}
a{color:inherit;text-decoration:none}
.serif{font-family:'Instrument Serif',serif;letter-spacing:0;font-weight:400}
.shell{width:1440px;margin:0 auto;display:grid;grid-template-columns:248px 1fr}

/* sidebar */
.side{position:sticky;top:0;height:100vh;background:#FCFCFA;border-right:1px solid var(--line);display:flex;flex-direction:column;padding:20px 14px}
.brand{display:flex;align-items:center;gap:10px;padding:4px 8px 18px}
.logo{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,#0F1115,#2A2D33);display:grid;place-items:center;color:#fff;font-weight:600;font-size:13px;letter-spacing:-.02em}
.brand-t{font-weight:600;font-size:14.5px;letter-spacing:-.01em}
.brand-s{font-size:11.5px;color:var(--mute)}
.workspace{margin:6px 4px 14px;padding:8px 10px;border:1px solid var(--line);border-radius:8px;display:flex;align-items:center;gap:9px;background:#fff;cursor:pointer}
.workspace .ic{width:22px;height:22px;border-radius:6px;background:#FEF3C7;display:grid;place-items:center;font-size:12px}
.workspace .nm{font-size:12.5px;font-weight:550}
.workspace .sb{font-size:11px;color:var(--mute)}
.workspace .ch{margin-left:auto;color:var(--mute)}
.nav-sec{padding:14px 10px 6px;font-size:11px;color:var(--mute);font-weight:500;letter-spacing:.02em;display:flex;align-items:center;justify-content:space-between}
.nav a{display:flex;align-items:center;gap:10px;padding:7px 10px;margin:1px 0;color:var(--ink2);text-decoration:none;border-radius:6px;font-size:13.5px;font-weight:450;cursor:pointer}
.nav a.active{background:#fff;color:var(--ink);box-shadow:0 0 0 1px var(--line),0 1px 2px rgba(15,17,21,.04);font-weight:550}
.nav a:hover{background:#F4F4F0;color:var(--ink)}
.nav .ic{width:16px;height:16px;display:inline-grid;place-items:center;color:var(--mute);font-size:13px}
.nav a.active .ic{color:var(--pri)}
.nav .badge{margin-left:auto;font-size:11px;color:var(--mute);background:#F2F2EE;padding:1px 7px;border-radius:10px;font-weight:500}
.nav .badge.warn{background:var(--warn-soft);color:var(--warn)}
.nav .badge.bad{background:var(--bad-soft);color:var(--bad)}
.side-foot{margin-top:auto;padding:14px 10px 4px;border-top:1px solid var(--line);display:flex;align-items:center;gap:10px}
.av{width:30px;height:30px;border-radius:50%;background:#1F2937;color:#fff;display:grid;place-items:center;font-size:11.5px;font-weight:600}
.av.lg{width:34px;height:34px;font-size:12.5px}

/* main */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;height:58px;border-bottom:1px solid var(--line);padding:0 28px;gap:14px;background:rgba(250,250,247,.85);backdrop-filter:blur(6px);position:sticky;top:0;z-index:5}
.crumbs{font-size:13px;color:var(--mute)}
.crumbs b{color:var(--ink);font-weight:550}
.search{margin-left:auto;flex:0 0 320px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:7px 12px;color:var(--mute);font-size:13px;display:flex;align-items:center;gap:8px}
.search .kbd{margin-left:auto;font-size:11px;color:var(--mute);border:1px solid var(--line);background:#F7F7F2;padding:1px 6px;border-radius:4px}
.btn{height:34px;padding:0 13px;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:8px;font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:7px;cursor:pointer;font-family:inherit;text-decoration:none}
.btn:hover{background:#F7F7F2}
.btn.pri{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn.pri:hover{background:#22252B}
.btn.danger{background:var(--bad);color:#fff;border-color:var(--bad)}
.btn.danger:hover{background:#9b1d13}
.btn.ghost{background:transparent;border-color:transparent}
.btn.ghost:hover{background:#F4F4F0}
.btn.sm{height:28px;padding:0 10px;font-size:12px;border-radius:7px}
.bell{position:relative;width:34px;height:34px;border:1px solid var(--line);border-radius:8px;background:#fff;display:grid;place-items:center;cursor:pointer}
.bell .dot{position:absolute;top:7px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--bad);box-shadow:0 0 0 2px #fff}

/* page */
.page{padding:24px 28px 60px;display:grid;gap:20px}
.title-row{display:flex;align-items:flex-end;gap:18px;justify-content:space-between;padding-bottom:4px}
.h1{font-size:30px;font-weight:600;letter-spacing:-.02em;line-height:1.15}
.h1 .serif{font-style:italic;font-weight:400;color:var(--ink2)}
.sub{color:var(--mute);font-size:14px;margin-top:6px;max-width:640px;line-height:1.5}
.scope{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.seg{display:inline-flex;background:#fff;border:1px solid var(--line);border-radius:8px;padding:3px;gap:2px}
.seg button{border:0;background:transparent;font:inherit;font-size:12.5px;color:var(--mute);padding:5px 11px;border-radius:6px;cursor:pointer;font-weight:500}
.seg button.on{background:var(--ink);color:#fff}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink2);background:#fff;border:1px solid var(--line);padding:5px 10px;border-radius:999px;font-weight:500}
.pill .gd{width:6px;height:6px;border-radius:50%;background:var(--good)}
.pill .rd{width:6px;height:6px;border-radius:50%;background:var(--bad)}
.pill .yl{width:6px;height:6px;border-radius:50%;background:var(--warn)}

/* INSIGHT BANNER */
.insight{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px 24px;display:grid;grid-template-columns:1fr 280px;gap:24px;box-shadow:0 1px 2px rgba(15,17,21,.03)}
.insight .lab{display:inline-flex;align-items:center;gap:8px;font-size:11.5px;font-weight:600;color:var(--pri);letter-spacing:.06em;text-transform:uppercase}
.insight .lab .sp{width:18px;height:18px;border-radius:6px;background:var(--pri-soft);display:grid;place-items:center;color:var(--pri);font-size:11px}
.insight h2{font-size:22px;line-height:1.3;font-weight:550;margin-top:10px;letter-spacing:-.012em}
.insight h2 em{font-style:normal;background:linear-gradient(transparent 60%, #FBEFD6 60%);padding:0 2px}
.insight .narr{color:var(--ink2);margin-top:10px;line-height:1.55;font-size:13.5px;max-width:620px}
.insight .actions{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}
.conf{background:#FBFBF8;border:1px solid var(--line);border-radius:10px;padding:14px 14px}
.conf .t{font-size:11.5px;color:var(--mute);font-weight:550;letter-spacing:.04em;text-transform:uppercase}
.conf .v{font-size:30px;font-weight:600;letter-spacing:-.02em;margin-top:2px}
.conf .v small{font-size:14px;color:var(--mute);font-weight:500;margin-left:4px}
.conf .ring{display:flex;align-items:center;gap:10px;margin-top:10px}
.conf .bar{flex:1;height:6px;background:#EFEFEA;border-radius:3px;overflow:hidden}
.conf .bar i{display:block;height:100%;background:var(--good);width:78%;border-radius:3px}
.conf .meta{margin-top:10px;font-size:12px;color:var(--mute);line-height:1.5}

/* KPI cards */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.kpis.three{grid-template-columns:repeat(3,1fr)}
.kpi{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px 20px}
.kpi .lbl{font-size:12.5px;color:var(--mute);font-weight:500}
.kpi .val{font-size:30px;font-weight:600;letter-spacing:-.02em;margin-top:6px;display:flex;align-items:baseline;gap:8px}
.kpi .val small{font-size:13px;color:var(--mute);font-weight:500}
.kpi .delta{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:550;padding:2px 8px;border-radius:999px;margin-top:10px}
.delta.up{color:var(--good);background:var(--good-soft)}
.delta.down{color:var(--bad);background:var(--bad-soft)}
.delta.warn{color:var(--warn);background:var(--warn-soft)}
.delta.flat{color:var(--mute);background:#F2F2EE}
.kpi .ctx{font-size:12px;color:var(--mute);margin-top:6px}
.kpi .spark{margin-top:10px;height:34px}

/* GRID */
.grid{display:grid;grid-template-columns:1fr 380px;gap:20px}
.grid.even{grid-template-columns:1fr 1fr}
.card{background:#fff;border:1px solid var(--line);border-radius:12px}
.cardh{padding:18px 22px 12px;display:flex;align-items:flex-start;gap:14px;border-bottom:1px solid var(--line)}
.cardh h3{font-size:15.5px;font-weight:600;letter-spacing:-.01em}
.cardh p{font-size:12.5px;color:var(--mute);margin-top:2px}
.cardh .right{margin-left:auto;display:flex;gap:8px;align-items:center}
.card .pad{padding:18px 22px}

/* MAP */
.mapwrap{position:relative;height:380px;background:linear-gradient(180deg,#FBFBF8,#F4F4EE);border-bottom-left-radius:12px;border-bottom-right-radius:12px;overflow:hidden}
.mapwrap.lg{height:560px}
.gline{position:absolute;height:3px;border-radius:3px;transform-origin:0 0;opacity:.35}
.gline.l1{background:#3B5BDB;width:520px;top:140px;left:80px;transform:rotate(8deg)}
.gline.l2{background:#F5A524;width:480px;top:200px;left:120px;transform:rotate(-4deg)}
.gline.l3{background:#10B981;width:560px;top:260px;left:60px;transform:rotate(14deg)}
.gline.l4{background:#EF4444;width:420px;top:300px;left:200px;transform:rotate(-10deg)}
.dotmap{position:absolute;background-image:radial-gradient(#E2E2DC 1.2px,transparent 1.2px);background-size:18px 18px;inset:0;opacity:.6}
.stn{position:absolute;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 4px rgba(255,255,255,.9)}
.stn.lg{width:18px;height:18px}
.stn.md{width:13px;height:13px}
.stn.sm{width:9px;height:9px}
.stn.crit{background:#B42318}
.stn.high{background:#D97706}
.stn.med{background:#3B5BDB}
.stn.low{background:#0E7C5A}
.stn .lbl{position:absolute;left:14px;top:-6px;font-size:11px;color:var(--ink);background:rgba(255,255,255,.95);padding:2px 7px;border-radius:5px;white-space:nowrap;border:1px solid var(--line);font-weight:500}
.maplegend{position:absolute;left:18px;bottom:16px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 14px;font-size:12px;color:var(--ink2);display:flex;gap:16px;align-items:center;box-shadow:0 4px 12px rgba(15,17,21,.05)}
.maplegend .it{display:flex;align-items:center;gap:7px}
.maplegend .sw{width:9px;height:9px;border-radius:50%}
.mapcap{position:absolute;right:18px;top:16px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 14px;font-size:12px;color:var(--ink2);box-shadow:0 4px 12px rgba(15,17,21,.05)}
.mapcap .lbl{font-size:11px;color:var(--mute);font-weight:500}
.mapcap .val{font-size:18px;font-weight:600;letter-spacing:-.02em}

/* recommendations list */
.recs{display:flex;flex-direction:column}
.rec{padding:16px 22px;border-bottom:1px solid var(--line);display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:flex-start;cursor:pointer}
.rec:hover{background:#FBFBF8}
.rec:last-child{border-bottom:0}
.rec .rank{width:26px;height:26px;border-radius:8px;background:#F2F2EE;color:var(--ink2);display:grid;place-items:center;font-size:12px;font-weight:600;font-variant-numeric:tabular-nums}
.rec.top .rank{background:var(--ink);color:#fff}
.rec .ttl{font-size:13.5px;font-weight:550;letter-spacing:-.005em}
.rec .sub{font-size:12.5px;color:var(--mute);margin-top:4px;line-height:1.5}
.rec .tags{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.tg{font-size:11px;font-weight:500;padding:2px 8px;border-radius:999px;background:#F2F2EE;color:var(--ink2)}
.tg.bad{background:var(--bad-soft);color:var(--bad)}
.tg.warn{background:var(--warn-soft);color:var(--warn)}
.tg.good{background:var(--good-soft);color:var(--good)}
.tg.pri{background:var(--pri-soft);color:var(--pri-ink)}
.rec .conf2{text-align:right;font-size:11px;color:var(--mute);font-weight:500}
.rec .conf2 .pct{font-size:14px;font-weight:600;color:var(--ink);letter-spacing:-.01em}

/* table */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;font-weight:550;color:var(--mute);font-size:11.5px;letter-spacing:.02em;padding:12px 22px;border-bottom:1px solid var(--line);text-transform:uppercase}
.tbl td{padding:13px 22px;border-bottom:1px solid var(--line);color:var(--ink2);vertical-align:middle}
.tbl tr:last-child td{border-bottom:0}
.tbl tr:hover td{background:#FBFBF8}
.tbl .name{color:var(--ink);font-weight:550}
.tbl .name .s{font-size:11.5px;color:var(--mute);font-weight:400;margin-top:2px}
.scorewrap{display:flex;align-items:center;gap:10px;font-variant-numeric:tabular-nums}
.scorewrap .num{font-weight:600;color:var(--ink);width:28px}
.scorewrap .bar{width:70px;height:6px;background:#EFEFEA;border-radius:3px;overflow:hidden}
.scorewrap .bar i{display:block;height:100%}
.dlt{font-size:12px;font-weight:550;font-variant-numeric:tabular-nums}
.dlt.up{color:var(--bad)}.dlt.down{color:var(--good)}.dlt.flat{color:var(--mute)}

/* incident */
.inc-h{padding:16px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.inc-h .tag{font-size:11px;font-weight:600;color:var(--bad);background:var(--bad-soft);padding:3px 9px;border-radius:999px}
.inc-h .ttl{font-size:14.5px;font-weight:600;letter-spacing:-.01em}
.inc-h .meta{font-size:12px;color:var(--mute);margin-left:auto}
.tl{padding:8px 22px 16px}
.evt{position:relative;padding:10px 0 10px 28px}
.evt::before{content:'';position:absolute;left:8px;top:16px;bottom:-6px;width:1px;background:var(--line)}
.evt:last-child::before{display:none}
.evt .nd{position:absolute;left:3px;top:13px;width:11px;height:11px;border-radius:50%;background:#fff;border:2px solid var(--line)}
.evt.act .nd{border-color:var(--pri);background:var(--pri)}
.evt.crit .nd{border-color:var(--bad);background:var(--bad)}
.evt.good .nd{border-color:var(--good);background:var(--good)}
.evt .h{font-size:13px;font-weight:550;color:var(--ink)}
.evt .s{font-size:12px;color:var(--mute);margin-top:2px;line-height:1.5}
.evt .tm{font-size:11.5px;color:var(--mute);float:right;font-variant-numeric:tabular-nums}

/* sla */
.sla{padding:14px 22px 18px}
.sla-row{display:grid;grid-template-columns:140px 1fr 80px 56px;gap:14px;padding:11px 0;align-items:center;border-bottom:1px solid var(--line);font-size:13px}
.sla-row:last-child{border-bottom:0}
.sla-row .ttl{font-weight:550;color:var(--ink)}
.sla-bar{height:8px;background:#EFEFEA;border-radius:4px;overflow:hidden;position:relative}
.sla-bar i{display:block;height:100%;border-radius:4px}
.sla-bar .target{position:absolute;top:-3px;height:14px;width:2px;background:var(--ink2);border-radius:1px}
.sla-row .met{font-size:12.5px;color:var(--mute);text-align:right;font-variant-numeric:tabular-nums}
.sla-row .pct{font-size:13px;font-weight:600;text-align:right;font-variant-numeric:tabular-nums}

/* footer */
.foot{margin-top:20px;padding:18px 28px 28px;display:flex;justify-content:space-between;color:var(--mute);font-size:12px;border-top:1px solid var(--line)}

/* Forms / Inputs */
.field{display:flex;flex-direction:column;gap:6px;font-size:13px}
.field label{font-weight:550;color:var(--ink)}
.field input,.field select,.field textarea{height:38px;padding:0 12px;border:1px solid var(--line);border-radius:8px;background:#fff;font:inherit;font-size:13.5px;color:var(--ink);outline:none}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--pri);box-shadow:0 0 0 3px var(--pri-soft)}
.field textarea{height:auto;padding:10px 12px;min-height:80px;resize:vertical}
.field .hint{color:var(--mute);font-size:11.5px}

/* Login screens */
.auth-shell{min-height:100vh;display:grid;grid-template-columns:1fr 460px;background:var(--bg)}
.auth-side{position:relative;background:linear-gradient(140deg,#0F1115 0%,#1F2937 60%,#22357A 130%);color:#fff;padding:48px 56px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}
.auth-side::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.08) 1.2px,transparent 1.2px);background-size:22px 22px;opacity:.5}
.auth-side .brand{position:relative;display:flex;align-items:center;gap:12px;color:#fff}
.auth-side .brand .logo{background:#fff;color:#0F1115}
.auth-side .brand .brand-t{color:#fff}
.auth-side .brand .brand-s{color:#cfd5e0}
.auth-hero{position:relative;z-index:1}
.auth-hero h1{font-size:40px;font-weight:600;letter-spacing:-.02em;line-height:1.15}
.auth-hero h1 .serif{font-style:italic;font-weight:400;color:#cfd5e0}
.auth-hero p{margin-top:14px;color:#cfd5e0;line-height:1.55;max-width:520px;font-size:14.5px}
.auth-points{position:relative;display:flex;flex-direction:column;gap:10px;margin-top:24px}
.auth-points .pt{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:#dde2ea}
.auth-points .pt .ic{width:20px;height:20px;border-radius:6px;background:rgba(255,255,255,.12);display:grid;place-items:center;font-size:11px;flex:0 0 20px;margin-top:1px}
.auth-foot{position:relative;color:#9aa3b2;font-size:12px}
.auth-form{background:#fff;padding:60px 64px;display:flex;flex-direction:column;justify-content:center;gap:18px;border-left:1px solid var(--line)}
.auth-form .lead{font-size:11.5px;font-weight:600;color:var(--pri);letter-spacing:.06em;text-transform:uppercase}
.auth-form h2{font-size:26px;font-weight:600;letter-spacing:-.015em;line-height:1.2}
.auth-form .role-pick{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.auth-form .role-pick label{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;cursor:pointer;font-size:12.5px;color:var(--ink2)}
.auth-form .role-pick input{accent-color:var(--pri)}
.auth-form .or{display:flex;align-items:center;gap:10px;color:var(--mute);font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;margin:6px 0}
.auth-form .or::before,.auth-form .or::after{content:'';flex:1;height:1px;background:var(--line)}
.auth-form .meta{font-size:11.5px;color:var(--mute);margin-top:8px;line-height:1.5}

/* Mobile preview frame */
.mobile-stage{padding:40px;display:flex;justify-content:center;gap:32px;flex-wrap:wrap;background:#F4F4EE;min-height:100vh}
.phone{width:380px;border-radius:38px;background:#0F1115;padding:14px;box-shadow:0 30px 60px -20px rgba(15,17,21,.35),0 8px 18px -8px rgba(15,17,21,.25)}
.phone-screen{background:var(--bg);border-radius:26px;overflow:hidden;height:780px;display:flex;flex-direction:column;position:relative}
.phone-status{height:30px;background:transparent;display:flex;align-items:center;justify-content:space-between;padding:0 22px;font-size:11.5px;color:var(--ink);font-weight:600}
.phone-top{padding:14px 18px 10px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line);background:#fff}
.phone-top .ttl{font-size:15px;font-weight:600}
.phone-top .sub{font-size:11.5px;color:var(--mute)}
.phone-body{flex:1;overflow:auto;padding:14px 16px 20px;display:flex;flex-direction:column;gap:12px}
.phone-tabbar{height:62px;border-top:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:space-around;padding:0 12px}
.phone-tabbar .tab{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10.5px;color:var(--mute);font-weight:500;cursor:pointer}
.phone-tabbar .tab.on{color:var(--pri)}
.phone-tabbar .tab .ic{font-size:18px}
.mobile-cap{font-size:12px;color:var(--mute);text-align:center;margin-top:14px;font-weight:500}
.assign{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 14px;display:flex;flex-direction:column;gap:6px}
.assign.urgent{border-left:3px solid var(--bad)}
.assign.warn{border-left:3px solid var(--warn)}
.assign.good{border-left:3px solid var(--good)}
.assign .tagrow{display:flex;gap:6px;align-items:center}
.assign .ttl{font-size:14px;font-weight:600;letter-spacing:-.005em;margin-top:2px}
.assign .meta{font-size:12px;color:var(--mute);line-height:1.5;margin-top:2px}
.assign .row{display:flex;align-items:center;gap:8px;margin-top:8px}
.assign .row .btn{flex:1;justify-content:center}
.station-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:8px}
.gauge{position:relative;height:80px;display:flex;align-items:center;justify-content:center}

/* Misc utilities */
.row-flex{display:flex;align-items:center;gap:10px}
.spread{display:flex;align-items:center;justify-content:space-between;gap:10px}
.muted{color:var(--mute)}
.minor{font-size:12px;color:var(--mute)}
.donut{position:relative;width:140px;height:140px;border-radius:50%;background:conic-gradient(var(--good) 0 68%, var(--good-soft) 68% 100%);display:grid;place-items:center}
.donut::after{content:'';position:absolute;inset:14px;background:#fff;border-radius:50%}
.donut .v{position:relative;z-index:1;font-size:28px;font-weight:600;letter-spacing:-.015em}
.donut .v small{font-size:13px;color:var(--mute);font-weight:500;margin-left:2px}

/* Trust composition rows */
.compo{padding:14px 22px 4px}
.compo-row{display:grid;grid-template-columns:140px 1fr 60px 60px;gap:14px;padding:10px 0;align-items:center;border-bottom:1px solid var(--line);font-size:13px}
.compo-row:last-child{border-bottom:0}
.compo-row .ttl{font-weight:550;color:var(--ink)}
.compo-row .b{height:8px;background:#EFEFEA;border-radius:4px;overflow:hidden}
.compo-row .b i{display:block;height:100%;border-radius:4px}
.compo-row .v{text-align:right;font-weight:600;font-variant-numeric:tabular-nums}
.compo-row .w{text-align:right;color:var(--mute);font-size:12px;font-variant-numeric:tabular-nums}

/* Toolbar / filters */
.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:14px 22px;border-bottom:1px solid var(--line)}
.toolbar .field{flex:0 0 220px}
.toolbar .field label{font-size:11px;color:var(--mute);font-weight:500;text-transform:uppercase;letter-spacing:.04em}
.toolbar .field input,.toolbar .field select{height:32px;font-size:12.5px}

/* Mini badge */
.mb{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:550;padding:2px 8px;border-radius:999px;background:#F2F2EE;color:var(--ink2)}
.mb.bad{background:var(--bad-soft);color:var(--bad)}
.mb.warn{background:var(--warn-soft);color:var(--warn)}
.mb.good{background:var(--good-soft);color:var(--good)}
.mb.pri{background:var(--pri-soft);color:var(--pri-ink)}

/* Index splash */
.index-shell{max-width:1180px;margin:0 auto;padding:60px 32px}
.idx-hero{display:grid;grid-template-columns:1.3fr 1fr;gap:32px;align-items:end;padding-bottom:24px;border-bottom:1px solid var(--line)}
.idx-hero h1{font-size:42px;font-weight:600;letter-spacing:-.02em;line-height:1.1}
.idx-hero h1 .serif{font-style:italic;color:var(--ink2)}
.idx-hero p{margin-top:14px;font-size:15px;color:var(--ink2);line-height:1.55;max-width:560px}
.idx-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.idx-stats .s{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px}
.idx-stats .s .lbl{font-size:11.5px;color:var(--mute);font-weight:500}
.idx-stats .s .val{font-size:24px;font-weight:600;letter-spacing:-.015em;margin-top:2px}
.idx-section{margin-top:36px}
.idx-section h2{font-size:18px;font-weight:600;letter-spacing:-.01em}
.idx-section .desc{color:var(--mute);font-size:13px;margin-top:4px;max-width:760px;line-height:1.55}
.idx-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:18px}
.idx-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:10px;text-decoration:none;color:inherit;transition:.15s box-shadow,.15s transform}
.idx-card:hover{box-shadow:0 8px 22px rgba(15,17,21,.07);transform:translateY(-1px)}
.idx-card .badge{font-size:11px;font-weight:550;color:var(--mute);text-transform:uppercase;letter-spacing:.06em}
.idx-card h3{font-size:16px;font-weight:600;letter-spacing:-.01em}
.idx-card p{font-size:13px;color:var(--ink2);line-height:1.5}
.idx-card .ft{margin-top:auto;display:flex;align-items:center;justify-content:space-between;color:var(--pri);font-size:12.5px;font-weight:550;padding-top:6px}
.idx-card .pill{font-size:11px}

/* Banner */
.banner{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 18px;display:flex;align-items:center;gap:14px;color:var(--ink2);font-size:13px}
.banner .ic{width:30px;height:30px;border-radius:8px;background:var(--pri-soft);color:var(--pri);display:grid;place-items:center;font-size:14px}
