/* ==========================================================
   MEIHIN INDEX — site.css 260129
   ========================================================== */

/* ==========================================================
   1) Design tokens
   ========================================================== */
:root{
  --serif: "Fraunces", ui-serif, Georgia, "Times New Roman", Times, serif;
  --sans: "Inter", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;

  --wrapMax: 1080px;
  --radius: 18px;
  --panelPad: 34px;

  --shadow: 0 18px 60px rgba(0,0,0,0.10);
  --shadowDark: 0 18px 60px rgba(0,0,0,0.45);

  /* Governance fallbacks (used in longform pages) */
  --ink: var(--text, #111);
  --hairline: var(--border, rgba(0,0,0,.12));
}

/* Light (default) */
:root{
  --bg: #f6f4ef;
  --bg2:#ffffff;

  --card: rgba(10,12,18,0.035);
  --border: rgba(10,12,18,0.10);

  --text: rgba(10,12,18,0.92);
  --muted: rgba(10,12,18,0.72);
  --faint: rgba(10,12,18,0.55);

  --link: rgba(10,12,18,0.92);
  --ring: rgba(10,12,18,0.14);

  --panelShadow: var(--shadow);
}

/* Dark overrides */
:root[data-theme="dark"]{
  --bg: #0b0c0f;
  --bg2:#0b0c0f;

  --card: rgba(255,255,255,0.06);
  --border: rgba(255,255,255,0.10);

  --text: rgba(255,255,255,0.92);
  --muted: rgba(255,255,255,0.70);
  --faint: rgba(255,255,255,0.55);

  --link: rgba(255,255,255,0.92);
  --ring: rgba(255,255,255,0.12);

  --panelShadow: var(--shadowDark);
}

/* Auto -> dark when OS is dark */
@media (prefers-color-scheme: dark){
  :root[data-theme="auto"]{
    --bg: #0b0c0f;
    --bg2:#0b0c0f;

    --card: rgba(255,255,255,0.06);
    --border: rgba(255,255,255,0.10);

    --text: rgba(255,255,255,0.92);
    --muted: rgba(255,255,255,0.70);
    --faint: rgba(255,255,255,0.55);

    --link: rgba(255,255,255,0.92);
    --ring: rgba(255,255,255,0.12);

    --panelShadow: var(--shadowDark);
  }
}

/* ==========================================================
   2) Base / reset
   ========================================================== */
*{ box-sizing: border-box; }
html, body{ height: 100%; }

body{
  margin: 0;
  font-family: var(--sans);
  color: var(--text);
  letter-spacing: -0.008em;
  min-height: 100vh;

  /* Endless background */
  background:
    radial-gradient(1200px 700px at 20% 10%, color-mix(in srgb, var(--bg2) 96%, #fff), transparent 60%),
    radial-gradient(900px 600px at 80% 20%, color-mix(in srgb, var(--bg) 94%, #000), transparent 55%),
    linear-gradient(180deg, var(--bg2), var(--bg));
  background-attachment: fixed;
}

img{ max-width: 100%; height: auto; display: block; }

a{
  color: var(--link);
  text-decoration: none;
  border-bottom: 1px solid color-mix(in srgb, var(--link) 25%, transparent);
}
a:hover{
  border-bottom-color: color-mix(in srgb, var(--link) 55%, transparent);
}

.wrap{
  max-width: var(--wrapMax);
  margin: 0 auto;
  padding: 44px 22px 76px;
}

/* ==========================================================
   3) Panels
   ========================================================== */
.panel{
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--panelShadow);
  padding: var(--panelPad);

  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--card) 72%, transparent),
      color-mix(in srgb, var(--card) 46%, transparent)
    );

  backdrop-filter: blur(10px);
}

/* Dark: keep slightly denser */
:root[data-theme="dark"] .panel{
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--card) 86%, transparent),
      color-mix(in srgb, var(--card) 64%, transparent)
    );
}

/* Auto + OS dark */
@media (prefers-color-scheme: dark){
  :root[data-theme="auto"] .panel{
    background:
      linear-gradient(
        180deg,
        color-mix(in srgb, var(--card) 86%, transparent),
        color-mix(in srgb, var(--card) 64%, transparent)
      );
  }
}

/* Notify panel: subtle highlight */
#notifyPanel{
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--bg2) 22%, var(--card)),
      color-mix(in srgb, var(--bg2) 10%, var(--card))
    );
  border-color: color-mix(in srgb, var(--text) 10%, var(--border));
  box-shadow: 0 22px 70px color-mix(in srgb, #000 11%, transparent);
}

