/* ==========================================================================
   KNUT CONNECT — Design System
   "Premium civic-tech" — institutional blue + gold, heritage since 1957.
   Display: Fraunces (editorial gravitas)  ·  UI/Body: Hanken Grotesk
   ========================================================================== */

/* ----------------------------- Fonts (vendored, offline) ----------------- */
@font-face{font-family:'Hanken Grotesk';src:url('../fonts/hanken-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('../fonts/hanken-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('../fonts/hanken-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('../fonts/hanken-700.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('../fonts/hanken-800.woff2') format('woff2');font-weight:800;font-style:normal;font-display:swap}
@font-face{font-family:'Fraunces';src:url('../fonts/fraunces-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Fraunces';src:url('../fonts/fraunces-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Fraunces';src:url('../fonts/fraunces-700.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Fraunces';src:url('../fonts/fraunces-900.woff2') format('woff2');font-weight:900;font-style:normal;font-display:swap}
@font-face{font-family:'Fraunces';src:url('../fonts/fraunces-600-italic.woff2') format('woff2');font-weight:600;font-style:italic;font-display:swap}

/* ----------------------------- Design tokens ----------------------------- */
:root{
  /* Brand — union blue */
  --blue-900:#08254f; --blue-800:#0b3d91; --blue-700:#114aa6; --blue-600:#1559c4;
  --blue-500:#1f6fe0; --blue-400:#4d8eea; --blue-300:#8fb6f1; --blue-100:#e4eefc; --blue-50:#f1f6fe;
  /* Navy — command surfaces / sidebar */
  --navy-950:#071529; --navy-900:#0a1f3d; --navy-850:#0d264a; --navy-800:#102d57; --navy-700:#16386a;
  /* Gold — accent */
  --gold-600:#c8860b; --gold-500:#e8a317; --gold-400:#f3b51f; --gold-300:#f8cf5f; --gold-100:#fbeecb; --gold-50:#fdf7e6;
  /* Warm neutrals */
  --ink-900:#13181f; --ink-800:#1f2630; --ink-700:#323b47; --ink-600:#475160; --ink-500:#5b6573;
  --ink-400:#6b7280; --ink-300:#9aa2af; --ink-200:#d8dce3;
  --line:#e7e4dd; --line-soft:#efece5; --line-strong:#d6d2c8;
  --paper:#faf9f6; --paper-2:#f1efe8; --surface:#ffffff; --surface-2:#fbfaf6;
  /* Semantic */
  --green-700:#15673c; --green-600:#1a7f4b; --green-500:#22a05f; --green-100:#e3f3ea; --green-50:#f0f9f3;
  --amber-700:#9a6608; --amber-600:#b8770a; --amber-500:#e09316; --amber-100:#fbeecb; --amber-50:#fdf6e3;
  --red-700:#a3271a; --red-600:#c0392b; --red-500:#dc5546; --red-100:#fae6e2; --red-50:#fdf1ef;
  --teal-600:#0f7d86; --teal-100:#dbf0f1;
  --purple-600:#5b4bb5; --purple-100:#e9e5f8;

  /* Region palette (8 regions) */
  --reg-central:#1f6fe0; --reg-coast:#0f9aa6; --reg-eastern:#7a5cd0; --reg-nyanza:#1a9f64;
  --reg-rift:#e8a317; --reg-western:#d9663e; --reg-ne:#b0476b; --reg-nairobi:#0b3d91;

  /* Typography */
  --font-display:'Fraunces',Georgia,'Times New Roman',serif;
  --font-sans:'Hanken Grotesk',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-mono:'SFMono-Regular',ui-monospace,'JetBrains Mono',Menlo,Consolas,monospace;

  /* Radii */
  --r-xs:6px; --r-sm:9px; --r-md:13px; --r-lg:18px; --r-xl:24px; --r-pill:999px;

  /* Shadows — layered, warm */
  --sh-xs:0 1px 2px rgba(16,28,51,.06);
  --sh-sm:0 1px 2px rgba(16,28,51,.06),0 2px 6px rgba(16,28,51,.05);
  --sh-md:0 2px 6px rgba(16,28,51,.06),0 8px 20px rgba(16,28,51,.07);
  --sh-lg:0 6px 16px rgba(16,28,51,.08),0 18px 46px rgba(16,28,51,.12);
  --sh-xl:0 20px 60px rgba(10,31,61,.22);
  --sh-gold:0 6px 20px rgba(232,163,23,.32);
  --sh-inset:inset 0 1px 0 rgba(255,255,255,.6);

  /* Layout */
  --sidebar-w:272px; --header-h:68px; --bottomnav-h:62px;
  --content-max:1480px;
  --ease:cubic-bezier(.22,.61,.36,1); --ease-out:cubic-bezier(.16,1,.3,1);
}

/* ----------------------------- Reset / base ------------------------------ */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{
  margin:0;font-family:var(--font-sans);color:var(--ink-700);background:var(--paper);
  font-size:14.5px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  font-feature-settings:"cv11","ss01";
}
h1,h2,h3,h4,h5{margin:0;color:var(--ink-900);font-weight:700;line-height:1.18;letter-spacing:-.01em}
p{margin:0}
a{color:var(--blue-600);text-decoration:none}
a:hover{color:var(--blue-700)}
button{font-family:inherit}
img{max-width:100%;display:block}
ul{margin:0;padding:0;list-style:none}
:focus-visible{outline:2.5px solid var(--blue-400);outline-offset:2px;border-radius:4px}
::selection{background:var(--gold-300);color:var(--navy-900)}
*::-webkit-scrollbar{width:11px;height:11px}
*::-webkit-scrollbar-thumb{background:#c9cdd6;border-radius:99px;border:3px solid transparent;background-clip:content-box}
*::-webkit-scrollbar-thumb:hover{background:#aeb4c0;border:3px solid transparent;background-clip:content-box}

/* Display helpers */
.display{font-family:var(--font-display);font-weight:600;letter-spacing:-.02em;color:var(--ink-900)}
.serif{font-family:var(--font-display)}
.num{font-family:var(--font-display);font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.eyebrow{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-400)}
.eyebrow.gold{color:var(--gold-600)}
.muted{color:var(--ink-400)}
.mono{font-family:var(--font-mono);font-size:.86em;letter-spacing:-.01em}
.t-xs{font-size:11.5px}.t-sm{font-size:12.5px}.t-md{font-size:14px}.t-lg{font-size:16px}
.fw-5{font-weight:500}.fw-6{font-weight:600}.fw-7{font-weight:700}.fw-8{font-weight:800}
.upper{text-transform:uppercase;letter-spacing:.06em}

/* ----------------------------- Layout utilities -------------------------- */
.row{display:flex;align-items:center}
.row.between{justify-content:space-between}
.row.center{justify-content:center}
.col{display:flex;flex-direction:column}
.wrap{flex-wrap:wrap}
.gap-2{gap:2px}.gap-4{gap:4px}.gap-6{gap:6px}.gap-8{gap:8px}.gap-10{gap:10px}
.gap-12{gap:12px}.gap-14{gap:14px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}.gap-28{gap:28px}
.grow{flex:1 1 auto;min-width:0}.shrink-0{flex-shrink:0}
.grid{display:grid;gap:18px}
.g-2{grid-template-columns:repeat(2,1fr)}.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}.g-5{grid-template-columns:repeat(5,1fr)}
.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}
.mt-20{margin-top:20px}.mt-24{margin-top:24px}.mt-28{margin-top:28px}.mt-32{margin-top:32px}
.mb-0{margin-bottom:0}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}
.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}
.tc{text-align:center}.tr{text-align:right}.nowrap{white-space:nowrap}
.hide{display:none!important}
.divider{height:1px;background:var(--line);border:0;margin:0}
.vdivider{width:1px;align-self:stretch;background:var(--line)}

/* ----------------------------- Buttons ----------------------------------- */
.btn{
  --bg:var(--surface);--fg:var(--ink-800);--bd:var(--line-strong);
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:40px;padding:0 16px;border-radius:var(--r-sm);border:1px solid var(--bd);
  background:var(--bg);color:var(--fg);font-size:13.5px;font-weight:600;cursor:pointer;
  transition:transform .12s var(--ease),box-shadow .18s var(--ease),background .18s,border-color .18s;
  white-space:nowrap;-webkit-tap-highlight-color:transparent;
}
.btn:hover{box-shadow:var(--sh-sm);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn svg{width:17px;height:17px;flex-shrink:0}
.btn-primary{--bg:linear-gradient(180deg,var(--blue-600),var(--blue-700));--fg:#fff;--bd:transparent;box-shadow:0 1px 0 rgba(255,255,255,.18) inset,0 6px 16px rgba(17,74,166,.28)}
.btn-primary:hover{box-shadow:0 1px 0 rgba(255,255,255,.18) inset,0 10px 24px rgba(17,74,166,.38)}
.btn-gold{--bg:linear-gradient(180deg,var(--gold-400),var(--gold-500));--fg:#3a2906;--bd:transparent;box-shadow:0 1px 0 rgba(255,255,255,.35) inset,var(--sh-gold)}
.btn-dark{--bg:var(--navy-900);--fg:#fff;--bd:transparent}
.btn-ghost{--bg:transparent;--bd:transparent;--fg:var(--ink-600)}
.btn-ghost:hover{--bg:var(--paper-2);box-shadow:none}
.btn-outline{--bg:var(--surface)}
.btn-danger{--bg:var(--red-600);--fg:#fff;--bd:transparent}
.btn-sm{height:32px;padding:0 11px;font-size:12.5px;border-radius:var(--r-xs)}
.btn-sm svg{width:15px;height:15px}
.btn-lg{height:48px;padding:0 22px;font-size:15px}
.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--r-sm)}
.btn-icon.btn-sm{width:32px;height:32px}
.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-md);
  box-shadow:var(--sh-sm);position:relative;
}
.card-pad{padding:20px}
.card-hd{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line-soft)}
.card-hd h3{font-size:15.5px}
.card-bd{padding:20px}
.card-ft{padding:13px 20px;border-top:1px solid var(--line-soft);background:var(--surface-2);border-radius:0 0 var(--r-md) var(--r-md)}
.card-hover{transition:transform .16s var(--ease),box-shadow .2s var(--ease),border-color .2s}
.card-hover:hover{transform:translateY(-3px);box-shadow:var(--sh-md);border-color:var(--line-strong)}
.card-accent::before{content:"";position:absolute;left:0;top:14px;bottom:14px;width:3px;border-radius:0 3px 3px 0;background:var(--blue-600)}
.elev{box-shadow:var(--sh-md)}

/* Stat / KPI card — premium, no border-rule accent */
.stat{position:relative;overflow:hidden;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:18px 18px 16px;box-shadow:var(--sh-sm);transition:transform .16s var(--ease),box-shadow .2s var(--ease),border-color .2s;display:flex;flex-direction:column;height:100%}
.stat:hover{transform:translateY(-2px);box-shadow:var(--sh-md);border-color:var(--line-strong)}
.stat::before{content:"";position:absolute;top:-44px;right:-34px;width:128px;height:128px;border-radius:50%;background:radial-gradient(circle,rgba(21,89,196,.07),transparent 70%);pointer-events:none}
.stat.s-gold::before{background:radial-gradient(circle,rgba(200,134,11,.10),transparent 70%)}
.stat.s-green::before{background:radial-gradient(circle,rgba(26,127,75,.09),transparent 70%)}
.stat.s-red::before{background:radial-gradient(circle,rgba(192,57,43,.09),transparent 70%)}
.stat.s-navy::before{background:radial-gradient(circle,rgba(11,61,145,.09),transparent 70%)}
.stat .stat-top{display:flex;align-items:center;justify-content:space-between;gap:10px;position:relative}
.stat .stat-ico{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;background:var(--blue-50);color:var(--blue-700);flex-shrink:0;box-shadow:inset 0 0 0 1px rgba(21,89,196,.08)}
.stat-spark{display:block;width:100%;height:30px;margin-top:auto;padding-top:12px;position:relative}
.stat.s-gold .stat-ico{background:var(--gold-50);color:var(--gold-600)}
.stat.s-green .stat-ico{background:var(--green-50);color:var(--green-600)}
.stat.s-red .stat-ico{background:var(--red-50);color:var(--red-600)}
.stat .stat-label{font-size:12px;font-weight:600;color:var(--ink-500);letter-spacing:.01em}
.stat .stat-num{font-family:var(--font-display);font-weight:700;font-size:27px;line-height:1.05;color:var(--ink-900);letter-spacing:-.025em;font-variant-numeric:tabular-nums;margin-top:9px}
.stat .stat-sub{margin-top:4px;font-size:12px;color:var(--ink-400)}
.delta{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:700;padding:2px 7px;border-radius:var(--r-pill)}
.delta.up{color:var(--green-600);background:var(--green-50)}
.delta.down{color:var(--red-600);background:var(--red-50)}
.delta.flat{color:var(--ink-500);background:var(--paper-2)}
.delta svg{width:13px;height:13px}

/* ----------------------------- Badges / chips ---------------------------- */
.badge{display:inline-flex;align-items:center;gap:5px;height:22px;padding:0 9px;border-radius:var(--r-pill);font-size:11.5px;font-weight:700;letter-spacing:.01em;background:var(--paper-2);color:var(--ink-600);white-space:nowrap}
.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.badge.b-green{background:var(--green-50);color:var(--green-700)}
.badge.b-amber{background:var(--amber-50);color:var(--amber-700)}
.badge.b-red{background:var(--red-50);color:var(--red-700)}
.badge.b-blue{background:var(--blue-50);color:var(--blue-700)}
.badge.b-gold{background:var(--gold-50);color:var(--gold-600)}
.badge.b-navy{background:var(--navy-900);color:#fff}
.badge.b-teal{background:var(--teal-100);color:var(--teal-600)}
.badge.b-purple{background:var(--purple-100);color:var(--purple-600)}
.badge.b-outline{background:transparent;border:1px solid var(--line-strong);color:var(--ink-600)}
.chip{display:inline-flex;align-items:center;gap:7px;height:30px;padding:0 12px;border-radius:var(--r-pill);font-size:12.5px;font-weight:600;color:var(--ink-600);background:var(--surface);border:1px solid var(--line);cursor:pointer;transition:.15s var(--ease);white-space:nowrap}
.chip:hover{border-color:var(--blue-300);color:var(--blue-700)}
.chip.active{background:var(--navy-900);color:#fff;border-color:var(--navy-900)}
.chip .chip-x{opacity:.6}
.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--r-pill);font-size:11.5px;font-weight:700;background:var(--blue-50);color:var(--blue-700)}

/* ----------------------------- Avatar ------------------------------------ */
.avatar{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:14px;color:#fff;flex-shrink:0;background:var(--blue-600);box-shadow:inset 0 0 0 2px rgba(255,255,255,.35),0 1px 2px rgba(0,0,0,.12);text-transform:uppercase;letter-spacing:.02em}
.avatar.sq{border-radius:11px}
.avatar.xs{width:28px;height:28px;font-size:11px}
.avatar.sm{width:34px;height:34px;font-size:12.5px}
.avatar.lg{width:56px;height:56px;font-size:19px}
.avatar.xl{width:76px;height:76px;font-size:26px;border-radius:18px}
.avatar-ring{box-shadow:inset 0 0 0 2px rgba(255,255,255,.6),0 0 0 2px var(--gold-400),0 2px 6px rgba(0,0,0,.15)}
.avatar-stack{display:flex}
.avatar-stack .avatar{margin-left:-10px;box-shadow:inset 0 0 0 2px #fff,0 0 0 2px #fff}
.avatar-stack .avatar:first-child{margin-left:0}

/* ----------------------------- Tables ------------------------------------ */
.table-wrap{overflow:auto;border-radius:var(--r-md)}
table.k-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13.5px}
.k-table thead th{
  position:sticky;top:0;background:var(--surface-2);text-align:left;font-size:11px;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;color:var(--ink-400);padding:11px 16px;
  border-bottom:1px solid var(--line);white-space:nowrap;z-index:1;
}
.k-table tbody td{padding:13px 16px;border-bottom:1px solid var(--line-soft);color:var(--ink-700);vertical-align:middle}
.k-table tbody tr{transition:background .12s}
.k-table tbody tr:hover{background:var(--blue-50)}
.k-table tbody tr:last-child td{border-bottom:0}
.k-table.rowlink tbody tr{cursor:pointer}
.k-table .cell-strong{font-weight:700;color:var(--ink-900)}
.k-table th.tr,.k-table td.tr{text-align:right}
.k-table th.tc,.k-table td.tc{text-align:center}
.cell-id{font-family:var(--font-mono);font-size:12px;color:var(--ink-400)}
.cell-user{display:flex;align-items:center;gap:10px}
.cell-user .nm{font-weight:600;color:var(--ink-900);line-height:1.2}
.cell-user .sub{font-size:11.5px;color:var(--ink-400)}

/* ----------------------------- Forms ------------------------------------- */
.field{display:flex;flex-direction:column;gap:6px}
.field > label{font-size:12.5px;font-weight:600;color:var(--ink-700)}
.field .hint{font-size:11.5px;color:var(--ink-400)}
.input,.select,.textarea{
  width:100%;height:42px;padding:0 13px;border:1px solid var(--line-strong);border-radius:var(--r-sm);
  background:var(--surface);color:var(--ink-900);font-family:inherit;font-size:14px;transition:.16s var(--ease);
}
.textarea{height:auto;padding:11px 13px;resize:vertical;min-height:92px;line-height:1.5}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--blue-500);box-shadow:0 0 0 4px var(--blue-100)}
.input::placeholder,.textarea::placeholder{color:var(--ink-400)}
.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='%238b95a4' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px;cursor:pointer}
.input-group{position:relative;display:flex;align-items:center}
.input-group .ig-ico{position:absolute;left:12px;color:var(--ink-400);display:grid;place-items:center;pointer-events:none}
.input-group .ig-ico svg{width:17px;height:17px}
.input-group .input{padding-left:38px}
.input-affix{position:absolute;right:1px;top:1px;bottom:1px;display:flex;align-items:center;padding:0 12px;background:var(--paper-2);border-left:1px solid var(--line);border-radius:0 var(--r-sm) var(--r-sm) 0;font-size:12.5px;font-weight:600;color:var(--ink-500)}
.switch{position:relative;width:42px;height:24px;border-radius:99px;background:var(--ink-200);cursor:pointer;transition:.2s;flex-shrink:0}
.switch::after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.25);transition:.2s var(--ease)}
.switch.on{background:var(--blue-600)}
.switch.on::after{left:20px}
.check{width:20px;height:20px;border-radius:6px;border:1.5px solid var(--line-strong);display:grid;place-items:center;cursor:pointer;background:#fff;flex-shrink:0}
.check.on{background:var(--blue-600);border-color:var(--blue-600);color:#fff}
.seg{display:inline-flex;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:3px}
.seg button{border:0;background:transparent;height:30px;padding:0 14px;border-radius:7px;font-size:12.5px;font-weight:600;color:var(--ink-500);cursor:pointer;transition:.15s}
.seg button.active{background:var(--surface);color:var(--ink-900);box-shadow:var(--sh-xs)}

/* ----------------------------- Tabs -------------------------------------- */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);overflow-x:auto}
.tabs button{position:relative;border:0;background:transparent;padding:12px 14px;font-size:13.5px;font-weight:600;color:var(--ink-500);cursor:pointer;white-space:nowrap;transition:color .15s}
.tabs button:hover{color:var(--ink-800)}
.tabs button.active{color:var(--blue-700)}
.tabs button.active::after{content:"";position:absolute;left:10px;right:10px;bottom:-1px;height:2.5px;border-radius:3px 3px 0 0;background:var(--blue-600)}
.tabs button .cnt{margin-left:6px;font-size:11px;padding:1px 6px;border-radius:99px;background:var(--paper-2);color:var(--ink-500)}
.tabs button.active .cnt{background:var(--blue-100);color:var(--blue-700)}

