/* ============================================================
   HALO SMS — design system
   Theme (light/dark) + Brand (3 schools) via CSS custom props.
   Semantic state colours are FIXED and never re-skinned.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Hanken+Grotesk:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

/* ---------- FIXED semantic states (same in every theme/brand) ---------- */
:root{
  --ok:oklch(0.62 0.13 158);
  --warn:oklch(0.70 0.13 70);
  --bad:oklch(0.585 0.18 25);
  --info:oklch(0.585 0.13 248);

  --r-xl:20px; --r-lg:16px; --r-md:11px; --r-sm:8px; --r-xs:6px;
  --fs-display:"Bricolage Grotesque",sans-serif;
  --fs-body:"Hanken Grotesk",system-ui,sans-serif;
  --fs-mono:"IBM Plex Mono",ui-monospace,monospace;
  --ease:cubic-bezier(.2,.7,.2,1);
}

/* ---------- LIGHT ---------- */
[data-theme="light"]{
  --paper:oklch(0.991 0.004 80);
  --surface:#ffffff;
  --surface-2:oklch(0.974 0.005 75);
  --surface-3:oklch(0.955 0.006 72);
  --ink-900:oklch(0.245 0.012 55);
  --ink-800:oklch(0.32 0.012 55);
  --ink-700:oklch(0.40 0.012 55);
  --ink-600:oklch(0.49 0.012 55);
  --ink-500:oklch(0.575 0.012 55);
  --ink-400:oklch(0.665 0.010 55);
  --line:oklch(0.905 0.006 70);
  --line-soft:oklch(0.945 0.005 72);
  --field:#ffffff;
  --overlay:oklch(0.25 0.02 55 / .42);
  --shadow-sm:0 1px 2px oklch(0.3 0.02 60/.06);
  --shadow:0 1px 2px oklch(0.3 0.02 60/.05),0 8px 24px -14px oklch(0.3 0.02 60/.20);
  --shadow-lg:0 2px 6px oklch(0.3 0.02 60/.07),0 28px 56px -28px oklch(0.3 0.02 60/.30);

  --ok-bg:oklch(0.965 0.03 158);  --ok-fg:oklch(0.46 0.11 158);  --ok-line:oklch(0.87 0.06 158);
  --warn-bg:oklch(0.97 0.04 85);  --warn-fg:oklch(0.50 0.10 65); --warn-line:oklch(0.87 0.08 82);
  --bad-bg:oklch(0.965 0.025 25); --bad-fg:oklch(0.50 0.15 25);  --bad-line:oklch(0.88 0.06 25);
  --info-bg:oklch(0.965 0.025 248);--info-fg:oklch(0.47 0.12 248);--info-line:oklch(0.88 0.05 248);
}

/* ---------- DARK ---------- */
[data-theme="dark"]{
  --paper:oklch(0.185 0.012 55);
  --surface:oklch(0.225 0.012 55);
  --surface-2:oklch(0.255 0.012 55);
  --surface-3:oklch(0.295 0.012 55);
  --ink-900:oklch(0.96 0.005 75);
  --ink-800:oklch(0.90 0.006 75);
  --ink-700:oklch(0.80 0.008 75);
  --ink-600:oklch(0.70 0.009 75);
  --ink-500:oklch(0.62 0.010 75);
  --ink-400:oklch(0.54 0.010 70);
  --line:oklch(0.34 0.012 55);
  --line-soft:oklch(0.30 0.012 55);
  --field:oklch(0.205 0.012 55);
  --overlay:oklch(0.12 0.02 55 / .60);
  --shadow-sm:0 1px 2px oklch(0 0 0/.3);
  --shadow:0 2px 4px oklch(0 0 0/.3),0 10px 30px -16px oklch(0 0 0/.55);
  --shadow-lg:0 4px 10px oklch(0 0 0/.4),0 32px 60px -28px oklch(0 0 0/.65);

  --ok-bg:oklch(0.30 0.05 158);   --ok-fg:oklch(0.82 0.13 158);  --ok-line:oklch(0.42 0.07 158);
  --warn-bg:oklch(0.32 0.05 75);  --warn-fg:oklch(0.85 0.12 82); --warn-line:oklch(0.44 0.07 78);
  --bad-bg:oklch(0.32 0.07 25);   --bad-fg:oklch(0.80 0.14 28);  --bad-line:oklch(0.44 0.10 25);
  --info-bg:oklch(0.30 0.05 248); --info-fg:oklch(0.82 0.11 248);--info-line:oklch(0.44 0.07 248);
}

