/* ============================================================
   Save Ormskirk Children's A&E — campaign engine stylesheet
   Palette + type tokens are injected from campaign.config.json
   at build time (see :root below, written by build.js).
   Mobile-first. No external requests. Self-hosted fonts.
   ============================================================ */

@font-face {
  font-family: 'Anton';
  src: url('/assets/fonts/anton-latin.woff2') format('woff2');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Oswald';
  src: url('/assets/fonts/oswald-latin.woff2') format('woff2');
  font-weight: 300 700; font-style: normal; font-display: swap;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Oswald',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  font-size:18px;
  font-weight:300;
  letter-spacing:.005em;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--blue);text-underline-offset:3px}
h1,h2,h3,h4{font-family:'Anton',Impact,'Oswald',sans-serif;font-weight:400;line-height:.98;letter-spacing:.01em;text-transform:uppercase;margin:0 0 .5em}
h1{font-size:clamp(2.6rem,9vw,5.5rem)}
h2{font-size:clamp(2rem,6vw,3.4rem)}
h3{font-size:clamp(1.4rem,4vw,2rem)}
p{margin:0 0 1.1em}
strong{font-weight:600}
.wrap{width:100%;max-width:1120px;margin:0 auto;padding:0 20px}
.narrow{max-width:760px}
.eyebrow{font-family:'Oswald';text-transform:uppercase;letter-spacing:.22em;font-weight:600;font-size:.8rem;color:var(--accent)}
.section{padding:clamp(48px,8vw,96px) 0}
.section--blue{background:var(--blue);color:#fff}
.section--blue h2,.section--blue h3{color:#fff}
.section--dark{background:var(--blue-dark);color:#fff}
.section--dark h2,.section--dark h3{color:#fff}
.section--cream{background:var(--cream)}
.section--white{background:#fff}
.lead{font-size:clamp(1.15rem,2.4vw,1.5rem);font-weight:300;line-height:1.5}
.center{text-align:center}
.mt0{margin-top:0}.mb0{margin-bottom:0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;justify-content:center;
  font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  font-size:1.05rem;line-height:1;
  padding:18px 30px;border-radius:8px;border:0;cursor:pointer;text-decoration:none;
  transition:transform .12s ease, box-shadow .12s ease, background .12s ease;
  box-shadow:0 6px 0 rgba(0,0,0,.18);
}
.btn:active{transform:translateY(3px);box-shadow:0 3px 0 rgba(0,0,0,.18)}
.btn--accent{background:var(--accent);color:#fff;box-shadow:0 6px 0 var(--accent-dark)}
.btn--accent:hover{background:#ff0a35}
.btn--blue{background:var(--blue);color:#fff;box-shadow:0 6px 0 var(--blue-dark)}
.btn--blue:hover{background:var(--blue-light)}
.btn--ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.6);box-shadow:none;padding:16px 28px}
.btn--ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn--ghost-dark{background:transparent;color:var(--blue);border:2px solid var(--blue);box-shadow:none;padding:16px 28px}
.btn--ghost-dark:hover{background:var(--blue);color:#fff}
.btn--lg{font-size:1.2rem;padding:22px 40px}
.btn--block{display:flex;width:100%}
.btn-row{display:flex;flex-wrap:wrap;gap:14px}
.btn-row--center{justify-content:center}

/* ---------- Header / nav ---------- */
.site-header{position:sticky;top:0;z-index:60;background:var(--blue);color:#fff;border-bottom:3px solid var(--accent)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff}
.brand__mark{width:38px;height:38px;flex:0 0 auto}
.brand__text{font-family:'Anton';text-transform:uppercase;font-size:1.05rem;line-height:.95;letter-spacing:.02em}
.brand__text span{display:block;color:var(--gold);font-size:.72rem;letter-spacing:.16em}
.nav{display:flex;align-items:center;gap:4px}
.nav a{color:#fff;text-decoration:none;font-family:'Oswald';font-weight:500;text-transform:uppercase;letter-spacing:.05em;font-size:.82rem;padding:10px 12px;border-radius:6px;white-space:nowrap}
.nav a:hover{background:rgba(255,255,255,.12)}
.nav a.is-active{color:var(--gold)}
.nav__cta{background:var(--accent)!important;margin-left:6px}
.nav__cta:hover{background:var(--accent-dark)!important}
.nav-toggle{display:none;background:none;border:0;color:#fff;cursor:pointer;padding:8px}
.nav-toggle svg{width:30px;height:30px}

@media(max-width:900px){
  .nav-toggle{display:block}
  .nav{position:fixed;inset:66px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--blue-dark);padding:8px 16px 20px;transform:translateY(-120%);
    transition:transform .28s ease;box-shadow:0 20px 40px rgba(0,0,0,.3);max-height:calc(100vh - 66px);overflow:auto}
  .nav.is-open{transform:translateY(0)}
  .nav a{font-size:1.05rem;padding:14px 10px;border-bottom:1px solid rgba(255,255,255,.08)}
  .nav__cta{margin:12px 0 0;text-align:center}
}

/* ---------- Hero ---------- */
.hero{position:relative;background:var(--blue-dark);color:#fff;overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center 30%}
.hero__scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(0,20,60,.62) 0%,rgba(0,20,60,.55) 40%,rgba(0,20,60,.82) 100%)}
.hero__inner{position:relative;z-index:2;padding:clamp(40px,7vw,84px) 0 clamp(36px,6vw,64px)}
.hero__kicker{display:inline-block;background:var(--accent);color:#fff;font-family:'Oswald';font-weight:600;
  text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;padding:7px 14px;border-radius:4px;margin-bottom:22px}
.hero h1{color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.35);max-width:15ch}
.hero__sub{font-size:clamp(1.15rem,2.6vw,1.55rem);font-weight:300;max-width:40ch;margin:0 0 28px;color:#eaf0fb}
.hero__cta{margin-bottom:26px}
.hero__meta{display:flex;flex-wrap:wrap;gap:10px 26px;align-items:center;font-size:.95rem;color:#cdd8ee}

/* ---------- Counters / scoreboard ---------- */
.counters{display:grid;grid-template-columns:1fr;gap:16px;margin-top:8px}
@media(min-width:680px){.counters{grid-template-columns:1fr 1fr}}
.score{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:12px;padding:18px 20px;backdrop-filter:blur(3px)}
.score__label{font-family:'Oswald';text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:#cdd8ee;margin-bottom:8px}
.score__value{font-family:'Anton';font-size:clamp(2.4rem,7vw,3.4rem);line-height:1;color:#fff;letter-spacing:.02em}
.score__value .digit{display:inline-block;background:var(--blue-dark);border-radius:6px;padding:.06em .12em;margin:0 1px;box-shadow:inset 0 -3px 0 rgba(0,0,0,.35)}
.score--days .score__value{color:var(--gold)}
.score__sub{font-size:.85rem;color:#cdd8ee;margin-top:6px;font-weight:300}
.score--accent{background:var(--accent);border-color:transparent}
.score--accent .score__label,.score--accent .score__sub{color:#ffe3e8}

/* ---------- Stat strip ---------- */
.statstrip{display:grid;grid-template-columns:1fr;gap:2px;background:var(--accent-dark)}
@media(min-width:720px){.statstrip{grid-template-columns:repeat(3,1fr)}}
.statstrip__item{background:var(--accent);color:#fff;padding:26px 22px;text-align:center}
.statstrip__value{font-family:'Anton';font-size:clamp(2.2rem,6vw,3rem);line-height:1}
.statstrip__label{font-family:'Oswald';text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;margin-top:6px;color:#ffe3e8}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:22px}
.grid--2{grid-template-columns:1fr}
.grid--3{grid-template-columns:1fr}
@media(min-width:720px){.grid--2{grid-template-columns:1fr 1fr}.grid--3{grid-template-columns:repeat(3,1fr)}}
.card{background:#fff;border-radius:14px;padding:26px;box-shadow:0 10px 30px rgba(0,20,60,.07);border:1px solid rgba(0,32,135,.06)}
.card--action{display:flex;flex-direction:column;height:100%}
.card__n{font-family:'Anton';font-size:2.2rem;color:var(--accent);line-height:1}
.card h3{margin:.3em 0 .35em}
.card p{color:var(--muted);font-size:1rem}
.card .btn{margin-top:auto}
.icon{width:34px;height:34px;color:var(--blue)}

/* ---------- Timeline ---------- */
.timeline{position:relative;max-width:820px;margin:0 auto;padding-left:34px}
.timeline::before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:3px;background:linear-gradient(var(--blue),var(--accent))}
.tl-item{position:relative;padding:0 0 34px}
.tl-item::before{content:"";position:absolute;left:-33px;top:4px;width:20px;height:20px;border-radius:50%;background:var(--accent);border:4px solid var(--cream);box-shadow:0 0 0 2px var(--accent)}
.tl-item:last-child::before{background:var(--gold);box-shadow:0 0 0 2px var(--gold)}
.tl-date{font-family:'Oswald';font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);font-size:.85rem}
.tl-item h3{font-size:1.35rem;margin:.15em 0 .25em}
.tl-item p{margin:0;color:var(--muted);font-size:1.02rem}
.section--blue .tl-item::before{border-color:var(--blue)}
.section--blue .tl-item p{color:#dbe4f5}
.section--blue .timeline::before{background:linear-gradient(#fff,var(--gold))}

/* ---------- Said vs Did ---------- */
.svd{display:grid;gap:18px}
.svd__row{display:grid;grid-template-columns:1fr;gap:2px;border-radius:14px;overflow:hidden;box-shadow:0 10px 30px rgba(0,20,60,.08)}
@media(min-width:720px){.svd__row{grid-template-columns:1fr 1fr}}
.svd__said,.svd__did{padding:22px 24px}
.svd__said{background:#eef2fb;color:var(--blue-dark)}
.svd__did{background:var(--blue);color:#fff}
.svd__tag{font-family:'Oswald';font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;display:block;margin-bottom:8px;opacity:.85}
.svd__said .svd__tag{color:var(--accent)}
.svd__did .svd__tag{color:var(--gold)}
.svd__said p,.svd__did p{margin:0;font-size:1.08rem}

/* ---------- Distance graphic ---------- */
.distance{background:#fff;border-radius:16px;padding:clamp(24px,4vw,40px);box-shadow:0 10px 30px rgba(0,20,60,.08)}
.dist-bar{display:flex;align-items:center;gap:12px;margin:14px 0 6px}
.dist-node{text-align:center;flex:0 0 auto}
.dist-dot{width:20px;height:20px;border-radius:50%;margin:0 auto 6px}
.dist-dot--o{background:var(--accent)}
.dist-dot--s{background:var(--blue)}
.dist-node span{font-family:'Oswald';font-weight:600;text-transform:uppercase;font-size:.78rem;letter-spacing:.05em}
.dist-line{flex:1;height:4px;background:repeating-linear-gradient(90deg,var(--muted) 0 8px,transparent 8px 16px);position:relative}
.dist-line b{position:absolute;top:-30px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-family:'Oswald';font-weight:700;font-size:.8rem;padding:3px 10px;border-radius:20px;white-space:nowrap}
.prox{display:grid;gap:12px;margin-top:26px}
.prox__item{display:flex;gap:12px;align-items:flex-start;padding:14px 16px;background:var(--cream);border-radius:10px;border-left:4px solid var(--gold)}
.prox__item strong{display:block;font-weight:600}
.prox__item small{color:var(--muted)}

/* ---------- Forms ---------- */
.form-card{background:#fff;border-radius:16px;padding:clamp(24px,4vw,40px);box-shadow:0 14px 40px rgba(0,20,60,.1);max-width:640px;margin:0 auto}
.field{margin-bottom:18px}
.field label{display:block;font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:.82rem;margin-bottom:7px;color:var(--blue-dark)}
.field .req{color:var(--accent)}
.field input,.field textarea{
  width:100%;font-family:inherit;font-size:1.05rem;font-weight:300;color:var(--ink);
  padding:14px 16px;border:2px solid #d7deea;border-radius:10px;background:#fdfefe;transition:border-color .15s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--blue)}
.field textarea{min-height:120px;resize:vertical}
.field-2{display:grid;gap:18px}
@media(min-width:560px){.field-2{grid-template-columns:1fr 1fr}}
.consent{display:flex;gap:12px;align-items:flex-start;background:var(--cream);border:2px solid #e5ddc9;border-radius:12px;padding:16px 18px;margin:6px 0 20px}
.consent input{width:22px;height:22px;flex:0 0 auto;margin-top:2px;accent-color:var(--accent)}
.consent label{font-family:'Oswald';font-weight:300;font-size:.95rem;line-height:1.45;text-transform:none;letter-spacing:0;color:var(--ink);margin:0}
.hp{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{font-size:.85rem;color:var(--muted);margin-top:14px}
.form-note a{color:var(--blue)}

/* ---------- Open letter ---------- */
.letter{background:#fff;border-radius:16px;box-shadow:0 16px 50px rgba(0,20,60,.1);padding:clamp(28px,5vw,64px);max-width:820px;margin:0 auto;position:relative}
.letter::before{content:"";position:absolute;top:0;left:0;right:0;height:8px;background:linear-gradient(90deg,var(--blue),var(--accent));border-radius:16px 16px 0 0}
.letter h2{font-size:clamp(1.8rem,5vw,2.8rem);margin-bottom:.6em;color:var(--blue-dark)}
.letter p{font-size:1.15rem;line-height:1.7;font-weight:300;color:#232a34}
.letter p strong{font-weight:600;color:var(--blue-dark)}
.letter em{color:var(--muted)}
.letter__sign{font-family:'Anton';text-transform:uppercase;color:var(--accent);font-size:1.6rem;margin-top:.4em}

/* ---------- Copy block ---------- */
.copyblock{background:#0f1830;color:#e7edf9;border-radius:14px;padding:24px;position:relative}
.copyblock pre{white-space:pre-wrap;font-family:'Oswald',monospace;font-weight:300;font-size:1rem;line-height:1.6;margin:0}
.copy-btn{position:sticky;top:12px;float:right;margin:-8px -8px 8px 8px}

/* ---------- Story wall ---------- */
.stories{columns:1;column-gap:22px}
@media(min-width:640px){.stories{columns:2}}
.story{break-inside:avoid;background:#fff;border-radius:14px;padding:22px 24px;margin:0 0 22px;box-shadow:0 8px 24px rgba(0,20,60,.07);border-top:4px solid var(--accent)}
.story p{font-size:1.05rem;color:#2a313c;font-style:italic}
.story cite{font-family:'Oswald';font-weight:600;font-style:normal;color:var(--blue);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto}
.faq details{background:#fff;border-radius:12px;margin-bottom:12px;box-shadow:0 6px 20px rgba(0,20,60,.06);overflow:hidden}
.faq summary{cursor:pointer;list-style:none;padding:20px 24px;font-family:'Oswald';font-weight:600;font-size:1.1rem;color:var(--blue-dark);display:flex;justify-content:space-between;gap:16px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:'Anton';color:var(--accent);font-size:1.6rem;line-height:1;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 24px 22px;margin:0;color:var(--muted);font-size:1.05rem}

/* ---------- Callout / ask block ---------- */
.ask{background:var(--blue-dark);color:#fff;border-radius:16px;padding:clamp(26px,4vw,44px);border:1px solid rgba(255,255,255,.12)}
.ask__primary{font-family:'Anton';text-transform:uppercase;font-size:clamp(1.5rem,4vw,2.3rem);line-height:1.05;color:#fff;margin:0 0 .5em}
.ask__secondary{font-size:1.1rem;color:#dbe4f5;font-weight:300;margin:0}
.pill{display:inline-block;background:var(--gold);color:var(--blue-dark);font-family:'Oswald';font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;padding:6px 12px;border-radius:20px;margin-bottom:16px}

/* ---------- Share buttons ---------- */
.share{display:flex;flex-wrap:wrap;gap:12px}
.share a{display:inline-flex;align-items:center;gap:9px;text-decoration:none;color:#fff;font-family:'Oswald';
  font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:.9rem;padding:14px 20px;border-radius:8px}
.share svg{width:20px;height:20px;fill:currentColor}
.share--wa{background:#25D366;color:#053}
.share--fb{background:#1877F2}
.share--x{background:#111}
.share a:hover{filter:brightness(1.08)}

/* ---------- Footer ---------- */
.site-footer{background:var(--blue-dark);color:#c9d4ec;padding:54px 0 120px;font-size:.95rem;font-weight:300}
@media(min-width:900px){.site-footer{padding-bottom:54px}}
.footer-grid{display:grid;gap:30px;grid-template-columns:1fr}
@media(min-width:720px){.footer-grid{grid-template-columns:2fr 1fr 1fr}}
.site-footer h4{font-family:'Oswald';font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.85rem;color:#fff;margin:0 0 14px}
.site-footer a{color:#c9d4ec;text-decoration:none;display:block;padding:4px 0}
.site-footer a:hover{color:#fff}
.footer-brand{display:flex;gap:12px;align-items:flex-start}
.footer-brand p{margin:.3em 0 0;max-width:38ch}
.footer-legal{margin-top:34px;padding-top:22px;border-top:1px solid rgba(255,255,255,.12);display:flex;flex-wrap:wrap;gap:8px 22px;align-items:center;font-size:.82rem;color:#8fa1c4}
.footer-legal a{display:inline;color:#8fa1c4}

/* ---------- Sticky mobile CTA ---------- */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:70;padding:10px 14px;
  background:linear-gradient(180deg,rgba(0,31,87,0),var(--blue-dark) 40%);display:none}
.sticky-cta .btn{width:100%;box-shadow:0 4px 0 var(--accent-dark)}
@media(max-width:900px){.sticky-cta{display:block}}
@media(min-width:901px){.site-footer{padding-bottom:54px}}

/* ---------- Utility / misc ---------- */
.badge-notaffil{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  border-radius:8px;padding:8px 14px;font-size:.82rem;color:#dbe4f5}
.prose{max-width:760px;margin:0 auto}
.prose h2{margin-top:1.4em;font-size:clamp(1.5rem,4vw,2.2rem)}
.prose h2:first-child{margin-top:0}
.prose p,.prose li{font-size:1.08rem;font-weight:300;color:#2a313c}
.prose strong{font-weight:600;color:var(--blue-dark)}
.anchor{scroll-margin-top:84px}
.hr{height:1px;background:rgba(0,32,135,.12);border:0;margin:44px 0}
.toast{position:fixed;bottom:96px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;
  padding:14px 22px;border-radius:10px;font-family:'Oswald';font-weight:500;opacity:0;pointer-events:none;transition:.25s;z-index:90;box-shadow:0 10px 30px rgba(0,0,0,.3)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important}}

/* scoreboard separators + spacing */
.score__value .sep{display:inline-block;padding:0 .04em;color:inherit}
.js-sig-counter,.js-days-counter{display:inline-flex;flex-wrap:wrap}
