@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap');

/* ============================================================
   NZ Club Fundraising — 2026 polished system
   Neutral paper, deep ink, indigo signal accent. Subtle radii,
   soft elevation, Inter typography, JetBrains Mono labels.
   Full auto dark mode + reduced-motion + safe-area support.
   ============================================================ */

:root{
  /* surfaces */
  --paper:#fafaf7;
  --paper-2:#ffffff;
  --surface:#ffffff;
  --shade:#f1efe8;

  /* ink */
  --ink:#0b0d10;
  --ink-2:#1a1d22;
  --muted:#5b626d;
  --muted-2:#8a8f99;
  --line:rgba(11,13,16,.10);
  --line-strong:rgba(11,13,16,.16);

  /* signal */
  --accent:#2546f0;
  --accent-2:#3a5dff;
  --accent-soft:color-mix(in srgb, #2546f0 12%, transparent);
  --accent-tint:color-mix(in srgb, #2546f0 6%, #fafaf7);

  /* semantic */
  --ok:#16864d;
  --warn:#c47a1a;
  --bad:#c24738;

  /* legacy aliases kept so any inline class still resolves cleanly */
  --green:var(--accent);
  --green-bright:var(--accent-2);
  --green-deep:var(--accent);
  --green-tint:var(--accent-soft);
  --navy:var(--ink);
  --navy-2:var(--ink-2);
  --orange:var(--warn);
  --blue:var(--accent);
  --red:var(--bad);

  /* type */
  --display:'Inter',ui-sans-serif,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --body:'Inter',ui-sans-serif,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;

  /* elevation */
  --shadow-xs:0 1px 2px rgba(11,13,16,.04);
  --shadow-sm:0 4px 14px rgba(11,13,16,.05);
  --shadow:0 12px 30px rgba(11,13,16,.06), 0 2px 6px rgba(11,13,16,.04);
  --shadow-lg:0 24px 60px rgba(11,13,16,.08), 0 4px 12px rgba(11,13,16,.04);

  /* shape */
  --radius:12px;
  --radius-sm:8px;
  --radius-lg:18px;
  --max:1200px;
}

@media (prefers-color-scheme: dark){
  :root{
    --paper:#0b0d10;
    --paper-2:#111418;
    --surface:#14181d;
    --shade:#1a1f25;
    --ink:#f5f5f2;
    --ink-2:#e6e7e3;
    --muted:#9aa2ad;
    --muted-2:#6b7280;
    --line:rgba(245,245,242,.10);
    --line-strong:rgba(245,245,242,.18);
    --accent:#7f96ff;
    --accent-2:#a3b5ff;
    --accent-soft:color-mix(in srgb, #7f96ff 18%, transparent);
    --accent-tint:color-mix(in srgb, #7f96ff 8%, #14181d);
    --shadow-xs:0 1px 2px rgba(0,0,0,.4);
    --shadow-sm:0 4px 14px rgba(0,0,0,.35);
    --shadow:0 12px 30px rgba(0,0,0,.45), 0 2px 6px rgba(0,0,0,.25);
    --shadow-lg:0 24px 60px rgba(0,0,0,.55), 0 4px 12px rgba(0,0,0,.3);
  }
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);
  font-size:16px;line-height:1.55;letter-spacing:-.005em;
  text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;
  padding-bottom:env(safe-area-inset-bottom)}
a{color:var(--accent);text-decoration:none;text-underline-offset:3px;transition:color .15s ease}
a:hover{color:var(--accent-2)}
img,svg,video{max-width:100%;height:auto;display:block}

::selection{background:var(--accent);color:#fff}
*:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}

.skip{position:absolute;left:-999px;top:10px;background:var(--paper-2);color:var(--ink);
  padding:10px 14px;border-radius:8px;z-index:99;border:1px solid var(--line)}
.skip:focus{left:10px}

/* ---------- Typography ---------- */
h1,h2,h3,h4{margin:0 0 .6rem;color:var(--ink);font-family:var(--display);font-weight:700;
  line-height:1.12;letter-spacing:-.028em;text-wrap:balance}
h1{font-size:clamp(2.2rem,4.4vw,4.2rem);line-height:1.02;letter-spacing:-.04em;max-width:22ch}
h2{font-size:clamp(1.55rem,2.4vw,2.35rem);max-width:26ch}
h3{font-size:clamp(1.08rem,1.3vw,1.25rem);font-weight:600;letter-spacing:-.018em}
p{margin:0 0 1rem;text-wrap:pretty}
.lead{font-size:clamp(1.04rem,1.18vw,1.18rem);line-height:1.6;max-width:62ch;color:var(--muted)}
.muted{color:var(--muted)}
.small{font-size:.9rem}
.eyebrow{display:inline-flex;gap:.6rem;align-items:center;text-transform:uppercase;
  letter-spacing:.14em;font-size:.7rem;font-weight:700;color:var(--muted);
  font-family:var(--mono);margin:0 0 1rem}
.eyebrow:before{content:"";width:24px;height:1px;background:var(--ink);display:block;opacity:.5}
.kicker{font-family:var(--mono);font-weight:600;text-transform:uppercase;letter-spacing:.12em;
  font-size:.7rem;color:var(--muted);margin-bottom:.55rem;display:block}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:color-mix(in srgb, var(--paper) 82%, transparent);
  backdrop-filter:saturate(150%) blur(16px);-webkit-backdrop-filter:saturate(150%) blur(16px);
  border-bottom:1px solid var(--line)}
.header-inner{max-width:var(--max);margin:0 auto;min-height:64px;padding:12px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:18px;position:relative}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink);text-decoration:none;min-width:0;font-weight:600}
.brand-mark{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;
  background:var(--ink);color:var(--paper);font-weight:800;font-size:.78rem;letter-spacing:-.02em}
