/* ============================================================================
   ds.css — GAIA Ethiopia design system (v1). Self-contained modern executive-
   dashboard layer refining the GAIA green brand: tokens + app shell + core
   components, light + dark. Replaces shell.css/theme.css on redesigned pages.
   Spec: design-system/MASTER.md.
   ============================================================================ */
@import url('https://api.fontshare.com/v2/css?f[]=ranade@400,500,600,700,800&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

/* ---- tokens: light ---- */
:root{
  --g:#15803d; --g-d:#0b5a2b; --g-bright:#1fa052; --g-soft:#e7f4eb;
  --accent:#b8791c; --accent-soft:#f8ebd3;
  --pos:#15803d; --warn:#c5841f; --danger:#d14b3d; --danger-soft:#fbe7e3;
  --bg:#f4f7f1; --card:#ffffff; --card-2:#fbfcfa;
  --line:#e6ece2; --line-2:#d6dfd0;
  --ink:#14241a; --ink-2:#51614f; --muted:#8a978c;
  --field:#ffffff;
  --e1:0 1px 2px rgba(20,40,25,.05);
  --e2:0 1px 2px rgba(20,40,25,.04), 0 10px 26px -16px rgba(20,40,25,.16);
  --e3:0 1px 3px rgba(20,40,25,.06), 0 22px 44px -22px rgba(20,40,25,.26);
  --r-sm:10px; --r-md:14px; --r-lg:18px;
  --sb1:#15723a; --sb2:#0c5126; --sb3:#06351b;       /* sidebar gradient stops */
  --font:'Ranade',ui-sans-serif,system-ui,sans-serif;
  --ui:'Inter',ui-sans-serif,system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  /* legacy --sh-* aliases so any not-yet-migrated rule still resolves */
  --sh-bg:var(--bg); --sh-card:var(--card); --sh-line:var(--line); --sh-line-2:var(--line-2);
  --sh-ink:var(--ink); --sh-ink-2:var(--ink-2); --sh-muted:var(--muted);
  --sh-accent:var(--g); --sh-accent-d:var(--g-d); --sh-accent-soft:var(--g-soft);
  --sh-shadow:var(--e2); --sh-shadow-sm:var(--e1);
}
:root[data-theme=dark]{
  --g:#4fbe67; --g-d:#8fe0a0; --g-bright:#5ccb74; --g-soft:#16271c;
  --accent:#d8a35c; --accent-soft:#2a2113;
  --pos:#4fbe67; --warn:#e0a13a; --danger:#e8705e; --danger-soft:#2a1714;
  --bg:#0b120e; --card:#131c16; --card-2:#18231b;
  --line:#243029; --line-2:#2c3a30;
  --ink:#e8efe9; --ink-2:#9db3a4; --muted:#7e9285;
  --field:#0f1813;
  --e1:0 1px 2px rgba(0,0,0,.4);
  --e2:0 1px 2px rgba(0,0,0,.4), 0 12px 30px -16px rgba(0,0,0,.7);
  --e3:0 1px 3px rgba(0,0,0,.5), 0 24px 48px -22px rgba(0,0,0,.8);
  --sb1:#0f5a2c; --sb2:#0a4020; --sb3:#062a16;
}

/* ---- base ---- */
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);
  font:14px/1.5 var(--ui);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
h1,h2,h3,h4{font-family:var(--font);letter-spacing:-.02em;margin:0}
a{color:var(--g-d)}
.num,.tnum{font-variant-numeric:tabular-nums}
.muted{color:var(--muted)}
::selection{background:var(--g-soft);color:var(--g-d)}
:focus-visible{outline:2px solid var(--g);outline-offset:2px;border-radius:6px}

/* ---- shell grid ---- */
.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh;background:var(--bg)}

/* ---- sidebar ---- */
.shell .sidebar{position:sticky;top:0;height:100vh;z-index:30;overflow:hidden;padding:0;
  color:#dbeadf;border-right:0;display:flex;flex-direction:column;
  background:linear-gradient(180deg,var(--sb1) 0%,var(--sb2) 52%,var(--sb3) 100%)}
.shell .sidebar::after{content:"";position:absolute;left:-20px;bottom:-30px;width:220px;height:260px;
  background:radial-gradient(120px 150px at 30% 40%,rgba(120,210,150,.16),transparent 70%);pointer-events:none}