/* Notify in dark */
:root[data-theme="dark"] #notifyPanel{
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--card) 92%, transparent),
      color-mix(in srgb, var(--card) 74%, transparent)
    );
  border-color: color-mix(in srgb, var(--text) 14%, var(--border));
}
@media (prefers-color-scheme: dark){
  :root[data-theme="auto"] #notifyPanel{
    background:
      linear-gradient(
        180deg,
        color-mix(in srgb, var(--card) 92%, transparent),
        color-mix(in srgb, var(--card) 74%, transparent)
      );
    border-color: color-mix(in srgb, var(--text) 14%, var(--border));
  }
}

/* ==========================================================
   4) Typography
   ========================================================== */
h1{
  font-family: var(--serif);
  font-weight: 600;
  font-size: 54px;
  line-height: 1.05;
  margin: 0 0 18px;
  letter-spacing: -0.02em;
}

h2{
  font-family: var(--serif);
  font-weight: 600;
  font-size: 26px;
  margin: 26px 0 10px;
  letter-spacing: -0.01em;
}

h3{
  font-family: var(--serif);
  font-weight: 600;
  font-size: 20px;
  margin: 22px 0 10px;
}

p{
  margin: 0 0 14px;
  line-height: 1.75;
  color: color-mix(in srgb, var(--text) 92%, transparent);
}

ul, ol{ margin: 10px 0 14px 20px; }
li{
  margin: 6px 0;
  line-height: 1.7;
  color: color-mix(in srgb, var(--text) 88%, transparent);
}

hr{
  border: 0;
  border-top: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
  margin: 22px 0;
}

.fineprint, .note{
  margin: 0;
  font-size: 12px;
  line-height: 1.7;
  color: var(--faint);
  max-width: 85ch;
}

/* ==========================================================
   5) Header
   ========================================================== */
.siteHeader{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.logoLink{ border-bottom: 0; }

/* Logo lockup (chosen for longevity) */
.logo{
  display: inline-flex;
  flex-direction: column;
  gap: 2px;
  font-family: var(--serif);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1;
}
.logoMain{ font-size: 32px; line-height: 1; }
.logoSub{
  font-family: var(--serif);
  font-weight: 600;
  font-size: 16px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1;
  opacity: 0.88;
}

.tagline{
  margin-top: 6px;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--faint);
}

.right{
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: flex-end;
}

.presented a{
  font-size: 12px;
  color: var(--faint);
  border-bottom-color: transparent;
}
.presented a:hover{
  border-bottom-color: color-mix(in srgb, var(--faint) 55%, transparent);
}

.navRow{
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
  column-gap: 18px;
}

.siteHeader .themeToggle{ margin-left: 8px; }

/* ==========================================================
   6) Pills (nav + footer)
   ========================================================== */
.siteNav, .footerNav{
  display: inline-flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}

.navlink{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--muted);
  text-decoration: none;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-bottom: 0;
}
.navlink:hover{
  background: color-mix(in srgb, var(--text) 9%, transparent);
  color: var(--text);
}
.navlink.is-active,
.navlink[aria-current="page"]{
  background: color-mix(in srgb, var(--text) 11%, transparent);
  color: var(--text);
}

/* ==========================================================
   7) Theme toggle pills
   ========================================================== */
.themeToggle{
  display: inline-flex;
  gap: 8px;
  padding: 6px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--card) 60%, transparent);
}

.themeToggle button{
  appearance: none;
  border: 1px solid transparent;
  background: transparent;
  color: var(--muted);
  padding: 7px 10px;
  border-radius: 999px;
  font: inherit;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
}
.themeToggle button:hover{
  color: var(--text);
  background: color-mix(in srgb, var(--text) 8%, transparent);
}
.themeToggle button[aria-pressed="true"]{
  background: color-mix(in srgb, var(--text) 11%, transparent);
  color: var(--text);
  border-color: color-mix(in srgb, var(--text) 16%, transparent);
}

/* ==========================================================
   8) Home layout
   ========================================================== */
.hero{
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 16px;
  align-items: start;
}
.hero > *{ min-width: 0; }

/* =========================================================
   KICKER (INDEPENDENT INDEX • COMING SOON)
   Struktur (rekommenderad):
   <div class="kicker">
     <span class="kicker-main">INDEPENDENT INDEX</span>
     <span class="kicker-tail">
       <span class="kicker-dot">•</span>
       <span class="kicker-soon">COMING SOON</span>
     </span>
   </div>
   ========================================================= */

.kicker{
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  column-gap: .55em;
  row-gap: .25em;

  letter-spacing: .18em;
  text-transform: uppercase;
}

.kicker-main{
  /* (valfritt) om du vill säkra att ordet inte bryter konstigt */
  white-space: nowrap;
}