.brand-text{display:flex;flex-direction:column;line-height:1.15;min-width:0}
.brand-title{font-family:var(--display);font-weight:700;letter-spacing:-.02em;white-space:nowrap;font-size:1rem}
.brand-sub{font-size:.74rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}
.nav{display:flex;align-items:center;gap:2px}
.nav a{padding:.5rem .8rem;font-size:.9rem;font-weight:500;color:var(--muted);
  border-radius:8px;transition:color .15s ease, background .15s ease}
.nav a:hover{color:var(--ink);background:var(--shade)}
.nav a.active{color:var(--ink);background:var(--shade);font-weight:600}
.nav-toggle{display:none;flex:0 0 auto;background:var(--ink);color:var(--paper);border:0;
  border-radius:8px;padding:.55rem .9rem;font-weight:600;font-family:var(--body);
  font-size:.9rem;cursor:pointer;transition:transform .15s ease}
.nav-toggle:hover{transform:translateY(-1px)}

/* ---------- Breadcrumb ---------- */
.breadcrumb{max-width:var(--max);margin:22px auto 0;padding:0 24px;
  color:var(--muted);font-size:.85rem;font-family:var(--mono);letter-spacing:.02em}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--ink)}
main{min-width:0}

/* ---------- Hero (home) ---------- */
.hero{position:relative;overflow:hidden;max-width:var(--max);margin:32px auto 0;
  border-radius:var(--radius-lg);color:var(--ink);background:var(--paper-2);
  border:1px solid var(--line);box-shadow:var(--shadow-lg);
  display:grid;grid-template-columns:minmax(0,1.4fr) minmax(290px,.9fr);gap:40px;
  align-items:center;padding:60px 52px}
.hero:before{content:"";position:absolute;right:-160px;bottom:-200px;width:480px;height:480px;
  border-radius:50%;background:radial-gradient(closest-side, var(--accent-soft), transparent 70%);pointer-events:none}