/* ---------- BRANDS (only --brand + --accent change) ---------- */
[data-brand="bright-future"]{
  --brand:oklch(0.55 0.085 195); --brand-strong:oklch(0.46 0.08 197); --brand-soft:oklch(0.965 0.02 195);
  --accent:oklch(0.78 0.115 84); --on-brand:#ffffff;
}
[data-theme="dark"][data-brand="bright-future"]{ --brand:oklch(0.66 0.09 193); --brand-strong:oklch(0.74 0.09 192); --brand-soft:oklch(0.30 0.04 195); }
[data-brand="crestwood"]{
  --brand:oklch(0.40 0.085 264); --brand-strong:oklch(0.33 0.08 266); --brand-soft:oklch(0.96 0.02 264);
  --accent:oklch(0.74 0.10 86); --on-brand:#ffffff;
}
[data-theme="dark"][data-brand="crestwood"]{ --brand:oklch(0.62 0.10 262); --brand-strong:oklch(0.70 0.10 261); --brand-soft:oklch(0.29 0.05 264); }
[data-brand="little-stars"]{
  --brand:oklch(0.55 0.16 300); --brand-strong:oklch(0.48 0.16 300); --brand-soft:oklch(0.965 0.03 300);
  --accent:oklch(0.72 0.15 30); --on-brand:#ffffff;
}
[data-theme="dark"][data-brand="little-stars"]{ --brand:oklch(0.68 0.16 300); --brand-strong:oklch(0.75 0.15 300); --brand-soft:oklch(0.30 0.06 300); }