.kicker-tail{
  display: inline-flex;
  align-items: baseline;
  gap: .45em;

  /* Tailen (• + label) hålls ihop */
  white-space: nowrap;

  /* När den bryter till ny rad blir det ett "hängande indrag" */
  margin-left: 1.1em;
}

.kicker-dot{
  opacity: .55;
}

/* COMING SOON – sober editorial label */
.kicker-soon{
  display: inline-block;
  padding: .12em .45em .14em;

  border-radius: 6px; /* inte kapsel */
  border: 1px solid color-mix(in oklab, var(--ink) 14%, transparent);
  background: color-mix(in oklab, var(--paper) 88%, transparent);
  color: color-mix(in oklab, var(--ink) 55%, transparent);

  font-size: .78em;
  letter-spacing: .12em;

  transform: translateY(-0.06em);
}

@media (max-width: 520px){
  .kicker-main{ 
  letter-spacing: .12em;
  }
}  
  .kicker{ letter-spacing: .14em; }

  .kicker-tail{
    margin-left: .85em; /* lite mindre indrag på mobil */
  }

  .kicker-soon{
    font-size: .70em;
    letter-spacing: .04em;
    padding: .08em .30em;
  } 
}

/* First-visit reveal for COMING SOON (still subtle, but perceptible) */
@keyframes kickerSoonReveal{
  from { opacity: 0; filter: blur(2px); }
  to   { opacity: 1; filter: blur(0); }
}

.kicker-soon.is-first-visit{
  animation: kickerSoonReveal 650ms ease-out 200ms both;
}

body.home .homeGrid{
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 16px;
  align-items: start;
}
body.home .homeGrid > *{ min-width: 0; }

.homeGrid2{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 16px;
}
.homeGrid2 > *{ min-width: 0; }

body.home .panel--lead p{
  font-size: 18px;
  line-height: 1.85;
}

/* Home callout (dot + rule) */
.panelRule{
  border: 0;
  border-top: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
  margin: 18px 0 14px;
}

.callout{
  display: grid;
  grid-template-columns: 16px 1fr;
  gap: 12px;
  align-items: start;
  padding: 0;
  border: 0;
  background: transparent;
}

.calloutDot{
  width: 12px;
  height: 12px;
  border-radius: 999px;
  margin-top: 6px;
  background: color-mix(in srgb, var(--text) 85%, transparent);
  box-shadow:
    0 0 0 6px color-mix(in srgb, var(--text) 6%, transparent),
    inset 0 0 0 2px color-mix(in srgb, var(--bg2) 85%, transparent);
}
.callout p{ margin: 0; }

/* ==========================================================
   9) Notify form
   ========================================================== */
.notify-form{
  display: grid;
  gap: 14px;
  margin-top: 14px;
  transition: opacity 180ms ease;
}

.notify-form label{
  display: grid;
  gap: 8px;
}

.notify-form label > span{
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--faint);
}

.notify-form input{
  width: 100%;
  padding: 12px 16px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--bg2) 92%, transparent);
  color: var(--text);
  outline: none;
}

.notify-form input::placeholder{
  color: color-mix(in srgb, var(--muted) 65%, transparent);
}

/* Subtle inputs in light/auto-light */
:root[data-theme="light"] .notify-form input,
:root[data-theme="auto"] .notify-form input{
  background: color-mix(in srgb, var(--bg) 55%, var(--bg2));
  border-color: color-mix(in srgb, var(--border) 75%, transparent);
}

/* Dark inputs */
:root[data-theme="dark"] .notify-form input{
  background: color-mix(in srgb, #000 20%, var(--bg2));
}
@media (prefers-color-scheme: dark){
  :root[data-theme="auto"] .notify-form input{
    background: color-mix(in srgb, #000 20%, var(--bg2));
  }
}

.notify-form input:focus{
  border-color: color-mix(in srgb, var(--text) 18%, var(--border));
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--ring) 55%, transparent);
}

.notify-form button{
  justify-self: start;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--text) 10%, transparent);
  color: var(--text);
  padding: 10px 14px;
  border-radius: 999px;
  cursor: pointer;
  font-size: 12px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  font-weight: 600;
}
.notify-form button:hover{
  background: color-mix(in srgb, var(--text) 14%, transparent);
}

#notifyMsg{
  margin: 10px 0 0;
  font-size: 14px;
  line-height: 1.7;
  max-width: 42ch;
}