.hero>*{position:relative;z-index:1}
.hero .eyebrow{color:var(--muted)}
.hero h1{color:var(--ink);font-weight:800;letter-spacing:-.045em;max-width:18ch}
.hero .lead{color:var(--muted);max-width:48ch}

/* ---------- Page hero (interior) ---------- */
.page-hero{position:relative;overflow:hidden;max-width:var(--max);margin:28px auto 0;
  border-radius:var(--radius-lg);background:var(--paper-2);border:1px solid var(--line);
  box-shadow:var(--shadow);padding:48px 44px}
.page-hero:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent)}
.page-hero>*{position:relative;z-index:1}
.page-hero h1{color:var(--ink);max-width:22ch}
.page-hero .lead{color:var(--muted)}

/* ---------- Hero panel / stats ---------- */
.hero-panel{align-self:start;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm);color:var(--ink)}
.hero-panel h3{color:var(--ink)}
.hero-panel p{color:var(--muted)}
.hero-panel ul{padding-left:0;margin:.8rem 0;list-style:none}
.hero-panel li{position:relative;margin:.6rem 0;padding-left:1.6rem;color:var(--ink-2);font-size:.96rem;line-height:1.5}
.hero-panel li:before{content:"";position:absolute;left:0;top:.45em;width:10px;height:10px;border-radius:3px;
  background:var(--accent-soft);box-shadow:inset 0 0 0 1.5px var(--accent)}
.stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:28px}
.stat{padding:18px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--line)}
.stat b{display:block;font-family:var(--display);font-size:1.7rem;line-height:1;font-weight:800;
  color:var(--ink);letter-spacing:-.03em;margin-bottom:6px;font-variant-numeric:tabular-nums}
.stat span{font-size:.78rem;color:var(--muted);font-weight:500;font-family:var(--mono);
  text-transform:uppercase;letter-spacing:.06em}

/* ---------- Buttons ---------- */
.actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  padding:.78rem 1.15rem;border:1px solid var(--ink);border-radius:10px;
  font-family:var(--body);font-weight:600;font-size:.95rem;text-decoration:none;cursor:pointer;
  background:var(--ink);color:var(--paper);
  transition:transform .15s ease, background .15s ease, color .15s ease, box-shadow .15s ease;
  letter-spacing:-.005em;min-height:44px;position:relative}
.btn:after{content:"→";opacity:0;transform:translateX(-4px);transition:opacity .18s ease, transform .18s ease;
  display:inline-block;font-weight:500}
.btn:hover{transform:translateY(-1px);background:var(--accent);color:#fff;border-color:var(--accent);
  box-shadow:0 8px 22px var(--accent-soft)}
.btn:hover:after{opacity:1;transform:translateX(0)}
.btn:active{transform:translateY(0)}
.btn.secondary{background:transparent;color:var(--ink);border-color:var(--line-strong)}
.btn.secondary:hover{background:var(--ink);color:var(--paper);border-color:var(--ink);box-shadow:var(--shadow-sm)}
.btn.light{background:var(--paper-2);color:var(--ink);border-color:var(--line)}
.btn.light:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ---------- Sections / bands ---------- */
.section{max-width:var(--max);margin:0 auto;padding:72px 24px}
.section.tight{padding-top:40px}
.border-top{border-top:1px solid var(--line)}
.band{background:var(--ink);color:var(--paper);margin:48px 0;position:relative;overflow:hidden}
.band:before{content:"";position:absolute;left:0;top:0;right:0;height:1px;background:var(--accent);opacity:.6}
.band .section{padding-top:62px;padding-bottom:62px}
.band h2,.band h3{color:var(--paper)}
.band p{color:color-mix(in srgb, var(--paper) 75%, transparent)}
.band .muted{color:color-mix(in srgb, var(--paper) 60%, transparent)}
.band .eyebrow{color:color-mix(in srgb, var(--paper) 60%, transparent)}
.band .eyebrow:before{background:var(--paper)}
.band .btn{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.band .btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.band .btn.secondary{background:transparent;color:var(--paper);border-color:color-mix(in srgb, var(--paper) 35%, transparent)}
.band .btn.secondary:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}