/* ============================================================ base */
*{box-sizing:border-box;}
html,body{margin:0;height:100%;}
body{
  background:var(--paper);color:var(--ink-900);
  font-family:var(--fs-body);font-size:15px;line-height:1.5;
  font-feature-settings:"tnum","ss01";
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
#root{height:100%;}
h1,h2,h3,h4,h5{font-family:var(--fs-display);font-weight:700;letter-spacing:-0.02em;margin:0;line-height:1.1;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;color:inherit;}
.mono{font-family:var(--fs-mono);}
.tnum{font-variant-numeric:tabular-nums;}
.naira{font-variant-numeric:tabular-nums;letter-spacing:-0.01em;}
.muted{color:var(--ink-500);}
.eyebrow{font-family:var(--fs-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-500);font-weight:500;}
::selection{background:var(--brand);color:var(--on-brand);}
:focus-visible{outline:2.5px solid var(--brand);outline-offset:2px;border-radius:4px;}
.scroll{scrollbar-width:thin;scrollbar-color:var(--line) transparent;}

/* ============================================================ icon */
.ic{width:1em;height:1em;display:inline-block;vertical-align:-0.125em;flex:none;}
.ic svg{width:100%;height:100%;display:block;}

/* ============================================================ app frame */
.app{display:flex;flex-direction:column;height:100%;min-height:100%;}
.viewport{display:flex;flex:1;min-height:0;}

/* demo strip */
.demobar{display:flex;align-items:center;gap:14px;height:44px;padding:0 16px;
  background:oklch(0.22 0.012 55);color:oklch(0.92 0.005 75);font-size:13px;flex:none;z-index:60;}
.demobar .brandmark{display:flex;align-items:center;gap:8px;font-family:var(--fs-mono);font-size:11.5px;letter-spacing:.10em;color:oklch(0.74 0.006 75);}
.demobar .pulse{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px oklch(0.78 0.115 84/.20);}
.demobar .spacer{flex:1;}
.demobar .ctrls{display:flex;align-items:center;gap:8px;}
.democtrl{position:relative;}
.democtrl > button{display:flex;align-items:center;gap:8px;height:30px;padding:0 10px;border-radius:8px;
  background:oklch(0.28 0.012 55);border:1px solid oklch(0.36 0.012 55);color:oklch(0.88 0.006 75);
  font-size:12.5px;transition:background .15s var(--ease);}
.democtrl > button:hover{background:oklch(0.33 0.012 55);}
.democtrl > button .k{color:oklch(0.66 0.006 75);}
.democtrl > button .ic{font-size:14px;opacity:.7;}
.swatch-dot{width:11px;height:11px;border-radius:3px;flex:none;}

/* dropdown menu (shared) */
.menu{position:absolute;z-index:80;min-width:212px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:6px;overflow:hidden;}
.menu.dark-on-demo{background:oklch(0.255 0.012 55);border-color:oklch(0.36 0.012 55);color:oklch(0.92 0.005 75);}
.menu .mlabel{font-family:var(--fs-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-500);padding:8px 10px 4px;}
.menu.dark-on-demo .mlabel{color:oklch(0.66 0.006 75);}
.mitem{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:8px 10px;border-radius:8px;
  background:none;border:none;color:inherit;font-size:13.5px;transition:background .12s var(--ease);}
.mitem:hover{background:var(--surface-2);}
.menu.dark-on-demo .mitem:hover{background:oklch(0.31 0.012 55);}
.mitem .ic{font-size:15px;color:var(--ink-500);}
.mitem.sel{color:var(--brand);font-weight:600;}
.mitem.sel .ic{color:var(--brand);}
.mitem .tick{margin-left:auto;color:var(--brand);font-size:15px;}
.mitem .sub{display:block;font-size:11.5px;color:var(--ink-500);font-weight:400;}
.mdiv{height:1px;background:var(--line);margin:6px 4px;}
.menu.dark-on-demo .mdiv{background:oklch(0.36 0.012 55);}

/* ============================================================ sidebar */
.sidebar{width:248px;flex:none;background:var(--surface);border-right:1px solid var(--line);
  display:flex;flex-direction:column;min-height:0;}
.sidebar .org{display:flex;align-items:center;gap:11px;padding:18px 18px 16px;}
.logo{width:38px;height:38px;border-radius:11px;background:var(--brand);color:var(--on-brand);
  display:grid;place-items:center;font-family:var(--fs-display);font-weight:800;font-size:17px;flex:none;
  box-shadow:0 2px 8px -2px var(--brand);}
.sidebar .org .nm{font-family:var(--fs-display);font-weight:700;font-size:15.5px;letter-spacing:-0.02em;line-height:1.1;}
.sidebar .org .sub{font-size:11.5px;color:var(--ink-500);margin-top:1px;}
.navscroll{flex:1;overflow-y:auto;padding:6px 12px 16px;min-height:0;}
.navgroup{font-family:var(--fs-mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-400);margin:16px 0 5px 10px;}
.navitem{display:flex;align-items:center;gap:11px;width:100%;text-align:left;padding:9px 11px;margin-bottom:2px;
  border-radius:9px;background:none;border:none;color:var(--ink-700);font-size:14px;font-weight:500;
  transition:background .14s var(--ease),color .14s var(--ease);}
.navitem .ic{font-size:17px;color:var(--ink-500);transition:color .14s var(--ease);}
.navitem:hover{background:var(--surface-2);color:var(--ink-900);}
.navitem:hover .ic{color:var(--ink-700);}
.navitem.on{background:var(--brand-soft);color:var(--brand-strong);font-weight:600;}
.navitem.on .ic{color:var(--brand);}
.navitem .badge{margin-left:auto;font-size:11px;font-weight:600;background:var(--brand);color:var(--on-brand);
  min-width:19px;height:19px;padding:0 5px;border-radius:10px;display:grid;place-items:center;font-variant-numeric:tabular-nums;}
.navitem.on .badge{background:var(--brand);}
.sidebar .foot{border-top:1px solid var(--line);padding:12px;}
.userchip{display:flex;align-items:center;gap:10px;width:100%;padding:8px;border-radius:10px;background:none;border:none;
  color:inherit;transition:background .14s var(--ease);}
.userchip:hover{background:var(--surface-2);}
.userchip .nm{font-size:13.5px;font-weight:600;line-height:1.15;}
.userchip .ro{font-size:11.5px;color:var(--ink-500);}
.userchip .ic{margin-left:auto;color:var(--ink-400);font-size:16px;}

.avatar{border-radius:50%;background:var(--surface-3);color:var(--ink-700);display:grid;place-items:center;
  font-weight:600;flex:none;overflow:hidden;font-family:var(--fs-display);}
.avatar.brand{background:var(--brand);color:var(--on-brand);}
.avatar.accent{background:var(--accent);color:oklch(0.30 0.04 80);}

/* ============================================================ main col */
.maincol{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;}
.topbar{display:flex;align-items:center;gap:14px;height:62px;padding:0 24px;border-bottom:1px solid var(--line);
  background:var(--surface);flex:none;}
.topbar .crumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-500);}
.topbar .crumb .ic{font-size:14px;}
.topbar h1.title{font-size:19px;letter-spacing:-0.02em;}
.topbar .spacer{flex:1;}
.searchbox{display:flex;align-items:center;gap:9px;height:38px;padding:0 13px;border-radius:10px;
  background:var(--surface-2);border:1px solid var(--line);min-width:230px;color:var(--ink-500);}