/* Notify instrument feel (scoped) */
#notifyPanel #notifyIntro{ margin-bottom: 18px; }
#notifyPanel .notify-form{ gap: 12px; margin-top: 10px; }
#notifyPanel .notify-form button{ margin-top: 4px; }
:root[data-theme="light"] #notifyPanel .notify-form input{
  background: color-mix(in srgb, var(--bg2) 70%, var(--bg));
  border-color: color-mix(in srgb, var(--border) 85%, transparent);
}
@media (prefers-color-scheme: light){
  :root[data-theme="auto"] #notifyPanel .notify-form input{
    background: color-mix(in srgb, var(--bg2) 70%, var(--bg));
    border-color: color-mix(in srgb, var(--border) 85%, transparent);
  }
}

/* Notify progress (single source of truth) */
.panel--notify .notify-progress{
  display: inline-flex;
  gap: 8px;
  margin: 8px 0 18px;
  opacity: 0.35;
}
.panel--notify .notify-progress .dot{
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--text) 14%, transparent);
  opacity: 0.55;
  transform: scale(0.92);
  transition:
    opacity 140ms ease,
    transform 140ms cubic-bezier(.2,.6,.2,1),
    background-color 140ms ease;
}
.panel--notify .notify-progress .dot.is-on{
  background: color-mix(in srgb, var(--text) 42%, transparent);
  opacity: 0.95;
  transform: scale(1);
}
:root[data-theme="dark"] .panel--notify .notify-progress .dot{
  background: color-mix(in srgb, var(--text) 22%, transparent);
  opacity: 0.45;
}
:root[data-theme="dark"] .panel--notify .notify-progress .dot.is-on{
  background: color-mix(in srgb, var(--text) 55%, transparent);
  opacity: 0.9;
}

/* Notify transitions (keep micro-UX) */
#notifyPanel .notify-form,
#notifyPanel #notifyMsg,
#notifyPanel #notifyStatus,
#notifyPanel #notifyIntro,
#notifyPanel #notifyTitle{
  transition: opacity 160ms ease, transform 160ms ease;
}
#notifyPanel.is-transitioning .notify-form,
#notifyPanel.is-transitioning #notifyMsg,
#notifyPanel.is-transitioning #notifyStatus,
#notifyPanel.is-transitioning #notifyIntro{
  opacity: 0;
  transform: translateY(2px);
}

/* ==========================================================
   10) Generic grids (used by methodology / content pages)
   ========================================================== */
.grid{
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 16px;
  align-items: start;
}
.grid > *{ min-width: 0; }

.pillRow{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin: 10px 0 0;
}

.pill{
  display: inline-flex;
  align-items: center;
  padding: 9px 14px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--card) 70%, transparent);
  color: var(--muted);
  font-size: 14px;
  letter-spacing: -0.01em;
  border-bottom: 0;
}
.pill:hover{ color: var(--text); }
.pill[aria-current="page"],
.pill.is-current{
  background: color-mix(in srgb, var(--text) 10%, transparent);
  color: var(--text);
}

/* ==========================================================
   11) Footer
   ========================================================== */
.siteFooter{
  margin-top: 22px;
  padding-top: 18px;
  border-top: 1px solid color-mix(in srgb, var(--border) 90%, transparent);
  color: color-mix(in srgb, var(--text) 45%, transparent);
  font-size: 12px;
  display: flex;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}

/* Footer pills slightly smaller */
.siteFooter .footerNav .navlink{
  padding: 6px 10px;
  font-size: 10px;
  letter-spacing: 0.07em;
}

.siteFooter strong{
  font-family: var(--serif);
  font-weight: 600;
  letter-spacing: -0.01em;
  color: color-mix(in srgb, var(--text) 70%, transparent);
}

/* Footer left stack + socials */
.footerLeft{
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.footerSocial{
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.socialIcon{
  width: 30px;
  height: 30px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--border) 70%, transparent);
  background: color-mix(in srgb, var(--card) 55%, transparent);
  border-bottom: 0;
  opacity: 0.55;
  transition: opacity 140ms ease, transform 140ms ease, background-color 140ms ease;
}
.socialIcon svg{
  width: 16px;
  height: 16px;
  fill: currentColor;
  color: color-mix(in srgb, var(--text) 70%, transparent);
}
.socialIcon:hover{
  opacity: 0.95;
  transform: translateY(-1px);
  background: color-mix(in srgb, var(--card) 75%, transparent);
}
.socialIcon:focus-visible{
  outline: none;
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--ring) 55%, transparent);
}

/* ==========================================================
   12) Governance longform (Privacy / Terms etc.)
   ========================================================== */