/* ---------- Grid + cards ---------- */
.grid{display:grid;gap:20px}
.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{min-width:0;position:relative;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-xs);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--line-strong)}
.card .number{display:inline-grid;place-items:center;width:36px;height:36px;margin-bottom:18px;
  border-radius:8px;font-family:var(--mono);font-size:.9rem;font-weight:600;
  color:var(--accent);background:var(--accent-soft);letter-spacing:-.02em}
.card.compact{padding:18px}
.card.accent{background:var(--accent-tint);border-color:color-mix(in srgb, var(--accent) 20%, var(--line))}
.card.accent .number{background:var(--accent);color:#fff}
.card.dark{background:var(--ink);color:var(--paper);border-color:transparent}
.card.dark:hover{border-color:var(--accent)}
.card.dark h2,.card.dark h3{color:var(--paper)}
.card.dark p{color:color-mix(in srgb, var(--paper) 75%, transparent)}
.card.dark a{color:var(--paper);text-decoration:underline;text-decoration-color:var(--accent)}
.card.dark .muted{color:color-mix(in srgb, var(--paper) 55%, transparent)}
.card.dark .number{background:var(--accent);color:#fff}

/* ---------- Tables ---------- */
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--surface);box-shadow:var(--shadow-xs)}
table{width:100%;border-collapse:collapse;min-width:680px}
th,td{padding:14px 18px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top;font-size:.94rem}
th{background:var(--shade);color:var(--ink);font-family:var(--mono);font-size:.7rem;
  text-transform:uppercase;letter-spacing:.08em;font-weight:600}
tbody tr{transition:background .12s ease}
tbody tr:hover{background:var(--accent-tint)}
tr:last-child td{border-bottom:0}

/* ---------- Forms / filters ---------- */
.filters{display:grid;grid-template-columns:1.3fr repeat(3,1fr);gap:10px;margin:24px 0}
input,select,textarea{width:100%;font:inherit;font-family:var(--body);color:var(--ink);
  background:var(--surface);border:1px solid var(--line-strong);border-radius:10px;
  padding:.72rem .9rem;transition:border-color .15s ease, box-shadow .15s ease, background .15s ease;
  min-height:44px}
input::placeholder,textarea::placeholder{color:var(--muted-2)}
input:hover,select:hover,textarea:hover{border-color:var(--muted-2)}
input:focus,select:focus,textarea:focus{outline:0;border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-soft)}
input[type=search]{appearance:none;-webkit-appearance:none}
textarea{min-height:120px;resize:vertical;line-height:1.5}
select{appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='none' stroke='%235b626d' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round' d='M1 1l5 5 5-5'/></svg>");
  background-repeat:no-repeat;background-position:right .9rem center;padding-right:2.2rem}
input[type=checkbox],input[type=radio]{width:18px;height:18px;min-height:0;padding:0;
  accent-color:var(--accent);vertical-align:middle;margin-right:.55rem;cursor:pointer}
label{display:block;font-weight:600;color:var(--ink);font-size:.9rem;margin-bottom:6px}
fieldset{border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin:0 0 16px}
legend{padding:0 .5rem;font-weight:600;color:var(--ink);font-family:var(--mono);
  font-size:.74rem;text-transform:uppercase;letter-spacing:.08em}

/* ---------- Funders ---------- */
.funders{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.funders .card{padding:24px}

/* ---------- Notices ---------- */
.notice,.callout,.warning{border-radius:var(--radius);padding:20px 22px;
  border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-xs);
  position:relative;padding-left:26px}
.notice:before,.callout:before,.warning:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:4px 0 0 4px}
.notice:before{background:var(--accent)}
.warning:before{background:var(--warn)}
.warning{background:color-mix(in srgb, var(--warn) 6%, var(--surface))}
.callout:before{background:var(--accent)}
.callout{background:var(--accent-tint)}