/* ----------------------------- Progress ---------------------------------- */
.bar{height:8px;border-radius:99px;background:var(--paper-2);overflow:hidden}
.bar > i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--blue-600),var(--blue-400))}
.bar.g > i{background:linear-gradient(90deg,var(--green-600),var(--green-500))}
.bar.gold > i{background:linear-gradient(90deg,var(--gold-500),var(--gold-300))}
.bar.red > i{background:linear-gradient(90deg,var(--red-600),var(--red-500))}
.bar.thin{height:5px}
.ring{--p:60;--c:var(--blue-600);--sz:84px;width:var(--sz);height:var(--sz);border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--c) calc(var(--p)*1%),var(--paper-2) 0);position:relative}
.ring::before{content:"";position:absolute;inset:9px;border-radius:50%;background:var(--surface)}
.ring > span{position:relative;font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--ink-900)}

/* ----------------------------- Alerts / notes ---------------------------- */
.note{display:flex;gap:12px;padding:13px 15px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--surface-2)}
.note .note-ico{flex-shrink:0;width:20px;height:20px;color:var(--blue-600)}
.note.n-blue{background:var(--blue-50);border-color:#cfe0fb}
.note.n-gold{background:var(--gold-50);border-color:#f3e2b0}.note.n-gold .note-ico{color:var(--gold-600)}
.note.n-green{background:var(--green-50);border-color:#bfe6cd}.note.n-green .note-ico{color:var(--green-600)}
.note.n-red{background:var(--red-50);border-color:#f3cdc6}.note.n-red .note-ico{color:var(--red-600)}

/* ----------------------------- Timeline ---------------------------------- */
.timeline{position:relative;padding-left:26px}
.timeline::before{content:"";position:absolute;left:8px;top:6px;bottom:6px;width:2px;background:var(--line)}
.tl-item{position:relative;padding:0 0 18px}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{content:"";position:absolute;left:-22px;top:3px;width:11px;height:11px;border-radius:50%;background:var(--surface);border:2.5px solid var(--blue-500);box-shadow:0 0 0 3px var(--blue-50)}
.tl-item.gold::before{border-color:var(--gold-500);box-shadow:0 0 0 3px var(--gold-50)}
.tl-item.green::before{border-color:var(--green-500);box-shadow:0 0 0 3px var(--green-50)}
.tl-time{font-size:11.5px;color:var(--ink-400);font-weight:600}

/* ----------------------------- Empty / skeleton -------------------------- */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:46px 20px;color:var(--ink-400)}
.empty .empty-ico{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;background:var(--paper-2);color:var(--ink-300);margin-bottom:14px}
.skl{background:linear-gradient(90deg,var(--paper-2) 25%,#fff 37%,var(--paper-2) 63%);background-size:400% 100%;animation:skl 1.4s ease infinite;border-radius:6px}
@keyframes skl{0%{background-position:100% 0}100%{background-position:-100% 0}}

/* ----------------------------- Tooltip ----------------------------------- */
[data-tip]{position:relative}
[data-tip]:hover::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--navy-900);color:#fff;font-size:11.5px;font-weight:600;padding:5px 9px;border-radius:7px;white-space:nowrap;box-shadow:var(--sh-md);z-index:50;pointer-events:none}

/* ----------------------------- Section header ---------------------------- */
.sec-hd{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:16px}
.sec-hd .sec-title{font-family:var(--font-display);font-weight:600;font-size:20px;color:var(--ink-900);letter-spacing:-.02em}
.sec-hd .sec-sub{font-size:13px;color:var(--ink-400);margin-top:2px}

/* ----------------------------- Animations -------------------------------- */
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
.rise{opacity:0;animation:rise .5s var(--ease-out) forwards}
.fade{animation:fade .4s ease forwards}
.d1{animation-delay:.04s}.d2{animation-delay:.08s}.d3{animation-delay:.12s}.d4{animation-delay:.16s}
.d5{animation-delay:.2s}.d6{animation-delay:.24s}.d7{animation-delay:.28s}.d8{animation-delay:.32s}
@media (prefers-reduced-motion:reduce){*{animation-duration:.001s!important;animation-delay:0!important;transition-duration:.001s!important}}

/* region dot helper */
.rdot{width:9px;height:9px;border-radius:50%;flex-shrink:0;display:inline-block}