.searchbox input{flex:1;border:none;background:none;outline:none;color:var(--ink-900);font-size:13.5px;font-family:inherit;}
.searchbox .ic{font-size:16px;}
.searchbox kbd{font-family:var(--fs-mono);font-size:10.5px;color:var(--ink-400);border:1px solid var(--line);border-radius:5px;padding:1px 5px;}
.iconbtn{width:38px;height:38px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line);
  display:grid;place-items:center;color:var(--ink-600);font-size:17px;position:relative;transition:.14s var(--ease);}
.iconbtn:hover{background:var(--surface-3);color:var(--ink-900);}
.iconbtn .dot{position:absolute;top:8px;right:9px;width:7px;height:7px;border-radius:50%;background:var(--bad);border:2px solid var(--surface);}

/* context (role) switcher in top bar — REAL feature */
.ctxswitch{position:relative;}
.ctxswitch > button{display:flex;align-items:center;gap:10px;height:42px;padding:0 8px 0 8px;border-radius:11px;
  background:var(--surface-2);border:1px solid var(--line);color:var(--ink-900);transition:.14s var(--ease);}
.ctxswitch > button:hover{background:var(--surface-3);}
.ctxswitch .who{text-align:left;line-height:1.1;}
.ctxswitch .who .nm{font-size:13px;font-weight:600;}
.ctxswitch .who .ro{font-size:11px;color:var(--ink-500);}
.ctxswitch .ic{color:var(--ink-400);font-size:16px;}

.page{flex:1;overflow-y:auto;min-height:0;}
.page-pad{padding:28px 32px 64px;max-width:1280px;}
.page-pad.wide{max-width:none;}

