*,*::before,*::after{box-sizing:border-box}
:root{
  color-scheme:dark;
  --bg:#140a07;
  --bg-2:#0f172a;
  --panel:rgba(35,20,15,0.78);
  --panel-2:rgba(63,35,24,0.62);
  --border:rgba(236,176,104,0.18);
  --text:#fff4e7;
  --text-soft:#dfc7b3;
  --text-muted:#b08972;
  --accent:#ffb36b;
  --accent-2:#ffd66e;
  --accent-3:#ff8d5c;
  --surface-wash:rgba(255,179,107,0.08);
  --warn:#fbbf24;
  --shadow:0 16px 48px -16px rgba(0,0,0,0.6);
  --radius:18px;
}
[data-theme="forest"]{
  --bg:#07110d;
  --bg-2:#102118;
  --panel:rgba(10,24,18,0.82);
  --panel-2:rgba(20,47,34,0.62);
  --border:rgba(111,183,140,0.18);
  --text:#edf7ef;
  --text-soft:#bdd7c3;
  --text-muted:#7e9e86;
  --accent:#77d39b;
  --accent-2:#c3f08f;
  --accent-3:#5ab49a;
  --surface-wash:rgba(119,211,155,0.08);
}
[data-theme="civic"]{
  --bg:#0e1116;
  --bg-2:#151a22;
  --panel:rgba(20,26,34,0.82);
  --panel-2:rgba(34,43,56,0.68);
  --border:rgba(234,117,84,0.18);
  --text:#f6f5f1;
  --text-soft:#cac7bd;
  --text-muted:#98948b;
  --accent:#f07d57;
  --accent-2:#f2b45d;
  --accent-3:#c85844;
  --surface-wash:rgba(240,125,87,0.08);
}
html,body{margin:0;padding:0}
body{
  font-family:'IBM Plex Sans','Inter',system-ui,sans-serif;
  background:radial-gradient(1200px 800px at 20% -10%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 60%),
             radial-gradient(900px 700px at 110% 10%, color-mix(in srgb, var(--accent-2) 16%, transparent), transparent 55%),
             radial-gradient(800px 640px at 50% 110%, color-mix(in srgb, var(--accent-3) 12%, transparent), transparent 62%),
             linear-gradient(180deg,var(--bg) 0%,color-mix(in srgb, var(--bg-2) 76%, #000) 60%,#050505 100%);
  color:var(--text); min-height:100vh; line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--accent);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .18s ease, color .18s ease}
a:hover,a:focus-visible{color:var(--accent-2);border-bottom-color:currentColor;outline:none}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:6px}
h1,h2,h3,h4{font-family:'Exo 2','IBM Plex Sans',sans-serif;letter-spacing:-0.01em;line-height:1.2;margin:0 0 .6em}
h1{font-size:clamp(2rem,4.5vw,3.2rem);font-weight:800}
h2{font-size:clamp(1.4rem,2.6vw,1.85rem);font-weight:700;margin-top:2.2em}
h3{font-size:1.15rem;font-weight:600;margin-top:1.6em;color:color-mix(in srgb, var(--text) 84%, white)}
h4{font-size:.95rem;font-weight:600;color:color-mix(in srgb, var(--text) 82%, white);margin:0 0 .5em}
p{margin:0 0 1em;color:var(--text-soft)}
strong{color:var(--text)}
code,kbd{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:.92em;background:var(--surface-wash);padding:.08em .35em;border-radius:4px;color:var(--accent-2)}
hr{border:none;border-top:1px solid var(--border);margin:2em 0}

.site-nav{
  position:sticky;top:0;z-index:40;
  display:flex;align-items:center;gap:24px;padding:14px 28px;
  background:linear-gradient(180deg,rgba(2,11,22,0.94),rgba(2,11,22,0.78));
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
}
.site-brand{display:flex;align-items:center;gap:12px;color:var(--text);border:none}
.site-brand:hover{color:var(--text)}
.site-brand-mark{
  width:38px;height:38px;border-radius:11px;
  display:grid;place-items:center;font-family:'Exo 2',sans-serif;font-weight:800;font-size:1.15rem;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#1c110d;
  box-shadow:0 10px 28px -14px color-mix(in srgb, var(--accent) 72%, transparent);
}
.site-brand-text strong{display:block;font-size:1.05rem;font-family:'Exo 2',sans-serif;font-weight:700;letter-spacing:.01em}
.site-brand-text small{display:block;font-size:.72rem;color:var(--text-muted);letter-spacing:.02em}
.site-nav-links{display:flex;flex-wrap:wrap;gap:6px;flex:1;justify-content:center}
.site-nav-links a{
  padding:7px 12px;border-radius:10px;font-size:.88rem;font-weight:500;
  color:var(--text-soft);border:1px solid transparent;
}
.site-nav-links a:hover,.site-nav-links a:focus-visible{color:var(--text);background:var(--surface-wash);border-color:var(--border)}
.site-nav-links a[aria-current="page"]{color:var(--text);background:color-mix(in srgb, var(--accent) 16%, transparent);border-color:color-mix(in srgb, var(--accent) 26%, transparent)}
.site-nav-lang,.site-nav-theme{display:flex;gap:4px;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:10px;padding:3px}
.site-nav-lang button,.site-nav-theme button{
  background:none;border:none;color:var(--text-muted);font-family:inherit;font-size:.78rem;font-weight:600;
  letter-spacing:.04em;padding:5px 10px;border-radius:7px;cursor:pointer;transition:all .18s ease;
}
.site-nav-lang button[aria-pressed="true"],.site-nav-theme button[aria-pressed="true"]{background:color-mix(in srgb, var(--accent) 20%, transparent);color:var(--accent-2)}
@media (max-width:780px){
  .site-nav{padding:10px 14px;gap:10px;flex-wrap:wrap}
  .site-nav-links{order:3;width:100%;overflow-x:auto;flex-wrap:nowrap;justify-content:flex-start;padding-bottom:4px}
  .site-nav-links a{flex:0 0 auto;font-size:.82rem}
  .site-nav-theme{width:100%;order:4;justify-content:space-between}
  .site-nav-theme button{flex:1}
  .site-brand-text small{display:none}
}