/* ---------- Fit chips ---------- */
.chip{display:inline-flex;align-items:center;gap:.4rem;padding:.25rem .6rem;
  border-radius:999px;font-family:var(--mono);font-size:.72rem;font-weight:600;letter-spacing:.02em}
.chip.ok{color:var(--ok);background:color-mix(in srgb, var(--ok) 14%, transparent)}
.chip.warn{color:var(--warn);background:color-mix(in srgb, var(--warn) 16%, transparent)}
.chip.bad{color:var(--bad);background:color-mix(in srgb, var(--bad) 14%, transparent)}
.chip.info{color:var(--accent);background:var(--accent-soft)}

/* ---------- Downloads / resources ---------- */
.download-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.download-item{display:flex;justify-content:space-between;gap:14px;align-items:center;min-width:0;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;
  box-shadow:var(--shadow-xs);transition:transform .15s ease, border-color .15s ease, box-shadow .15s ease}
.download-item strong{display:block;font-weight:600;color:var(--ink);font-size:.98rem;margin-bottom:2px}
.download-item span{min-width:0;color:var(--muted);font-size:.86rem}
.download-item:hover{transform:translateY(-1px);border-color:var(--accent);box-shadow:var(--shadow-sm)}
.resource-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.resource-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-xs);padding:24px;display:flex;flex-direction:column;gap:12px;min-width:0;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease}
.resource-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--line-strong)}
.resource-card h3{font-size:1.05rem;margin:0}
.resource-card p{margin:0;color:var(--muted);font-size:.92rem}
.resource-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto}
.resource-actions a{display:inline-flex;align-items:center;justify-content:center;
  border-radius:8px;padding:.55rem .85rem;font-weight:600;font-size:.84rem;text-decoration:none;
  background:var(--ink);color:var(--paper);border:1px solid var(--ink);transition:.15s ease}
.resource-actions a:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-1px)}

.resource-card{position:relative;cursor:pointer}
.resource-actions a,.download-item,.btn,.copy-btn,.nav-toggle,button{position:relative;z-index:2;pointer-events:auto}
.resource-card:focus-within{outline:2px solid var(--accent);outline-offset:3px}

/* ---------- Generated / template blocks ---------- */
.template-block,.generated{background:var(--ink);color:color-mix(in srgb, var(--paper) 92%, transparent);
  border:1px solid var(--line);border-radius:var(--radius);padding:22px;overflow:auto;box-shadow:var(--shadow-xs)}
.template-block pre,.generated{white-space:pre-wrap;margin:0;font-family:var(--mono);font-size:.86rem;line-height:1.55}
.copy-row{display:flex;justify-content:space-between;gap:12px;align-items:center;margin:.8rem 0}
.copy-btn{background:var(--ink);color:var(--paper);border:1px solid var(--ink);
  border-radius:8px;font-weight:600;font-size:.86rem;padding:.55rem .9rem;cursor:pointer;
  font-family:var(--body);transition:.15s ease;min-height:38px}
.copy-btn:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-1px)}