/* ============================================================ buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:40px;padding:0 16px;border-radius:10px;
  font-size:14px;font-weight:600;border:1px solid transparent;transition:.15s var(--ease);white-space:nowrap;font-family:inherit;}
.btn .ic{font-size:17px;}
.btn-primary{background:var(--brand);color:var(--on-brand);box-shadow:0 1px 2px oklch(0.3 0.02 60/.18);}
.btn-primary:hover{background:var(--brand-strong);}
.btn-primary:active{transform:translateY(.5px);}
.btn-ghost{background:var(--surface-2);color:var(--ink-800);border-color:var(--line);}
.btn-ghost:hover{background:var(--surface-3);}
.btn-quiet{background:none;color:var(--ink-700);}
.btn-quiet:hover{background:var(--surface-2);}
.btn-danger{background:var(--bad);color:#fff;}
.btn-danger:hover{filter:brightness(1.06);}
.btn-danger-soft{background:var(--bad-bg);color:var(--bad-fg);border-color:var(--bad-line);}
.btn-sm{height:33px;padding:0 12px;font-size:13px;border-radius:8px;}
.btn-lg{height:46px;padding:0 22px;font-size:15px;}
.btn-block{width:100%;}
.btn:disabled{opacity:.5;cursor:not-allowed;}

/* ============================================================ cards */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);}
.card-pad{padding:20px;}
.card-h{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 20px;border-bottom:1px solid var(--line);}
.card-h h3{font-size:16px;letter-spacing:-0.01em;}
.card-h .sub{font-size:12.5px;color:var(--ink-500);margin-top:2px;}

/* ============================================================ chips / badges */
.chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 9px;border-radius:999px;
  line-height:1;border:1px solid transparent;white-space:nowrap;}
.chip .d{width:7px;height:7px;border-radius:50%;flex:none;}
.chip .ic{font-size:13px;}
.chip-ok{background:var(--ok-bg);color:var(--ok-fg);border-color:var(--ok-line);}
.chip-ok .d{background:var(--ok);}
.chip-warn{background:var(--warn-bg);color:var(--warn-fg);border-color:var(--warn-line);}
.chip-warn .d{background:var(--warn);}
.chip-bad{background:var(--bad-bg);color:var(--bad-fg);border-color:var(--bad-line);}
.chip-bad .d{background:var(--bad);}
.chip-info{background:var(--info-bg);color:var(--info-fg);border-color:var(--info-line);}
.chip-info .d{background:var(--info);}
.chip-neutral{background:var(--surface-2);color:var(--ink-600);border-color:var(--line);}
.chip-neutral .d{background:var(--ink-400);}

/* ============================================================ forms */
.field{display:flex;flex-direction:column;gap:6px;}
.field label{font-size:13px;font-weight:600;color:var(--ink-800);}
.field .hint{font-size:12px;color:var(--ink-500);}
.field .req{color:var(--bad);}
.input,.select,.textarea{height:42px;padding:0 13px;border-radius:10px;border:1px solid var(--line);background:var(--field);
  color:var(--ink-900);font-size:14px;font-family:inherit;width:100%;transition:.14s var(--ease);}