.page-main{max-width:920px;margin:0 auto;padding:48px 28px 64px}
.page-article{animation:fadeIn .35s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.eyebrow{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:.74rem;letter-spacing:.16em;color:var(--accent);text-transform:uppercase;margin-bottom:14px;padding:5px 10px;background:var(--surface-wash);border-radius:99px}
.lede{font-size:1.15rem;color:color-mix(in srgb, var(--text) 84%, white);max-width:60ch}

.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow);margin:1.2em 0}
.card h3{margin-top:0}
.grid{display:grid;gap:18px}
.grid.cols-2{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.grid.cols-3{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}

.kpi{display:flex;flex-direction:column;gap:4px;padding:16px 18px;background:var(--panel-2);border:1px solid var(--border);border-radius:14px}
.kpi .num{font-family:'Exo 2',sans-serif;font-weight:800;font-size:1.7rem;color:var(--text);letter-spacing:-0.02em}
.kpi .lbl{font-size:.78rem;color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase}

.tag{display:inline-block;padding:3px 9px;border-radius:99px;font-size:.74rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;border:1px solid var(--border);background:rgba(255,255,255,0.04);color:var(--text-soft);margin-right:6px}
.tag.ok{color:var(--accent-2);border-color:color-mix(in srgb, var(--accent) 35%, transparent);background:var(--surface-wash)}
.tag.warn{color:#fcd34d;border-color:rgba(252,211,77,0.35);background:rgba(252,211,77,0.08)}
.tag.muted{color:var(--text-muted)}

ul,ol{padding-left:22px;color:var(--text-soft)}
li{margin:.35em 0}
li::marker{color:var(--accent)}

table.data{width:100%;border-collapse:collapse;margin:.8em 0;font-size:.92rem}
table.data th,table.data td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border)}
table.data th{color:var(--text-muted);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;background:rgba(255,255,255,0.03)}
table.data td{color:var(--text-soft)}
table.data tr:hover td{background:var(--surface-wash)}

.btn{
  display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border-radius:12px;
  font-family:'Exo 2',sans-serif;font-weight:600;font-size:.92rem;letter-spacing:.01em;
  background:linear-gradient(135deg,color-mix(in srgb, var(--accent) 22%, transparent),color-mix(in srgb, var(--accent-2) 20%, transparent));
  border:1px solid color-mix(in srgb, var(--accent) 35%, transparent);color:var(--accent-2);cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
}
.btn:hover{transform:translateY(-1px);background:linear-gradient(135deg,color-mix(in srgb, var(--accent) 30%, transparent),color-mix(in srgb, var(--accent-2) 28%, transparent));box-shadow:0 10px 30px -12px color-mix(in srgb, var(--accent) 36%, transparent)}
.btn.ghost{background:transparent;color:var(--text-soft);border-color:var(--border)}
.btn.ghost:hover{color:var(--text);background:rgba(255,255,255,0.04)}
.btn.lg{padding:14px 22px;font-size:1rem}

details{background:var(--panel-2);border:1px solid var(--border);border-radius:14px;padding:14px 18px;margin:.6em 0}
details[open]{background:var(--panel)}
details summary{cursor:pointer;font-weight:600;color:var(--text);list-style:none}
details summary::marker{content:""}
details summary::-webkit-details-marker{display:none}
details summary::before{content:"›";display:inline-block;margin-right:10px;color:var(--accent);transition:transform .2s ease}
details[open] summary::before{transform:rotate(90deg)}
details > *:not(summary){margin-top:.8em;color:var(--text-soft)}

.site-footer{margin-top:40px;padding:36px 28px;border-top:1px solid var(--border);background:rgba(2,11,22,0.6);backdrop-filter:blur(14px)}
.footer-grid{max-width:1080px;margin:0 auto;display:grid;gap:28px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.footer-grid h4{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}
.footer-grid ul{list-style:none;padding:0;margin:0;font-size:.88rem}
.footer-grid li{margin:.32em 0}
.footer-meta{max-width:1080px;margin:24px auto 0;padding-top:16px;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;font-size:.8rem;color:var(--text-muted)}
.version-pill{display:inline-block;padding:1px 8px;border-radius:99px;font-family:'JetBrains Mono',monospace;font-size:.72rem;background:var(--surface-wash);color:var(--accent-2);border:1px solid color-mix(in srgb, var(--accent) 24%, transparent);letter-spacing:.04em}

.callout{border-left:3px solid var(--accent);padding:14px 18px;background:color-mix(in srgb, var(--accent) 10%, transparent);border-radius:0 12px 12px 0;margin:1em 0;color:color-mix(in srgb, var(--text) 84%, white)}
.callout.warn{border-left-color:var(--warn);background:rgba(251,191,36,0.06);color:#fde68a}

@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important}}