.gov-grid{
  display: grid;
  grid-template-columns: minmax(0, 1fr) 260px;
  gap: 34px;
  align-items: start;
}
.gov-main{ max-width: 72ch; }
.gov-main p{ line-height: 1.65; color: var(--ink); }
.gov-main .lede{
  margin-top: 10px;
  color: var(--muted);
  font-size: 1.02rem;
}
.gov-main .kicker{
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: .78rem;
}
.gov-main h2{
  margin-top: 34px;
  padding-top: 18px;
  border-top: 1px solid var(--hairline);
  scroll-margin-top: 110px;
}

.gov-toc{
  position: sticky;
  top: 96px;
  padding-left: 16px;
  border-left: 1px solid var(--hairline);
}
.gov-toc-title{
  font-size: .82rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 12px;
}
.gov-toc-links{
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.gov-toc-links a{
  text-decoration: none;
  color: var(--ink);
  opacity: .85;
  line-height: 1.25;
}
.gov-toc-links a:hover{
  opacity: 1;
  text-decoration: underline;
  text-underline-offset: 4px;
}
.gov-toc-links a[aria-current="true"]{
  opacity: 1;
  text-decoration: none;
  position: relative;
}
.gov-toc-links a[aria-current="true"]::before{
  content: "";
  position: absolute;
  left: -16px;
  top: .2em;
  width: 8px;
  height: 1.15em;
  border-left: 2px solid var(--ink);
  opacity: .65;
}

/* ==========================================================
   13) Utilities / state
   ========================================================== */
.mono{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 12px;
  color: color-mix(in srgb, var(--text) 55%, transparent);
}

/* Home-only cursor treatment (JS adds .is-home on <html>) */
.is-home .logoLink{ cursor: default; }

/* ==========================================================
   14) Responsive (single collected set)
   ========================================================== */

/* Tablet / small desktop */
@media (max-width: 980px){
  .siteHeader{ flex-direction: column; align-items: flex-start; }
  .right{ align-items: flex-start; }
  .navRow{ justify-content: flex-start; }

  .hero{ grid-template-columns: 1fr; }
  body.home .homeGrid{ grid-template-columns: 1fr; }
  .homeGrid2{ grid-template-columns: 1fr; }
  .grid{ grid-template-columns: 1fr; }
}

/* Mobile */
@media (max-width: 520px){
  /* Global rhythm */
  .wrap{ padding: 22px 18px 54px; }
  .panel{ padding: 22px; }
  h1{ font-size: 44px; }
  body.home .panel--lead p{ font-size: 16px; line-height: 1.8; }

  /* Header: logo left, theme toggle right (same row) */
  .siteHeader{
    margin-bottom: 6px;
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "brand toggle"
      "presented presented";
    align-items: center;
    row-gap: 6px;
    column-gap: 12px;
  }
  .brand{ grid-area: brand; display: flex; flex-direction: column; gap: 4px; }
  .right{ grid-area: toggle; width: auto; align-items: flex-end; gap: 6px; }

  .logoMain{ font-size: 28px; }
  .logoSub{ font-size: 14px; letter-spacing: 0.05em; }
  .tagline{ margin-top: 4px; font-size: 10px; letter-spacing: 0.12em; }

  .presented{ grid-area: presented; margin-top: 2px; }
  .presented a{ font-size: 11px; opacity: 0.65; }

  .navRow{ width: auto; justify-content: flex-end; gap: 8px; column-gap: 10px; }
  .siteNav{ display: none; } /* nav currently empty in header; safe */

  .themeToggle{ padding: 3px; gap: 4px; opacity: 0.70; }
  .themeToggle button{ padding: 5px 8px; font-size: 11px; }

  /* Footer: prevent awkward wrap geometry in mobile */
  .siteFooter{
    margin-top: 16px;
    padding-top: 12px;
    gap: 10px;
    flex-direction: column;
    align-items: flex-start;
  }
  .footerLeft{
    width: 100%;
    justify-content: space-between;
    flex-wrap: nowrap;
  }
  .footerSocial{ gap: 6px; margin-left: auto; }
  .socialIcon{ width: 28px; height: 28px; }
  .socialIcon svg{ width: 15px; height: 15px; }
  .footerNav{ width: 100%; justify-content: flex-start; }
}

/* Governance mobile stack */
@media (max-width: 880px){
  .gov-grid{ grid-template-columns: 1fr; gap: 22px; }
  .gov-main{ max-width: 100%; }
  .gov-toc{
    position: static;
    padding-left: 0;
    border-left: none;
    padding-top: 14px;
    border-top: 1px solid var(--hairline);
  }
}

/* Slightly wider TOC on very wide screens */
@media (min-width: 1200px){
  .gov-grid{
    grid-template-columns: minmax(0, 1fr) 280px;
    gap: 42px;
  }
}