.textarea{height:auto;padding:11px 13px;resize:vertical;min-height:80px;line-height:1.5;}
.input:focus,.select:focus,.textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px color-mix(in oklch,var(--brand) 18%,transparent);outline:none;}
.input::placeholder,.textarea::placeholder{color:var(--ink-400);}
.input.err,.select.err,.textarea.err{border-color:var(--bad);box-shadow:0 0 0 3px color-mix(in oklch,var(--bad) 14%,transparent);}
.field .errmsg{font-size:12px;color:var(--bad-fg);display:flex;align-items:center;gap:5px;}
.field .errmsg .ic{font-size:13px;}
select.select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23999' stroke-width='2'><path d='m4 6 4 4 4-4'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px;}
.inputwrap{position:relative;display:flex;align-items:center;}
.inputwrap .lead{position:absolute;left:13px;color:var(--ink-500);font-size:14px;pointer-events:none;}
.inputwrap .lead + .input{padding-left:30px;}
.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:3px;gap:2px;}
.seg button{border:none;background:none;padding:7px 13px;border-radius:7px;font-size:13px;font-weight:500;color:var(--ink-600);transition:.14s var(--ease);}
.seg button.on{background:var(--surface);color:var(--ink-900);font-weight:600;box-shadow:var(--shadow-sm);}
.stepbtn{border:none;background:var(--surface-2);color:var(--ink-700);width:34px;height:100%;font-size:18px;font-weight:600;cursor:pointer;transition:.12s var(--ease);}
.stepbtn:hover:not(:disabled){background:var(--surface-3);color:var(--ink-900);}
.stepbtn:disabled{opacity:.4;cursor:not-allowed;}
.armchip{display:inline-flex;align-items:center;gap:2px;background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:3px 4px 3px 9px;height:34px;}
.armchip input{border:none;background:none;outline:none;color:var(--ink-900);font-family:inherit;font-size:13px;font-weight:500;min-width:30px;padding:0;}
.armchip:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px color-mix(in oklch,var(--brand) 16%,transparent);}
.armx{width:20px;height:20px;border:none;border-radius:5px;background:none;color:var(--ink-400);display:grid;place-items:center;cursor:pointer;font-size:11px;flex:none;transition:.12s var(--ease);}
.armx:hover{background:var(--bad-bg);color:var(--bad-fg);}
.checkrow{display:flex;align-items:center;gap:10px;cursor:pointer;}
.checkbox{width:20px;height:20px;border-radius:6px;border:1.5px solid var(--line);background:var(--field);display:grid;place-items:center;flex:none;transition:.14s var(--ease);}
.checkrow:hover .checkbox{border-color:var(--brand);}
.checkbox.on{background:var(--brand);border-color:var(--brand);color:var(--on-brand);}
.checkbox .ic{font-size:13px;opacity:0;}
.checkbox.on .ic{opacity:1;}
.toggle{width:40px;height:23px;border-radius:999px;background:var(--surface-3);border:1px solid var(--line);position:relative;transition:.18s var(--ease);flex:none;}
.toggle .kn{position:absolute;top:2px;left:2px;width:17px;height:17px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:.18s var(--ease);}
.toggle.on{background:var(--brand);border-color:var(--brand);}
.toggle.on .kn{left:19px;}

/* form layout */
.formsec{border-bottom:1px solid var(--line);padding:24px 0;display:grid;grid-template-columns:236px 1fr;gap:32px;}
.formsec:last-child{border-bottom:none;}
.formsec .secinfo h3{font-size:15px;}
.formsec .secinfo p{font-size:13px;color:var(--ink-500);margin-top:5px;line-height:1.5;}
.formsec .secinfo .step{font-family:var(--fs-mono);font-size:11px;color:var(--brand);letter-spacing:.08em;}
.formgrid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.formgrid .full{grid-column:1/-1;}
.formgrid .third{grid-column:span 1;}

/* ============================================================ table */
.tablewrap{overflow-x:auto;}
table.data{width:100%;border-collapse:collapse;}
table.data th{font-family:var(--fs-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-500);
  font-weight:500;text-align:left;padding:11px 14px;border-bottom:1px solid var(--line);white-space:nowrap;}
table.data th.num,table.data td.num{text-align:right;font-variant-numeric:tabular-nums;}
table.data td{padding:13px 14px;border-bottom:1px solid var(--line-soft);font-size:14px;vertical-align:middle;}
table.data tbody tr{transition:background .12s var(--ease);}
table.data tbody tr:hover{background:var(--surface-2);cursor:pointer;}
table.data tbody tr:last-child td{border-bottom:none;}
.cellname{display:flex;align-items:center;gap:11px;}
.cellname .nm{font-weight:600;font-size:14px;}
.cellname .sub{font-size:12px;color:var(--ink-500);}