/* ---------- Calculator ---------- */
.calculator{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.calc-results{background:var(--ink);color:var(--paper);padding:28px;
  border-radius:var(--radius);display:grid;gap:14px;box-shadow:var(--shadow);border:1px solid var(--ink)}
.calc-results h2,.calc-results h3{color:var(--paper)}
.result-row{display:flex;justify-content:space-between;border-bottom:1px solid color-mix(in srgb, var(--paper) 15%, transparent);padding-bottom:10px;font-size:.94rem}
.result-row strong{font-family:var(--display);font-size:1.18rem;color:var(--accent-2);font-weight:700;font-variant-numeric:tabular-nums}
.progress{height:8px;background:color-mix(in srgb, var(--paper) 14%, transparent);border-radius:999px;overflow:hidden}
.progress>div{height:100%;background:var(--accent);width:0%;transition:width .4s ease;border-radius:999px}

/* ---------- Checklist / steps ---------- */
.checklist{list-style:none;padding:0;margin:0}
.checklist li{display:grid;grid-template-columns:22px 1fr;gap:10px;align-items:start;margin:.7rem 0;color:var(--ink-2)}
.checklist li:before{content:"";width:16px;height:16px;margin-top:4px;border-radius:4px;
  background:var(--accent-soft);box-shadow:inset 0 0 0 1.5px var(--accent)}
.step-list{counter-reset:steps;list-style:none;padding:0}
.step-list li{counter-increment:steps;position:relative;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--surface);padding:18px 20px 18px 64px;margin:14px 0;box-shadow:var(--shadow-xs)}
.step-list li:before{content:counter(steps);position:absolute;left:18px;top:18px;display:inline-grid;place-items:center;
  width:30px;height:30px;background:var(--accent-soft);color:var(--accent);
  font-family:var(--mono);font-weight:600;font-size:.86rem;border-radius:8px}

/* ---------- Tool panels ---------- */
.tool-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);padding:28px;margin-top:20px}
.tool-panel h2{font-size:1.4rem;margin-bottom:18px;letter-spacing:-.025em}
.tool-panel label{display:block;font-weight:600;margin-bottom:14px;color:var(--ink);font-size:.92rem}
.tool-panel label input[type=checkbox]{margin-right:.5rem}
.tool-panel input,.tool-panel select,.tool-panel textarea{margin-top:6px}
.result-box{border:1px solid var(--line);background:var(--accent-tint);padding:20px;
  margin-top:18px;border-radius:var(--radius);color:var(--ink)}
.score-meter{display:grid;grid-template-columns:1fr auto;gap:14px;align-items:center;margin:14px 0}
.score-meter .progress{background:var(--shade)}
.score-meter .progress>div{background:var(--accent)}
.score-number{font-family:var(--display);font-size:1.75rem;font-weight:800;color:var(--ink);
  letter-spacing:-.03em;font-variant-numeric:tabular-nums}

/* ---------- Pills / regions / misc ---------- */
.pill-list{display:flex;flex-wrap:wrap;gap:6px;padding:0;margin:12px 0;list-style:none}
.pill-list li{padding:.3rem .65rem;background:var(--accent-soft);color:var(--accent);
  font-family:var(--mono);font-size:.72rem;font-weight:600;border-radius:999px;letter-spacing:.02em}
.region-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.region-card details{border-top:1px solid var(--line);padding-top:10px;margin-top:10px}
.region-card summary{cursor:pointer;font-weight:600;color:var(--ink);list-style:none;
  display:flex;align-items:center;gap:.5rem}
.region-card summary::-webkit-details-marker{display:none}
.region-card summary:before{content:"+";display:inline-block;width:1em;color:var(--accent);font-weight:700;
  transition:transform .15s ease}
.region-card details[open] summary:before{content:"−"}
.mini-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.mini-form label{font-weight:600;color:var(--ink);font-size:.88rem}
.mini-form label input,.mini-form label select,.mini-form label textarea{margin-top:6px}
.seo-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.sample{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-xs)}
.page-links{display:flex;flex-wrap:wrap;gap:8px}
.page-links a{border:1px solid var(--line-strong);border-radius:8px;padding:.5rem .85rem;
  background:var(--surface);font-weight:500;font-size:.88rem;color:var(--ink);
  transition:.15s ease}
.page-links a:hover{background:var(--ink);color:var(--paper);border-color:var(--ink);transform:translateY(-1px)}
.source-list{columns:2;gap:30px}
.source-list li{break-inside:avoid;margin:.4rem 0;color:var(--muted)}
.empty-state{padding:22px;border:1.5px dashed var(--line-strong);border-radius:var(--radius);
  background:var(--surface);color:var(--muted);text-align:center}

