/* ===== SHC National Health Intelligence Platform — Design System ===== */
:root{
  /* Saudi Health Council brand: blue-led, green→teal→blue→purple spectrum */
  --teal-900:#063150; --teal-800:#0a4a6e; --teal-700:#0a567f; --teal-600:#0a6ca8;
  --teal-500:#1391b0; --teal-400:#33c0d4; --green-600:#3f9e63; --green-500:#54b87c;
  --shc-blue:#0a6ca8; --shc-teal:#0e9aa8; --shc-green:#4aa85f; --shc-purple:#5b4fa0; --tachy-navy:#314186;
  --ink:#0f172a; --ink-2:#334155; --muted:#64748b; --muted-2:#94a3b8;
  --line:#e2e8f0; --line-2:#eef2f6; --bg:#f4f7fa; --card:#ffffff;
  --amber:#d97706; --amber-bg:#fef3c7; --red:#dc2626; --red-bg:#fee2e2;
  --blue:#0ea5e9; --violet:#8b5cf6;
  --shadow:0 1px 2px rgba(15,23,42,.04),0 8px 24px -12px rgba(15,23,42,.12);
  --shadow-lg:0 24px 60px -20px rgba(8,47,52,.35);
  --r:14px; --r-sm:10px;
  --sidebar:264px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
/* base icon sizing — every inline icon defaults to 18px; contexts override */
.ic{width:18px;height:18px;flex-shrink:0;vertical-align:-3px}
.brand .logo svg,.login .logo svg{width:26px!important;height:26px!important}
.banner .bi svg,.gov-row .gi svg,.drawer-h svg{width:19px;height:19px}
.bigicon svg{width:30px!important;height:30px!important}
.msg .ava svg{width:18px;height:18px}
body{
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  background:var(--bg); color:var(--ink); -webkit-font-smoothing:antialiased;
  font-size:14px; line-height:1.5;
}
body[dir="rtl"]{font-family:"Tahoma","Segoe UI",-apple-system,sans-serif}
button{font-family:inherit;cursor:pointer;border:none;background:none}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px;border:2px solid var(--bg)}
::selection{background:var(--teal-400);color:#042f2e}

/* ---------- Layout ---------- */
.app{display:flex;min-height:100vh}
body[dir="rtl"] .app{flex-direction:row-reverse}
.main{flex:1;min-width:0;display:flex;flex-direction:column}

/* ---------- Sidebar ---------- */
.sidebar{
  width:var(--sidebar);flex-shrink:0;background:linear-gradient(180deg,#05263f,var(--teal-900) 55%,#0a4060);
  color:#cdeaea;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;
}
.brand{padding:12px 14px 10px;border-bottom:1px solid rgba(255,255,255,.08)}
.brandlogo{background:#fff;border-radius:12px;padding:9px 12px;box-shadow:0 6px 18px -8px rgba(0,0,0,.5)}
.brandlogo img{width:100%;height:auto;display:block}
.brandsub{font-size:9px;color:#9fd2e8;margin-top:6px;text-align:center;letter-spacing:.1em;text-transform:uppercase;font-weight:700}
.nav{padding:8px 10px;flex:1;overflow-y:auto}
.nav .group{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:#5fb3ad;margin:9px 12px 3px;font-weight:600}
.nav .group:first-child{margin-top:2px}
.nav a{display:flex;align-items:center;gap:11px;padding:6px 12px;border-radius:9px;color:#bfe6e3;
  font-weight:500;font-size:13px;margin-bottom:1px;transition:.15s;position:relative}
.nav a svg{width:17px;height:17px;opacity:.85;flex-shrink:0}
.nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.nav a.active{background:linear-gradient(90deg,rgba(45,212,191,.22),rgba(45,212,191,.05));color:#fff}
.nav a.active::before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;border-radius:3px;background:var(--teal-400)}
body[dir="rtl"] .nav a.active::before{left:auto;right:0}
.nav a .badge{margin-left:auto;background:var(--red);color:#fff;font-size:10px;font-weight:700;
  padding:1px 7px;border-radius:20px}
body[dir="rtl"] .nav a .badge{margin-left:0;margin-right:auto}
.sidefoot{padding:10px 14px;border-top:1px solid rgba(255,255,255,.08);font-size:10.5px;color:#8fc4dd}
.sidefoot b{color:#bfe0ee}
.poweredby{display:flex;align-items:center;gap:9px;background:#fff;border-radius:10px;padding:8px 12px;margin-bottom:10px}
.poweredby span{font-size:9.5px;color:#475569;font-weight:700;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}
.poweredby img{height:18px;width:auto}
.login-logo img{width:310px;max-width:80%;height:auto;display:block;margin:0 auto}
.login-tachy{display:flex;align-items:center;justify-content:center;gap:9px;margin-top:18px}
.login-tachy span{font-size:11px;color:var(--muted-2);font-weight:600}
.login-tachy img{height:22px;width:auto}

/* ---------- Topbar ---------- */
.topbar{height:62px;background:rgba(255,255,255,.85);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:16px;padding:0 24px;position:sticky;top:0;z-index:20}
.topbar .pagetitle{font-size:17px;font-weight:700;color:var(--ink)}
.topbar .pagesub{font-size:12px;color:var(--muted);margin-top:1px}
.topbar .spacer{flex:1}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:6px 11px;border-radius:9px;
  background:var(--line-2);color:var(--ink-2);border:1px solid var(--line)}
.chip.live{background:#ecfdf5;color:#047857;border-color:#a7f3d0}
.chip .dot{width:7px;height:7px;border-radius:50%;background:#10b981;box-shadow:0 0 0 3px rgba(16,185,129,.18);animation:pulse 2s infinite}
@keyframes pulse{50%{opacity:.4}}
.persona{display:flex;align-items:center;gap:9px;padding:5px 10px 5px 6px;border:1px solid var(--line);border-radius:11px;background:#fff;transition:.15s}
.persona:hover{border-color:var(--teal-400);box-shadow:var(--shadow)}
.persona .av{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--teal-600),var(--teal-800));
  color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px}
.persona .pn{font-size:12.5px;font-weight:700;line-height:1.1}
.persona .pr{font-size:11px;color:var(--muted)}
.langtoggle{display:flex;border:1px solid var(--line);border-radius:9px;overflow:hidden}
.langtoggle button{padding:6px 11px;font-size:12px;font-weight:700;color:var(--muted)}
.langtoggle button.on{background:var(--teal-600);color:#fff}

/* ---------- Content ---------- */
.content{padding:24px;max-width:1500px;width:100%;margin:0 auto;animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.grid{display:grid;gap:16px}
.g-4{grid-template-columns:repeat(4,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-2-1{grid-template-columns:2fr 1fr}
.g-1-2{grid-template-columns:1fr 2fr}
@media(max-width:1100px){.g-4{grid-template-columns:repeat(2,1fr)}.g-3,.g-2,.g-2-1,.g-1-2{grid-template-columns:1fr}}

/* ---------- Cards ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow)}
.card.pad{padding:18px}
.card-h{display:flex;align-items:center;gap:10px;padding:15px 18px;border-bottom:1px solid var(--line-2)}
.card-h h3{margin:0;font-size:14px;font-weight:700}
.card-h .sub{font-size:11.5px;color:var(--muted)}
.card-h .spacer{flex:1}
.card-b{padding:18px}

/* KPI */
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi .kl{font-size:12px;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:7px}
.kpi .kl svg{width:15px;height:15px}
.kpi .kv{font-size:27px;font-weight:800;letter-spacing:-.5px;margin-top:7px;color:var(--ink)}
.kpi .kf{font-size:11.5px;color:var(--muted);margin-top:3px;display:flex;align-items:center;gap:6px}
.kpi .spark{position:absolute;right:14px;bottom:12px;opacity:.85}
body[dir="rtl"] .kpi .spark{right:auto;left:14px}
.delta{font-weight:700;font-size:11.5px;padding:1px 6px;border-radius:6px}
.delta.up{color:#b91c1c;background:#fef2f2}
.delta.down{color:#047857;background:#ecfdf5}
.delta.flat{color:var(--muted);background:var(--line-2)}
.kpi.accent{background:linear-gradient(135deg,var(--teal-800),var(--teal-600));border:none;color:#fff}
.kpi.accent .kl,.kpi.accent .kf{color:#bdeae6}
.kpi.accent .kv{color:#fff}

/* badges / pills */
.pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px}
.pill.alert{background:var(--red-bg);color:#b91c1c}
.pill.watch{background:var(--amber-bg);color:#b45309}
.pill.ok{background:#dcfce7;color:#15803d}
.pill.low{background:#dcfce7;color:#15803d}
.pill.moderate{background:#e0f2fe;color:#0369a1}
.pill.high{background:var(--amber-bg);color:#b45309}
.pill.critical{background:var(--red-bg);color:#b91c1c}
.pill.gray{background:var(--line-2);color:var(--ink-2)}
.tag{font-size:11px;padding:3px 8px;border-radius:7px;background:var(--line-2);color:var(--ink-2);font-weight:600}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 15px;border-radius:10px;font-weight:600;font-size:13px;transition:.15s;border:1px solid transparent}
.btn svg{width:16px;height:16px}
.btn.primary{background:var(--teal-600);color:#fff;box-shadow:0 6px 16px -8px var(--teal-600)}
.btn.primary:hover{background:var(--teal-700)}
.btn.ghost{background:#fff;border-color:var(--line);color:var(--ink-2)}
.btn.ghost:hover{border-color:var(--teal-400);color:var(--teal-700)}
.btn.sm{padding:6px 11px;font-size:12px}

/* tables */
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700;padding:10px 14px;border-bottom:1px solid var(--line)}
body[dir="rtl"] th{text-align:right}
td{padding:11px 14px;border-bottom:1px solid var(--line-2)}
tr:last-child td{border-bottom:none}
tbody tr{transition:.12s}
tbody tr:hover{background:#f8fafc}
.bar-cell{display:flex;align-items:center;gap:9px}
.minibar{height:7px;border-radius:5px;background:var(--line);overflow:hidden;flex:1;min-width:60px}
.minibar i{display:block;height:100%;border-radius:5px}

/* region tile map */
.tilemap{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.tile{aspect-ratio:1.25;border-radius:11px;padding:9px 10px;color:#fff;display:flex;flex-direction:column;justify-content:space-between;
  cursor:pointer;transition:.15s;border:2px solid transparent;position:relative;overflow:hidden}
.tile:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:#fff}
.tile.sel{border-color:var(--ink);outline:2px solid var(--teal-400)}
.tile .tn{font-size:11.5px;font-weight:700;text-shadow:0 1px 3px rgba(0,0,0,.25);line-height:1.1}
.tile .tv{font-size:16px;font-weight:800;text-shadow:0 1px 3px rgba(0,0,0,.3)}
.tile .ts{font-size:9.5px;opacity:.9}

/* copilot */
.copilot-wrap{display:flex;flex-direction:column;height:calc(100vh - 62px)}
.chat-scroll{flex:1;overflow-y:auto;padding:24px;max-width:980px;margin:0 auto;width:100%}
.msg{display:flex;gap:12px;margin-bottom:22px;animation:fade .3s}
.msg .ava{width:34px;height:34px;border-radius:9px;flex-shrink:0;display:grid;place-items:center;font-weight:700;font-size:13px}
.msg.user .ava{background:var(--teal-700);color:#fff}
.msg.ai .ava{background:linear-gradient(135deg,var(--teal-400),var(--green-500));color:#063}
.msg .body{flex:1;min-width:0}
.msg .who{font-size:12px;font-weight:700;color:var(--muted);margin-bottom:5px}
.msg .bubble{font-size:14px;line-height:1.62;color:var(--ink)}
.msg .bubble h4{margin:14px 0 7px;font-size:13.5px}
.msg .bubble p{margin:0 0 9px}
.msg .bubble ul{margin:6px 0 10px;padding-left:20px}
.msg .bubble li{margin:3px 0}
.msg .bubble strong{color:var(--ink)}
.sources{margin-top:12px;padding:11px 13px;background:#f0fdfa;border:1px solid #99f6e4;border-radius:10px}
.sources .sh{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:#0f766e;font-weight:700;margin-bottom:6px;display:flex;align-items:center;gap:6px}
.sources .si{font-size:12px;color:#115e59;display:flex;align-items:center;gap:7px;margin:3px 0}
.sources .si code{background:#ccfbf1;padding:1px 6px;border-radius:5px;font-size:11px}
.trace{margin-top:9px;font-size:11.5px;color:var(--muted);display:flex;flex-wrap:wrap;gap:6px}
.trace .tt{background:var(--line-2);padding:2px 8px;border-radius:6px;font-weight:600;color:var(--ink-2)}
.composer{border-top:1px solid var(--line);background:#fff;padding:14px 24px}
.composer .inner{max-width:980px;margin:0 auto;display:flex;gap:10px;align-items:flex-end}
.composer textarea{flex:1;resize:none;border:1px solid var(--line);border-radius:12px;padding:12px 14px;font:inherit;font-size:14px;max-height:120px;outline:none;transition:.15s}
.composer textarea:focus{border-color:var(--teal-400);box-shadow:0 0 0 3px rgba(45,212,191,.15)}
.suggest{display:flex;flex-wrap:wrap;gap:8px;max-width:980px;margin:0 auto 14px}
.suggest button{font-size:12.5px;padding:8px 13px;border:1px solid var(--line);border-radius:20px;background:#fff;color:var(--ink-2);font-weight:500;transition:.15s}
.suggest button:hover{border-color:var(--teal-400);background:#f0fdfa;color:var(--teal-700)}
.typing span{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--teal-500);margin:0 2px;animation:bounce 1.2s infinite}
.typing span:nth-child(2){animation-delay:.15s}.typing span:nth-child(3){animation-delay:.3s}
@keyframes bounce{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}

/* drawer */
.drawer-bg{position:fixed;inset:0;background:rgba(15,23,42,.4);backdrop-filter:blur(2px);z-index:50;animation:fade .2s}
.drawer{position:fixed;top:0;right:0;bottom:0;width:440px;max-width:92vw;background:#fff;z-index:51;box-shadow:var(--shadow-lg);
  display:flex;flex-direction:column;animation:slideIn .28s cubic-bezier(.2,.8,.2,1)}
body[dir="rtl"] .drawer{right:auto;left:0}
@keyframes slideIn{from{transform:translateX(100%)}to{transform:none}}
.drawer-h{padding:18px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px}
.drawer-h h3{margin:0;font-size:15px;font-weight:700}
.drawer-b{padding:20px;overflow-y:auto;flex:1}
.xbtn{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;color:var(--muted)}
.xbtn:hover{background:var(--line-2)}

/* misc */
.section-title{font-size:13px;font-weight:700;color:var(--ink-2);margin:0 0 10px;display:flex;align-items:center;gap:8px}
.muted{color:var(--muted)}
.hr{height:1px;background:var(--line-2);margin:16px 0}
.flex{display:flex;align-items:center;gap:10px}
.between{display:flex;align-items:center;justify-content:space-between;gap:10px}
.wrap{display:flex;flex-wrap:wrap;gap:8px}
.stat-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line-2);font-size:13px}
.stat-row:last-child{border:none}
.stat-row b{font-weight:700}
.dot-lg{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.legend{display:flex;flex-wrap:wrap;gap:14px;font-size:11.5px;color:var(--muted)}
.legend i{width:10px;height:10px;border-radius:3px;display:inline-block;margin-right:5px;vertical-align:-1px}
.evidence{background:#f8fafc;border:1px solid var(--line);border-left:3px solid var(--teal-500);border-radius:8px;padding:11px 13px;font-size:12.5px;color:var(--ink-2);margin:8px 0}
body[dir="rtl"] .evidence{border-left:1px solid var(--line);border-right:3px solid var(--teal-500)}
.banner{border-radius:12px;padding:14px 18px;display:flex;align-items:center;gap:14px;margin-bottom:18px}
.banner.alert{background:linear-gradient(90deg,#fef2f2,#fff);border:1px solid #fecaca}
.banner .bi{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;flex-shrink:0}
.slider{width:100%;-webkit-appearance:none;height:6px;border-radius:5px;background:var(--line);outline:none}
.slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--teal-600);cursor:pointer;box-shadow:0 2px 6px rgba(13,148,136,.5);border:2px solid #fff}
.seg-card{border:1px solid var(--line);border-radius:12px;padding:15px;transition:.15s;cursor:pointer;background:#fff}
.seg-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.ring{transform:rotate(-90deg)}
.gov-row{display:flex;gap:12px;padding:13px;border:1px solid var(--line);border-radius:11px;margin-bottom:10px;align-items:flex-start}
.gov-row .gi{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;flex-shrink:0}
.kgsvg{width:100%;height:520px;background:radial-gradient(circle at 50% 40%,#f0fdfa,#fff 70%);border-radius:12px;border:1px solid var(--line)}
.kg-node{cursor:pointer;transition:.15s}
.kg-node:hover{filter:brightness(1.08)}
.tooltip{position:fixed;background:var(--ink);color:#fff;font-size:11.5px;padding:6px 10px;border-radius:7px;pointer-events:none;z-index:99;box-shadow:var(--shadow-lg);max-width:220px}
.login{position:fixed;inset:0;background:linear-gradient(135deg,var(--teal-900),var(--teal-700));display:grid;place-items:center;z-index:200}
.login .panel{background:#fff;border-radius:20px;padding:34px;width:440px;max-width:92vw;box-shadow:var(--shadow-lg);animation:fade .4s}
.persona-pick{display:flex;flex-direction:column;gap:10px;margin-top:18px}
.persona-pick button{display:flex;align-items:center;gap:13px;padding:14px;border:1.5px solid var(--line);border-radius:13px;background:#fff;transition:.15s;text-align:left}
.persona-pick button:hover{border-color:var(--teal-500);background:#f0fdfa;transform:translateX(3px)}
.persona-pick .pi{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;color:#fff;flex-shrink:0}

/* ===================== Responsive & overflow fixes ===================== */
html,body{overflow-x:hidden;max-width:100%}
.main{min-width:0}
.grid>*{min-width:0}                 /* stop grid children from expanding their track */
.card,.kpi{min-width:0}
.between,.flex{min-width:0}
.between>*,.flex>*{min-width:0}
.card-h{flex-wrap:wrap}
.card-h h3{min-width:0;overflow:hidden;text-overflow:ellipsis}
.kpi .kv{overflow-wrap:anywhere}

/* topbar */
.topbar{flex-wrap:nowrap}
.hamburger{display:inline-flex;width:38px;height:38px;border-radius:9px;align-items:center;justify-content:center;color:var(--ink-2);flex-shrink:0}
.hamburger:hover{background:var(--line-2)}
.nav-backdrop{display:none}
.tb-title{min-width:0;flex:0 1 auto}
.topbar .pagetitle{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar .pagesub{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.persona{flex-shrink:0;max-width:230px}
.persona-txt{min-width:0;overflow:hidden}
.persona .pn,.persona .pr{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}

/* tables + maps scroll inside their card instead of breaking the page */
.tscroll{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
.tscroll table{min-width:580px}
.tile{aspect-ratio:auto;min-height:60px}
.mapscroll{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
.mapscroll .tilemap{min-width:430px}

/* tablet / small desktop */
@media(max-width:1100px){
  .g-4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .g-3{grid-template-columns:repeat(2,minmax(0,1fr))}
  .g-2,.g-2-1,.g-1-2{grid-template-columns:minmax(0,1fr)}
}

/* collapse the sidebar into an off-canvas drawer */
@media(max-width:900px){
  .hamburger{display:inline-flex}
  .sidebar{position:fixed;left:0;top:0;bottom:0;height:100vh;transform:translateX(-100%);
    transition:transform .25s cubic-bezier(.2,.8,.2,1);z-index:60;box-shadow:var(--shadow-lg)}
  body[dir="rtl"] .sidebar{left:auto;right:0;transform:translateX(100%)}
  .app.nav-open .sidebar{transform:translateX(0)}
  .app.nav-open .nav-backdrop{display:block;position:fixed;inset:0;background:rgba(8,38,63,.45);backdrop-filter:blur(2px);z-index:55;animation:fade .2s}
  .main{width:100%}
  .content{padding:16px}
  .topbar{padding:0 14px;gap:10px}
  .topbar .pagetitle{font-size:15.5px}
}

/* phones */
@media(max-width:620px){
  .g-4,.g-3,.g-2,.g-2-1,.g-1-2{grid-template-columns:1fr}
  .chip.live{display:none}
  .topbar .pagesub{display:none}
  .persona .pn,.persona .pr{display:none}
  .persona{max-width:none;padding:4px}
  .persona .av{width:36px;height:36px}
  .tb-export .tb-lbl{display:none}
  .langtoggle button{padding:6px 9px}
  .content{padding:12px}
  .card-b{padding:14px}
  .banner{flex-direction:column;align-items:flex-start}
  .banner .btn{width:100%;justify-content:center}
  .composer{padding:12px 14px}
  .chat-scroll{padding:16px 14px}
  .suggest{padding-left:14px;padding-right:14px}
  .sidebar{width:86vw;max-width:300px}
}

/* ===== Sidebar collapse (desktop icon-rail) ===== */
.sidebar{transition:width .2s ease}
.brand-mini{display:none;width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,var(--shc-blue),var(--shc-teal));color:#fff;align-items:center;justify-content:center;box-shadow:0 6px 16px -6px rgba(10,108,168,.6)}
.brand-mini svg{width:24px;height:24px}
@media(min-width:901px){
  .app.nav-collapsed{--sidebar:76px}
  .app.nav-collapsed .brandlogo,.app.nav-collapsed .brandsub{display:none}
  .app.nav-collapsed .brand{display:flex;justify-content:center;padding:15px 0}
  .app.nav-collapsed .brand-mini{display:flex}
  .app.nav-collapsed .nav{padding:12px 10px}
  .app.nav-collapsed .nav .group{display:none}
  .app.nav-collapsed .nav a{justify-content:center;padding:11px 0;gap:0}
  .app.nav-collapsed .nav a>span:not(.badge){display:none}
  .app.nav-collapsed .nav a.active::before{display:none}
  .app.nav-collapsed .nav a .badge{position:absolute;top:2px;right:13px;padding:0 5px;min-width:6px}
  .app.nav-collapsed .sidefoot{display:none}
}

/* choropleth region interactions */
.map-regions .region{transition:fill .15s ease,stroke-width .12s ease}
.map-regions .region:hover{stroke:#0a6ca8;stroke-width:1.8;filter:brightness(1.05)}

/* ===================== Onboarding: help, welcome, tour, guide ===================== */
.help-wrap{position:relative}
.iconbtn{padding:7px}
.iconbtn .ic{width:18px;height:18px}
.help-pop{position:absolute;top:calc(100% + 8px);right:0;width:280px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 20px 50px -12px rgba(8,30,50,.35);padding:8px;z-index:45;animation:fade .15s}
body[dir="rtl"] .help-pop{right:auto;left:0}
.help-pop-h{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:6px 8px}
.help-pop-h .ic{width:14px;height:14px}
.help-pop-item{display:flex;align-items:center;gap:11px;width:100%;text-align:left;padding:10px;border:none;background:none;border-radius:10px;cursor:pointer;text-decoration:none;color:inherit}
.help-pop-item:hover{background:#f1f5f9}
.help-pop-item .ic{width:18px;height:18px;color:var(--shc-blue);flex-shrink:0}
.help-pop-item div{display:flex;flex-direction:column;min-width:0}
.help-pop-item b{font-size:13px}
.help-pop-item span{font-size:11px;color:var(--muted)}

.welcome-bg{position:fixed;inset:0;background:rgba(8,30,50,.5);backdrop-filter:blur(3px);z-index:70;animation:fade .2s}
.welcome{position:fixed;z-index:71;top:50%;left:50%;transform:translate(-50%,-50%);width:460px;max-width:92vw;background:#fff;border-radius:20px;box-shadow:0 30px 80px -20px rgba(8,30,50,.6);padding:32px 30px;text-align:center;animation:pop .25s}
.welcome-logo img{height:38px;margin-bottom:14px}
.welcome h2{margin:0 0 10px;font-size:20px;color:var(--shc-blue);line-height:1.3}
.welcome p{margin:0 0 20px;font-size:13.5px;line-height:1.6;color:var(--ink-2)}
.welcome-actions{display:flex;flex-direction:column;gap:10px}
.welcome-actions .btn{width:100%;justify-content:center}
.welcome-skip{margin-top:14px;background:none;border:none;color:var(--muted);font-size:12px;cursor:pointer}
.welcome-skip:hover{color:var(--ink-2)}
@keyframes pop{from{opacity:0;transform:translate(-50%,-46%) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}

.tour-dim{position:fixed;inset:0;background:rgba(8,30,50,.55);z-index:60;animation:fade .2s}
.app.touring .sidebar,.app.touring .topbar{z-index:65}
.tour-spot{outline:3px solid var(--teal-400);outline-offset:2px;border-radius:10px;box-shadow:0 0 0 6px rgba(45,212,191,.25);position:relative}
.tour-card{position:fixed;z-index:66;width:330px;max-width:90vw;background:#fff;border-radius:16px;box-shadow:0 24px 60px -12px rgba(8,30,50,.5);padding:18px 20px;animation:fade .2s}
.tour-step{font-size:11px;font-weight:700;color:var(--teal-600);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:6px;margin-bottom:6px}
.tour-step .ic{width:14px;height:14px}
.tour-card h3{margin:0 0 6px;font-size:16px;color:var(--ink)}
.tour-card p{margin:0;font-size:13px;line-height:1.6;color:var(--ink-2)}
.tour-dots{display:flex;gap:5px;margin:14px 0 12px}
.tour-dot{width:6px;height:6px;border-radius:50%;background:var(--line-2);transition:.2s}
.tour-dot.on{background:var(--teal-500);width:18px;border-radius:3px}
.tour-actions{display:flex;align-items:center;gap:8px}

.sidefoot-guide{display:flex;align-items:center;gap:10px;width:100%;background:rgba(255,255,255,.06);border:none;color:#cdeaea;padding:7px 12px;border-radius:9px;cursor:pointer;font:inherit;font-size:13px;margin-bottom:8px}
.sidefoot-guide:hover{background:rgba(255,255,255,.12);color:#fff}
.sidefoot-guide.active{background:linear-gradient(90deg,rgba(45,212,191,.22),rgba(45,212,191,.05));color:#fff}
.sidefoot-guide .ic{width:18px;height:18px;flex-shrink:0}
.app.nav-collapsed .sidefoot-guide span{display:none}
.app.nav-collapsed .sidefoot-guide{justify-content:center}

.guide{display:grid;grid-template-columns:220px 1fr;gap:30px;align-items:start}
.guide-toc{position:sticky;top:84px;display:flex;flex-direction:column;gap:2px}
.guide-toc-link{text-align:left;background:none;border:none;padding:7px 10px;border-radius:8px;cursor:pointer;font:inherit;font-size:13px;color:var(--ink-2)}
.guide-toc-link:hover{background:#eef4f9;color:var(--shc-blue)}
.guide-body{max-width:800px}
.guide-body section{margin-bottom:30px;scroll-margin-top:84px}
.guide-body h2{display:flex;align-items:center;gap:9px;font-size:18px;color:var(--shc-blue);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.guide-body h2 .ic{width:20px;height:20px;flex-shrink:0}
.guide-body p{font-size:13.5px;line-height:1.7;color:var(--ink-2);margin:0 0 10px}
.guide-list{margin:4px 0;padding-left:18px}
.guide-list li{font-size:13.5px;line-height:1.7;color:var(--ink-2);margin-bottom:8px}
.guide-body code{background:#eef2f7;padding:1px 6px;border-radius:5px;font-size:12px}
body[dir="rtl"] .guide-list{padding-left:0;padding-right:18px}
@media(max-width:860px){.guide{grid-template-columns:1fr}.guide-toc{position:static;flex-direction:row;flex-wrap:wrap;margin-bottom:16px}}

/* Citizen digital twin cards */
.twin-card{transition:transform .15s, box-shadow .15s, border-color .15s}
.twin-card:hover{transform:translateY(-2px);box-shadow:0 14px 34px -16px rgba(8,30,50,.4);border-color:var(--shc-blue)}
.twin-card .minibar{border-radius:4px}