/* ============================================================ stat tiles */
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;box-shadow:var(--shadow-sm);}
.stat .l{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink-500);font-weight:500;}
.stat .l .ic{font-size:16px;}
.stat .v{font-family:var(--fs-display);font-weight:800;font-size:30px;letter-spacing:-0.02em;margin-top:10px;font-variant-numeric:tabular-nums;line-height:1;}
.stat .d{font-size:12.5px;color:var(--ink-500);margin-top:8px;display:flex;align-items:center;gap:6px;}
.stat .d .up{color:var(--ok-fg);font-weight:600;}
.stat .d .down{color:var(--bad-fg);font-weight:600;}

/* progress bar (fees) */
.bar{height:8px;border-radius:999px;background:var(--surface-3);overflow:hidden;display:flex;}
.bar > i{display:block;height:100%;}
.bar > i.paid{background:var(--ok);}
.bar > i.part{background:var(--warn);}

/* ============================================================ states */
.skel{background:linear-gradient(90deg,var(--surface-2) 0%,var(--surface-3) 50%,var(--surface-2) 100%);
  background-size:200% 100%;animation:shimmer 1.3s var(--ease) infinite;border-radius:7px;}
@keyframes shimmer{to{background-position:-200% 0;}}
.emptystate{display:flex;flex-direction:column;align-items:center;text-align:center;padding:56px 24px;}
.emptystate .glyph{width:64px;height:64px;border-radius:18px;background:var(--surface-2);border:1px solid var(--line);
  display:grid;place-items:center;color:var(--ink-400);font-size:28px;margin-bottom:18px;}
.emptystate h3{font-size:18px;}
.emptystate p{font-size:14px;color:var(--ink-500);max-width:360px;margin:8px 0 20px;line-height:1.55;}
.errorstate .glyph{background:var(--bad-bg);border-color:var(--bad-line);color:var(--bad-fg);}

/* ============================================================ modal */
.scrim{position:fixed;inset:0;background:var(--overlay);backdrop-filter:blur(3px);z-index:100;
  display:flex;align-items:center;justify-content:center;padding:24px;animation:fade .18s var(--ease);}
@keyframes fade{from{opacity:0;}}
.modal{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);
  width:100%;max-width:460px;animation:pop .22s var(--ease);overflow:hidden;}
.modal.lg{max-width:620px;}
@keyframes pop{from{opacity:0;transform:translateY(8px) scale(.98);}}
.modal .mhead{padding:22px 24px 0;}
.modal .mhead .micon{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:21px;margin-bottom:14px;}
.modal .mhead h2{font-size:20px;}
.modal .mhead p{font-size:14px;color:var(--ink-600);margin-top:8px;line-height:1.55;}
.modal .mbody{padding:18px 24px;}
.modal .mfoot{display:flex;gap:10px;justify-content:flex-end;padding:16px 24px 22px;}
.consequence{background:var(--warn-bg);border:1px solid var(--warn-line);color:var(--warn-fg);border-radius:10px;
  padding:12px 14px;font-size:13px;line-height:1.5;display:flex;gap:10px;}
.consequence .ic{font-size:17px;flex:none;margin-top:1px;}

/* ============================================================ toast */
.toaststack{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;gap:10px;align-items:center;}
.toast{display:flex;align-items:center;gap:12px;background:var(--ink-900);color:var(--paper);padding:13px 18px;border-radius:12px;
  box-shadow:var(--shadow-lg);font-size:14px;font-weight:500;animation:toastin .26s var(--ease);max-width:440px;}
@keyframes toastin{from{opacity:0;transform:translateY(14px);}}
.toast .ic{font-size:18px;}
.toast .ok{color:oklch(0.78 0.13 158);}
.toast .bad{color:oklch(0.74 0.16 28);}

/* ============================================================ score grid */
.gridinput{width:58px;height:34px;text-align:center;border:1px solid var(--line);border-radius:8px;background:var(--field);
  color:var(--ink-900);font-family:var(--fs-body);font-size:14px;font-variant-numeric:tabular-nums;transition:.12s var(--ease);}