.shell .sidebar .brand{background:transparent;margin:0;padding:18px 8px 8px;
  display:flex;align-items:center;justify-content:center}
.shell .sidebar .brand .mark.logo{width:206px;height:96px}
.shell .sidebar .brand .mark.logo img{width:100%;height:100%;object-fit:contain;display:block}
.shell .sidebar .brand>span:not(.mark){display:none}
.shell .sidebar .navlabel{padding:16px 22px 6px;font-size:10px;letter-spacing:.12em;
  text-transform:uppercase;color:#9ec9ac;font-weight:600}
.shell .sidebar nav a{position:relative;display:flex;align-items:center;gap:12px;margin:2px 12px;
  padding:9px 13px;border-radius:12px;color:#cfe4d5;font-weight:500;font-size:13.5px;
  text-decoration:none;transition:background .14s ease,color .14s ease}
.shell .sidebar nav a .ic{width:19px;height:19px;flex:none;display:grid;place-items:center;opacity:.85}
.shell .sidebar nav a .ic svg{width:18px;height:18px}
.shell .sidebar nav a:hover{background:rgba(255,255,255,.09);color:#fff}
.shell .sidebar nav a.active{background:linear-gradient(100deg,#1f9d4d,#15823c);color:#fff;font-weight:600;
  box-shadow:0 8px 20px -10px rgba(20,120,55,.9)}
.shell .sidebar nav a.active .ic{opacity:1}
.shell .sidebar .side-foot{margin-top:auto;padding:14px 16px;border-top:1px solid rgba(255,255,255,.12)}
.shell .sidebar .side-foot .dot{display:none}
.shell .sidebar .account{display:flex;align-items:center;gap:11px;padding:6px;border-radius:12px;transition:background .14s}
.shell .sidebar .account:hover{background:rgba(255,255,255,.07)}
.shell .sidebar .account .av{width:36px;height:36px;border-radius:50%;flex:none;display:grid;place-items:center;
  font-weight:700;font-size:12.5px;color:#fff;background:linear-gradient(145deg,#2bbd57,#0c5a2b)}
.shell .sidebar .account .meta{min-width:0}
.shell .sidebar .account .meta{flex:1}
.shell .sidebar .account .meta b{display:block;color:#eaf5ec;font-size:13px;font-weight:600;line-height:1.3}
.shell .sidebar .account .meta span{display:block;color:#9ec9ac;font-size:11.5px}
.shell .sidebar .account .logout{margin-left:auto;flex:none;width:30px;height:30px;border-radius:9px;border:0;
  background:rgba(255,255,255,.08);color:#cfe4d5;display:grid;place-items:center;cursor:pointer;transition:background .14s,color .14s}
.shell .sidebar .account .logout:hover{background:rgba(255,255,255,.18);color:#fff}
.shell .sidebar .account .logout svg{width:16px;height:16px}
/* legacy: hide any leftover tagline if a page still injects one */
.shell .sidebar .tagline{display:none}

/* ---- main column + top app bar ---- */
.shell .colmain{display:flex;flex-direction:column;background:var(--bg);min-width:0}
.shell .topbar{position:sticky;top:0;z-index:1100;background:var(--card);border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:16px;padding:0 22px;height:60px;transition:box-shadow .16s ease}
.shell .topbar.scrolled{box-shadow:0 6px 20px -16px rgba(20,40,25,.5)}
/* page-title block (section eyebrow + title), set by nav.js */
.pagehead{display:flex;flex-direction:column;justify-content:center;min-width:0;gap:2px}
.pagehead .eyebrow{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700;line-height:1}
.pagehead h1{font-family:var(--font);font-size:17px;font-weight:700;color:var(--ink);line-height:1.15;
  letter-spacing:-.01em;display:flex;align-items:center;gap:8px;white-space:nowrap}
.pagehead h1 .tag,.pagehead h1 .real,.pagehead h1 .demo-tag{font-family:var(--ui);font-size:9.5px;font-weight:700;color:#fff;
  background:var(--accent);border-radius:7px;padding:2px 7px;letter-spacing:.03em;text-transform:uppercase}
/* quick-search / command */
.topsearch{position:relative;flex:1;max-width:420px;margin-left:6px}
.topsearch>svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--muted);pointer-events:none}
.topsearch input[type=text]{width:100%;height:38px;border:1px solid var(--line);border-radius:10px;background:var(--card-2);
  padding:0 12px 0 38px;font:inherit;font-size:13px;color:var(--ink)}
.topsearch input::placeholder{color:var(--muted)}
.topsearch input[type=text]:focus{outline:none;border-color:var(--g);background:var(--card);box-shadow:0 0 0 3px var(--g-soft)}
.navsearch-pop{position:absolute;top:46px;left:0;right:0;background:var(--card);border:1px solid var(--line);
  border-radius:12px;box-shadow:var(--e3);padding:6px;display:none;z-index:1200}
.navsearch-pop.open{display:block}
.navsearch-pop a{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;text-decoration:none;
  color:var(--ink);font-size:13px;font-weight:500}
.navsearch-pop a .ic{width:16px;height:16px;color:var(--muted);display:grid;place-items:center}
.navsearch-pop a .ic svg{width:16px;height:16px}
.navsearch-pop a .sec{margin-left:auto;font-size:11px;color:var(--muted);font-weight:600}
.navsearch-pop a:hover,.navsearch-pop a.sel{background:var(--g-soft);color:var(--g-d)}
.navsearch-pop a:hover .ic,.navsearch-pop a.sel .ic{color:var(--g-d)}
.navsearch-pop .empty{padding:11px;color:var(--muted);font-size:12.5px}
.topbar-tools{display:flex;align-items:center;gap:10px}
.topright{margin-left:auto;display:flex;align-items:center;gap:11px}
.loc{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);
  border-radius:11px;padding:8px 12px;font-weight:600;font-size:13.5px;box-shadow:var(--e1);cursor:pointer}
.loc svg{width:16px;height:16px;color:var(--g)}
.loc select{border:0;background:transparent;font:inherit;font-weight:600;color:var(--ink);outline:none;cursor:pointer}
.iconbtn{width:40px;height:40px;border-radius:50%;background:var(--card);border:1px solid var(--line);
  display:grid;place-items:center;cursor:pointer;position:relative;box-shadow:var(--e1);color:var(--ink-2);
  transition:border-color .14s,transform .14s}
.iconbtn:hover{border-color:var(--line-2);transform:translateY(-1px)}
.iconbtn svg{width:18px;height:18px}
.iconbtn .badge{position:absolute;top:-3px;right:-3px;background:var(--danger);color:#fff;
  font-size:9.5px;font-weight:700;width:16px;height:16px;border-radius:50%;display:grid;place-items:center}
.who{display:flex;align-items:center;gap:9px;background:var(--card);border:1px solid var(--line);
  border-radius:24px;padding:5px 13px 5px 6px;box-shadow:var(--e1)}
.who .av{width:30px;height:30px;border-radius:50%;flex:none;
  background:linear-gradient(145deg,var(--g-bright),var(--g-d));color:#fff;
  display:grid;place-items:center;font-weight:700;font-size:11.5px}
.who b{font-size:13px;color:var(--ink)}

/* ---- cards ---- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--e2)}
.card .ch{display:flex;align-items:center;gap:8px;padding:15px 17px 0}
.card .ch h3{font-size:15px;font-weight:700;letter-spacing:-.01em}
.card .ch .i{color:var(--muted);opacity:.55;width:15px;height:15px}
.card .ch .more{margin-left:auto;font-size:12.5px;color:var(--g-d);font-weight:600;text-decoration:none;
  display:flex;align-items:center;gap:3px}
.card .ch .more:hover{color:var(--g)}

/* ---- KPI ---- */
.kpis{display:grid;gap:14px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:15px 16px;
  display:flex;gap:13px;align-items:flex-start;box-shadow:var(--e2);transition:transform .14s,box-shadow .14s}
.kpi:hover{transform:translateY(-2px);box-shadow:var(--e3)}
.kpi .ic{width:46px;height:46px;border-radius:50%;background:var(--g-soft);display:grid;place-items:center;
  flex:none;color:var(--g);font-weight:700}
.kpi .ic svg{width:22px;height:22px}
.kpi .lab{font-size:12px;color:var(--ink-2);font-weight:500}
.kpi .v{font-size:25px;font-weight:800;letter-spacing:-.02em;line-height:1.15;margin:1px 0;font-variant-numeric:tabular-nums}
.kpi .v small{font-size:13px;font-weight:600;color:var(--ink-2)}
.kpi .d{font-size:11.5px;font-weight:600;display:flex;align-items:center;gap:3px}
.kpi .d.up{color:var(--pos)} .kpi .d.down{color:var(--danger)} .kpi .d.flat{color:var(--ink-2)}

/* ---- buttons / chips / segmented ---- */
button{font:inherit}
.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid transparent;border-radius:10px;
  padding:9px 15px;font-size:13.5px;font-weight:600;cursor:pointer;transition:background .14s,transform .14s}
.btn:hover{transform:translateY(-1px)}
.btn.primary{background:var(--g);color:#fff} .btn.primary:hover{background:var(--g-bright)}
.btn.sec{background:var(--card);color:var(--g-d);border-color:var(--line-2)}
.seg{display:inline-flex;background:var(--card-2);border:1px solid var(--line);border-radius:11px;padding:3px;gap:2px}
.seg button{border:0;background:transparent;color:var(--ink-2);padding:7px 13px;border-radius:8px;cursor:pointer;
  font-size:12.5px;font-weight:600;white-space:nowrap;transition:background .14s,color .14s}
.seg button.on{background:var(--card);color:var(--g-d);box-shadow:var(--e1)}
.chip{font-size:11.5px;font-weight:700;padding:3px 10px;border-radius:9px;white-space:nowrap}
.chip.high,.chip.pos{background:var(--g-soft);color:var(--g-d)}
.chip.med,.chip.warn{background:var(--accent-soft);color:var(--accent)}
.chip.low,.chip.danger{background:var(--danger-soft);color:var(--danger)}

/* ---- form controls ---- */
select,input[type=text],input[type=number]{font:inherit;color:var(--ink);background:var(--field);
  border:1px solid var(--line);border-radius:10px;padding:8px 11px}
input[type=range]{accent-color:var(--g)}
label{font-size:12.5px;font-weight:600;color:var(--ink-2)}

/* ---- tables ---- */
table{border-collapse:collapse;width:100%;font-size:12.5px}
th,td{padding:7px 10px;border-bottom:1px solid var(--line);text-align:left}
th{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700}
td.num{text-align:right;font-variant-numeric:tabular-nums}
tr:last-child td{border-bottom:0}

/* ---- sub-page tab nav ---- */
.subnav{display:flex;gap:4px;padding:2px 26px 0;border-bottom:1px solid var(--line)}
.subnav a{padding:9px 15px;font-size:13.5px;font-weight:600;color:var(--muted);text-decoration:none;
  border-bottom:2px solid transparent;margin-bottom:-1px;display:inline-flex;align-items:center;gap:7px}
.subnav a:hover{color:var(--ink)} .subnav a.active{color:var(--g-d);border-bottom-color:var(--g)}
.subnav a svg{width:15px;height:15px}

/* ---- leaflet polish ---- */
.leaflet-control-zoom{border:0!important;box-shadow:var(--e2)!important}
.leaflet-bar a{background:var(--card);color:var(--ink);border-color:var(--line)}
[data-theme=dark] .leaflet-container{background:#0e1410}
[data-theme=dark] .leaflet-control-attribution{background:rgba(20,28,22,.82)!important;color:#8a9b8f!important}

/* ---- glossary: info icon + definition popover (glossary.js) ---- */
.infodot{display:inline-grid;place-items:center;vertical-align:middle;width:15px;height:15px;flex:none;
  border:0;padding:0;margin:0 0 1px 4px;cursor:pointer;background:var(--muted);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.1' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='9'/><path d='M12 11v5M12 7.6h.01'/></svg>") center/contain no-repeat;
          mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.1' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='9'/><path d='M12 11v5M12 7.6h.01'/></svg>") center/contain no-repeat;
  transition:background .14s}
.infodot:hover,.infodot[aria-expanded=true]{background:var(--g)}
.term{text-decoration:underline dotted;text-underline-offset:3px;text-decoration-color:var(--muted);cursor:help}
.term:hover,.term[aria-expanded=true]{text-decoration-color:var(--g)}
.gloss-pop{position:absolute;z-index:2000;max-width:300px;display:none;background:var(--card);
  border:1px solid var(--line);border-radius:12px;box-shadow:var(--e3);padding:11px 13px;
  font:inherit;font-size:12.5px;line-height:1.5;color:var(--ink-2)}
.gloss-pop.open{display:block}
.gloss-pop[data-pin="0"]{pointer-events:none}
.gloss-pop b{display:block;font-family:var(--font);color:var(--ink);font-size:13px;font-weight:700;margin-bottom:4px;letter-spacing:-.01em}
.gloss-pop p{margin:0}

/* theme.js floating toggle hidden — pages host the toggle in the topbar */
#themeToggle{display:none!important}

/* ---- responsive: collapse sidebar to icons ---- */
@media(max-width:1050px){
  .shell{grid-template-columns:72px 1fr}
  .shell .sidebar .navlabel,.shell .sidebar nav a span:not(.ic),.shell .sidebar .tagline,
  .shell .sidebar .side-foot{display:none}
  .shell .sidebar .brand{margin:0 9px 8px;padding:10px 4px}
  .shell .sidebar .brand .mark.logo{width:44px;height:44px}
  .shell .sidebar nav a{justify-content:center;margin:3px 9px}
}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
}

/* ============================================================================
   Compatibility layer — lets pre-redesign pages drop shell.css + theme.css and
   adopt ds.css with no markup churn. Legacy var names alias to the new tokens
   (so they flip in dark automatically); component fallbacks + dark overrides
   reproduce what theme.css used to provide, retuned to the token palette.
   ============================================================================ */
:root{
  --paper:var(--bg); --soft:var(--g-soft);
  --green:var(--g); --green-d:var(--g-d); --bronze:var(--accent);
  --red:var(--danger); --amber:var(--warn); --amber-bg:var(--accent-soft);
  --al:#bf3b2e; --p:#edb12f; --non:var(--muted);
}
/* Ranade for display, Inter for body — win over any leftover !important rule */
body{font-family:var(--ui)!important}
h1,h2,h3,h4,.big,.kpi .v{font-family:var(--font)!important}

/* component fallbacks (used when a page no longer carries its own) */
.verdict{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:13px 15px;color:var(--ink)}
.verdict.warn{background:var(--accent-soft);border:1px solid var(--line);border-left:3px solid var(--accent)}
.real{background:var(--accent);color:#fff;font-size:10.5px;padding:1px 7px;border-radius:10px;margin-left:8px}
.miniseg button{background:var(--card);color:var(--ink-2);border:1px solid var(--line);border-radius:7px;font-weight:600;cursor:pointer}
.miniseg button.on{background:var(--g-soft);color:var(--g-d);border-color:transparent}
.tabs button{background:var(--card);color:var(--ink-2);border:1px solid var(--line)}
.tabs button.on{background:var(--g);color:#fff;border-color:var(--g)}

/* dark overrides — [data-theme=dark] specificity beats pages' plain selectors */
[data-theme=dark] body{background:var(--bg);color:var(--ink)}
[data-theme=dark] .card,[data-theme=dark] .kpi{background:var(--card);border-color:var(--line)}
[data-theme=dark] aside{background:linear-gradient(180deg,var(--sb1),var(--sb2) 52%,var(--sb3))}
[data-theme=dark] select,[data-theme=dark] input{background:var(--field);color:var(--ink);border-color:var(--line)}
[data-theme=dark] th,[data-theme=dark] td{border-color:var(--line)}
[data-theme=dark] a{color:var(--g-d)}
[data-theme=dark] .info{background:var(--card);color:var(--ink);border-color:var(--line)}
[data-theme=dark] .verdict{background:var(--card);border-color:var(--line);color:var(--ink)}
[data-theme=dark] .verdict.warn{background:var(--accent-soft);border-color:var(--line-2);border-left-color:var(--accent)}
[data-theme=dark] .rec{background:var(--g-soft);border-color:var(--line-2)}
[data-theme=dark] #qbar{background:var(--card-2);border-color:var(--line)}
[data-theme=dark] #qbar .chip{background:var(--card);border-color:var(--line);color:var(--ink-2)}
[data-theme=dark] #qbar .chip.on{background:var(--g);color:#08240e}
[data-theme=dark] #qbar input{background:var(--field);color:var(--ink);border-color:var(--line)}
[data-theme=dark] .tabs button{background:var(--card);color:var(--ink-2);border-color:var(--line)}
[data-theme=dark] .tabs button.on{background:var(--g);color:#08240e;border-color:var(--g)}
[data-theme=dark] .seg button.on{background:var(--card);color:var(--g-d)}
[data-theme=dark] .leaflet-control-attribution{background:rgba(20,28,22,.82)!important;color:#8a9b8f!important}
[data-theme=dark] .leaflet-bar a{background:var(--card);color:var(--ink);border-color:var(--line)}