/* ---------- Live status dot ---------- */
.live-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--ok);
  box-shadow:0 0 0 0 color-mix(in srgb, var(--ok) 60%, transparent);
  animation:pulse 1.8s ease-out infinite;margin-right:.45rem;vertical-align:middle}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 color-mix(in srgb, var(--ok) 55%, transparent)}
  70%{box-shadow:0 0 0 8px transparent}
  100%{box-shadow:0 0 0 0 transparent}
}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:color-mix(in srgb, var(--paper) 75%, transparent);
  margin-top:64px;border-top:1px solid var(--accent)}
.footer-inner{max-width:var(--max);margin:0 auto;padding:52px 24px;
  display:grid;grid-template-columns:1.2fr .8fr;gap:36px}
.site-footer h2{font-family:var(--display);font-size:1.3rem;color:var(--paper);
  margin-bottom:.6rem;letter-spacing:-.02em}
.site-footer p{color:color-mix(in srgb, var(--paper) 70%, transparent);font-size:.94rem}
.site-footer a{color:var(--paper);text-decoration:none;border-bottom:1px solid color-mix(in srgb, var(--paper) 25%, transparent)}
.site-footer a:hover{color:var(--accent-2);border-bottom-color:var(--accent-2)}
.site-footer strong{font-weight:600;color:var(--paper)}

/* ---------- Reveal animation (IntersectionObserver target) ---------- */
.reveal{opacity:0;transform:translateY(8px);transition:opacity .5s ease, transform .5s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .grid.four{grid-template-columns:repeat(2,minmax(0,1fr))}
  .filters{grid-template-columns:1fr 1fr}
  .hero{grid-template-columns:1fr;padding:48px 36px}
  .calculator{grid-template-columns:1fr}
}
@media (max-width:860px){
  .hero,.page-hero{width:calc(100% - 24px);margin:14px auto 0;border-radius:var(--radius);padding:32px 22px}
  .hero{gap:22px}
  .stats{grid-template-columns:1fr 1fr 1fr;gap:8px}
  .stat{padding:14px}
  .actions{flex-direction:column}
  .btn{width:100%}
  .grid.two,.grid.three,.funders,.calculator,.footer-inner,.region-grid,.mini-form,.seo-list,.resource-list,.download-list{grid-template-columns:1fr}
  .filters{grid-template-columns:1fr}
  .source-list{columns:1}
  .nav-toggle{display:inline-flex}
  .nav{display:none;position:absolute;left:12px;right:12px;top:62px;background:var(--paper-2);
    border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);
    padding:10px;flex-direction:column;align-items:stretch;gap:2px}
  .nav.open{display:flex}
  .nav a{border-radius:8px;padding:.7rem .85rem;font-size:.95rem}
  .header-inner{padding:12px 16px}
  .section{padding:54px 18px}
  .brand-sub{display:none}
}
@media (max-width:520px){
  .brand-mark{width:34px;height:34px}
  .brand-title{font-size:.95rem}
  .stats{grid-template-columns:1fr}
  .footer-inner{padding:40px 18px}
  .resource-actions a{width:100%}
  .page-hero{padding:28px 20px}
  h1{letter-spacing:-.035em}
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;scroll-behavior:auto!important;animation:none!important}
  .reveal{opacity:1;transform:none}
}

/* Print */
@media print{
  .site-header,.site-footer,.breadcrumb,.nav-toggle,.actions{display:none}
  body{background:#fff;color:#000}
  .hero,.page-hero,.section{box-shadow:none;max-width:none;margin:0;border-radius:0;color:#000;background:#fff;border:0}
  .hero h1,.hero .lead{color:#000}
  .section{padding:24px 0}
  .card,.notice,.callout,.warning,.tool-panel,.resource-card,.download-item,.step-list li{box-shadow:none;border:1px solid #ccc}
  .template-block,.generated,.calc-results,.card.dark{background:#fff;color:#000;border:1px solid #ccc}
}