.gridinput:focus{border-color:var(--brand);box-shadow:0 0 0 3px color-mix(in oklch,var(--brand) 18%,transparent);outline:none;background:var(--brand-soft);}
.gridinput:disabled{background:var(--surface-2);color:var(--ink-400);}
table.scoregrid td{padding-top:7px;padding-bottom:7px;}
table.scoregrid tbody tr:hover{background:transparent;cursor:default;}
.absbtn{cursor:pointer;transition:.12s var(--ease);}

/* ============================================================ misc */
.divider{height:1px;background:var(--line);margin:0;}
.kv{display:flex;flex-direction:column;gap:3px;}
.kv .k{font-size:11.5px;color:var(--ink-500);font-family:var(--fs-mono);letter-spacing:.05em;text-transform:uppercase;}
.kv .v{font-size:14.5px;font-weight:500;}
.tag{font-family:var(--fs-mono);font-size:12px;color:var(--ink-600);background:var(--surface-2);border:1px solid var(--line);border-radius:6px;padding:2px 7px;}
.sectiontitle{display:flex;align-items:center;gap:10px;margin:0 0 16px;}
.sectiontitle h2{font-size:22px;}
.sectiontitle .count{font-size:13px;color:var(--ink-500);font-variant-numeric:tabular-nums;}
.row{display:flex;align-items:center;gap:10px;}
.wrap-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}

/* mobile shells */
.mobile-only{display:none;}
.appbar-m{display:none;}
.tabbar{display:none;}

/* "best on desktop" */
.deskonly{display:flex;flex-direction:column;align-items:center;text-align:center;padding:48px 26px;}
.deskonly .glyph{width:58px;height:58px;border-radius:16px;background:var(--surface-2);border:1px solid var(--line);display:grid;place-items:center;color:var(--ink-400);font-size:26px;margin-bottom:16px;}
.deskonly h3{font-size:18px;}
.deskonly p{font-size:14px;color:var(--ink-500);max-width:320px;margin:8px 0 0;line-height:1.55;}

/* ============================================================ responsive */
@media(max-width:920px){
  .desktop-only{display:none !important;}
  .mobile-only{display:block;}
  .sidebar{display:none;}
  .demobar{height:auto;flex-wrap:wrap;padding:8px 12px;gap:8px;}
  .demobar .brandmark .longlbl{display:none;}
  .topbar{display:none;}
  .appbar-m{display:flex;align-items:center;gap:12px;height:56px;padding:0 16px;background:var(--surface);
    border-bottom:1px solid var(--line);flex:none;position:sticky;top:0;z-index:40;}
  .appbar-m .ttl{font-family:var(--fs-display);font-weight:700;font-size:17px;flex:1;text-align:center;}
  .appbar-m .iconbtn{width:36px;height:36px;}
  .page-pad{padding:18px 16px 96px;}
  .tabbar{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--line);
    z-index:50;padding-bottom:env(safe-area-inset-bottom);}
  .tabbar .tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:9px 0 11px;
    background:none;border:none;color:var(--ink-500);font-size:10.5px;font-weight:500;}
  .tabbar .tab .ic{font-size:21px;}
  .tabbar .tab.on{color:var(--brand);}
  .formsec{grid-template-columns:1fr;gap:14px;}
  .formgrid{grid-template-columns:1fr;}
  .grid-3,.grid-4{grid-template-columns:1fr;}
  .grid-2{grid-template-columns:1fr;}
  .searchbox{min-width:0;}
}
@media(max-width:1180px) and (min-width:921px){
  .grid-4{grid-template-columns:repeat(2,1fr);}
}

/* print — report sheet */
@media print{
  .demobar,.sidebar,.topbar,.appbar-m,.tabbar,.noprint{display:none !important;}
  body,.page,.app{height:auto;overflow:visible;background:#fff;}
  .page-pad{padding:0;max-width:none;}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;transition-duration:.001ms !important;}
}
