/* =============================================================
   JoinAStudy.ca — Design System
   Palette from brand: Navy #183868 · Sky #6898D0 · Amber #FFB600
   Type: Bitter (display slab) · Atkinson Hyperlegible (body)
   ============================================================= */

/* ---------- Fonts (self-hosted, latin, woff2 only) ---------- */
@font-face{font-family:'Atkinson Hyperlegible';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/atkinson-hyperlegible-latin-400-normal.woff2') format('woff2')}
@font-face{font-family:'Atkinson Hyperlegible';font-style:italic;font-weight:400;font-display:swap;src:url('../fonts/atkinson-hyperlegible-latin-400-italic.woff2') format('woff2')}
@font-face{font-family:'Atkinson Hyperlegible';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/atkinson-hyperlegible-latin-700-normal.woff2') format('woff2')}
@font-face{font-family:'Bitter';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/bitter-latin-600-normal.woff2') format('woff2')}
@font-face{font-family:'Bitter';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/bitter-latin-700-normal.woff2') format('woff2')}

/* ---------- Tokens ---------- */
:root{
  --navy:#183868;          /* brand primary */
  --navy-deep:#0F2547;     /* hero / footer depth */
  --navy-ink:#1C2B45;      /* headings on light */
  --sky:#6898D0;           /* brand accent */
  --sky-soft:#A8C4E8;
  --sky-tint:#EAF1FA;      /* chips, tints */
  --amber:#FFB600;         /* CTA only */
  --amber-deep:#E5A400;
  --paper:#F7F9FC;         /* page background */
  --card:#FFFFFF;
  --mist:#DCE6F2;          /* borders, rules */
  --ink:#28374F;           /* body text — AA on paper/card */
  --ink-soft:#4C5D77;
  --ok:#1E7B4F;            /* recruiting */
  --shadow-s:0 1px 2px rgba(24,56,104,.08),0 2px 8px rgba(24,56,104,.06);
  --shadow-m:0 4px 14px rgba(24,56,104,.10),0 14px 34px rgba(24,56,104,.10);
  --shadow-l:0 10px 24px rgba(15,37,71,.16),0 30px 60px rgba(15,37,71,.16);
  --r-s:6px;--r-m:12px;--r-l:18px;
  --font-body:'Atkinson Hyperlegible',system-ui,-apple-system,'Segoe UI',sans-serif;
  --font-display:'Bitter',Georgia,'Times New Roman',serif;
  --fs-0:1.0625rem;  /* 17px base — legible for older adults */
  --fs-1:1.1875rem;
  --fs-2:1.375rem;
  --fs-3:1.625rem;
  --fs-4:2.0625rem;
  --fs-5:clamp(2.25rem,1.6rem + 2.2vw,3.1875rem);
  --fs-6:clamp(2.6rem,1.9rem + 3.4vw,4rem);
  --space-1:.5rem;--space-2:1rem;--space-3:1.5rem;--space-4:2.5rem;--space-5:4rem;--space-6:6rem;
  --wrap:1180px;
  --path-w:2px;            /* care-path rail */
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
[hidden]{display:none!important}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;font-family:var(--font-body);font-size:var(--fs-0);line-height:1.65;color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.15;color:var(--navy-ink);margin:0 0 .5em;text-wrap:balance;overflow-wrap:break-word}
h1{font-size:var(--fs-6)}
h2{font-size:var(--fs-5)}
h3{font-size:var(--fs-3)}
h4{font-size:var(--fs-2)}
p{margin:0 0 1.1em}
a{color:var(--navy);text-decoration-color:var(--sky);text-decoration-thickness:2px;text-underline-offset:3px}
a:hover{color:var(--sky)}
:focus-visible{outline:3px solid var(--sky);outline-offset:3px;border-radius:2px}
button{font:inherit}
::selection{background:var(--sky);color:#fff}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--navy);color:#fff;padding:.75rem 1.25rem;z-index:200;border-radius:0 0 var(--r-s) 0}
.skip-link:focus{left:0}
.wrap{width:min(var(--wrap),100% - 2.5rem);margin-inline:auto}
.section{padding-block:var(--space-5)}
@media (min-width:900px){.section{padding-block:var(--space-6)}}
.section--tight{padding-block:var(--space-4)}
.section--paper{background:var(--paper)}
.section--card{background:var(--card)}
.section--navy{background:linear-gradient(160deg,var(--navy-deep),var(--navy) 70%);color:#E8EFF9}
.section--navy h2,.section--navy h3{color:#fff}
.center{text-align:center}
.flow>*+*{margin-top:var(--space-3)}

/* Eyebrow — structural label */
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-weight:700;font-size:.8125rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sky);margin-bottom:var(--space-2)}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--sky);border-radius:2px}
.section--navy .eyebrow{color:var(--sky-soft)}
.lede{font-size:var(--fs-1);color:var(--ink-soft);max-width:62ch}
.section--navy .lede{color:#C7D7EF}
.center .lede{margin-inline:auto}

/* ---------- Care-path rail (signature) ----------
   A thin sky line echoing the stethoscope tube in the logo:
   threads the homepage sections together and marks each with a node. */
.pathline{position:relative}
.pathline::before{content:"";position:absolute;left:calc(50% - var(--path-w)/2);top:0;bottom:0;width:var(--path-w);background:linear-gradient(var(--sky-soft),var(--sky));opacity:.55}
.path-node{position:relative;width:18px;height:18px;margin:-9px auto var(--space-3);border-radius:50%;background:var(--card);border:3px solid var(--sky);box-shadow:0 0 0 6px var(--paper)}
.section--navy .path-node{box-shadow:0 0 0 6px var(--navy-deep);background:var(--navy-deep)}
@media (max-width:719px){.pathline::before,.path-node{display:none}}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;min-height:52px;padding:.8rem 1.6rem;border-radius:var(--r-s);border:2px solid transparent;font-weight:700;font-size:1.0625rem;text-decoration:none;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background-color .15s ease,color .15s ease}
.btn:active{transform:translateY(1px)}
.btn--join{background:var(--amber);color:var(--navy-deep);box-shadow:0 3px 0 var(--amber-deep),var(--shadow-s)}
.btn--join:hover{background:#FFC42E;color:var(--navy-deep);box-shadow:0 3px 0 var(--amber-deep),var(--shadow-m)}
.btn--navy{background:var(--navy);color:#fff}
.btn--navy:hover{background:var(--navy-deep);color:#fff}
.btn--ghost{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn--ghost:hover{background:var(--navy);color:#fff}
.section--navy .btn--ghost,.hero .btn--ghost{color:#fff;border-color:rgba(255,255,255,.65)}
.section--navy .btn--ghost:hover,.hero .btn--ghost:hover{background:rgba(255,255,255,.12);color:#fff;border-color:#fff}
.btn--sm{min-height:42px;padding:.45rem 1.05rem;font-size:.95rem}
.btn .i{width:20px;height:20px;flex:none}

/* Chips */
.chip{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .8rem;border-radius:999px;background:var(--sky-tint);color:var(--navy);font-weight:700;font-size:.85rem;text-decoration:none;border:1px solid transparent}
a.chip:hover{border-color:var(--sky);color:var(--navy)}
.chip--on{background:var(--navy);color:#fff}
.badge-rec{display:inline-flex;align-items:center;gap:.45rem;font-weight:700;font-size:.85rem;color:var(--ok)}
.badge-rec .dot{width:9px;height:9px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 0 rgba(30,123,79,.5);animation:pulse 2s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 9px rgba(30,123,79,0)}100%{box-shadow:0 0 0 0 rgba(30,123,79,0)}}
@media (prefers-reduced-motion:reduce){.badge-rec .dot{animation:none}}

/* ---------- Header ---------- */
.topbar{background:var(--navy-deep);color:#CBDBF2;font-size:.9rem}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:40px}
.topbar a{color:#fff;text-decoration:none;font-weight:700}
.topbar a:hover{color:var(--amber)}
.topbar .tag{opacity:.9}
.topbar .util{display:flex;align-items:center;gap:1.1rem}
@media (max-width:719px){.topbar .tag{display:none}.topbar .wrap{justify-content:center}}
.site-head{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.94);backdrop-filter:saturate(1.4) blur(10px);border-bottom:1px solid var(--mist)}
.site-head .wrap{display:flex;align-items:center;gap:1.4rem;min-height:76px}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none;margin-right:auto}
.brand img{height:52px;width:auto}
.brand .brand-text{font-family:var(--font-display);font-weight:700;font-size:1.45rem;line-height:1;color:var(--navy)}
.brand .brand-text em{font-style:normal;color:var(--sky)}
.nav{display:flex;align-items:center;gap:.2rem}
.nav a{display:inline-block;padding:.55rem .8rem;border-radius:var(--r-s);color:var(--navy-ink);text-decoration:none;font-weight:700}
.nav a:hover,.nav .current-menu-item>a,.nav .current_page_item>a{background:var(--sky-tint);color:var(--navy)}
.head-cta{margin-left:.4rem}
.nav-toggle{display:none;background:none;border:2px solid var(--navy);border-radius:var(--r-s);color:var(--navy);padding:.5rem .7rem;font-weight:700;cursor:pointer}
@media (max-width:1023px){
  .nav-toggle{display:inline-flex;align-items:center;gap:.5rem}
  .nav{position:fixed;inset:0 0 0 auto;width:min(360px,88vw);background:var(--card);flex-direction:column;align-items:stretch;padding:5.5rem 1.4rem 2rem;gap:.3rem;transform:translateX(100%);transition:transform .25s ease;box-shadow:var(--shadow-l);z-index:99}
  .nav.open{transform:none}
  .nav a{font-size:1.15rem;padding:.9rem 1rem}
  .head-cta{margin:1rem 0 0}
  body.nav-open{overflow:hidden}
  /* Dim the page behind the open drawer so context is clear and tap-to-close is discoverable */
  body.nav-open::before{content:"";position:fixed;inset:0;background:rgba(15,37,71,.45);z-index:98;animation:jas-fade .2s ease}
  @keyframes jas-fade{from{opacity:0}}
}

/* ---------- Hero ---------- */
.hero{position:relative;background:linear-gradient(155deg,var(--navy-deep) 0%,#14315C 55%,var(--navy) 100%);color:#EAF1FB;overflow:hidden}
.hero::after{content:"";position:absolute;inset:auto -10% -55% -10%;height:70%;background:radial-gradient(60% 100% at 50% 100%,rgba(104,152,208,.28),transparent 70%)}
.hero .tube{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;opacity:.5}
.hero .wrap{position:relative;z-index:2;display:grid;gap:var(--space-4);padding-block:var(--space-5);align-items:center}
@media (min-width:980px){.hero .wrap{grid-template-columns:1.05fr .95fr;padding-block:var(--space-6)}}
.hero h1{color:#fff;margin-bottom:.4em}
.hero h1 .accent{color:var(--amber)}
.hero .lede{color:#C9D9F0;font-size:var(--fs-2);max-width:32ch}
.hero .eyebrow{color:var(--sky-soft)}
.hero .eyebrow::before{background:var(--sky-soft)}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:var(--space-3)}
.hero-proof{display:flex;flex-wrap:wrap;gap:1rem 1.6rem;margin-top:var(--space-4);padding-top:var(--space-3);border-top:1px solid rgba(168,196,232,.3);color:#BCD0EC;font-size:.95rem}
.hero-proof b{color:#fff;font-family:var(--font-display);font-size:1.15rem;margin-right:.35rem}

/* Featured study deck */
.deck{position:relative;display:grid}
.deck .card-study{grid-area:1/1;box-shadow:var(--shadow-l)}
.deck .ghost{grid-area:1/1;border-radius:var(--r-m);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18)}
.deck .g1{transform:rotate(2.5deg) translate(14px,14px)}
.deck .g2{transform:rotate(-2deg) translate(-12px,26px)}
.deck-nav{display:flex;gap:.5rem;justify-content:flex-end;margin-top:var(--space-2)}
.deck-nav button{width:46px;height:46px;border-radius:50%;border:2px solid rgba(255,255,255,.55);background:transparent;color:#fff;cursor:pointer;font-size:1.15rem;line-height:1}
.deck-nav button:hover{background:rgba(255,255,255,.14)}
.deck-count{align-self:center;margin-right:auto;color:#BCD0EC;font-size:.9rem}

/* ---------- Study card ---------- */
.card-study{background:var(--card);border-radius:var(--r-m);padding:1.4rem 1.4rem 1.2rem;border:1px solid var(--mist);box-shadow:var(--shadow-s);display:flex;flex-direction:column;gap:.8rem;position:relative;transition:box-shadow .18s ease,transform .18s ease}
.card-study:hover{box-shadow:var(--shadow-m);transform:translateY(-3px)}
.card-study .row-top{display:flex;flex-wrap:wrap;gap:.45rem;align-items:center}
.card-study .row-top .badge-rec{margin-left:auto}
.card-study h3{font-size:var(--fs-2);margin:0}
.card-study h3 a{color:var(--navy-ink);text-decoration:none}
.card-study h3 a:hover{color:var(--sky)}
.card-study h3 a::after{content:"";position:absolute;inset:0}
.card-study .desc{color:var(--ink-soft);margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card-study .meta{display:flex;flex-wrap:wrap;gap:.4rem 1.1rem;color:var(--ink-soft);font-size:.92rem;border-top:1px dashed var(--mist);padding-top:.8rem}
.card-study .meta span{display:inline-flex;align-items:center;gap:.4rem}
.card-study .meta .i{width:17px;height:17px;color:var(--sky)}
.card-study .actions{display:flex;gap:.7rem;flex-wrap:wrap}
.card-study .actions .btn{position:relative;z-index:2}

/* Grid of cards */
.grid{display:grid;gap:var(--space-3)}
@media (min-width:700px){.grid--2{grid-template-columns:repeat(2,1fr)}.grid--3{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1024px){.grid--3{grid-template-columns:repeat(3,1fr)}.grid--4{grid-template-columns:repeat(4,1fr)}}

/* ---------- Pathway cards (3 ways in) ---------- */
.pathways{counter-reset:step}
.card-path{position:relative;background:var(--card);border:1px solid var(--mist);border-radius:var(--r-m);padding:1.8rem 1.6rem;box-shadow:var(--shadow-s);display:flex;flex-direction:column;gap:.6rem;transition:box-shadow .18s ease,transform .18s ease;text-decoration:none}
.card-path:hover{box-shadow:var(--shadow-m);transform:translateY(-4px)}
.card-path .icon{width:58px;height:58px;border-radius:14px;background:var(--sky-tint);color:var(--navy);display:grid;place-items:center;margin-bottom:.4rem}
.card-path .icon svg{width:30px;height:30px}
.card-path h3{margin:0}
.card-path p{color:var(--ink-soft);margin:0}
.card-path .go{margin-top:auto;padding-top:.9rem;font-weight:700;color:var(--navy);display:inline-flex;align-items:center;gap:.45rem}
.card-path:hover .go{color:var(--sky)}
.card-path .go .i{transition:transform .18s ease}
.card-path:hover .go .i{transform:translateX(4px)}

/* ---------- How it works (true sequence) ---------- */
.steps{display:grid;gap:var(--space-3);counter-reset:hiw}
@media (min-width:900px){.steps{grid-template-columns:repeat(3,1fr)}}
.step{position:relative;padding:1.4rem 1.4rem 1.4rem 1.5rem;background:var(--card);border-radius:var(--r-m);border:1px solid var(--mist)}
.step::before{counter-increment:hiw;content:counter(hiw);position:absolute;top:-18px;left:1.2rem;width:40px;height:40px;border-radius:50%;background:var(--navy);color:var(--amber);font-family:var(--font-display);font-weight:700;font-size:1.15rem;display:grid;place-items:center;box-shadow:0 0 0 5px var(--paper)}
@media (min-width:900px){
.step:not(:last-child)::after{content:"";position:absolute;top:2px;right:-14%;width:28%;height:2px;background:repeating-linear-gradient(90deg,var(--sky) 0 8px,transparent 8px 15px);opacity:.6}
}
.step h4{margin:.4rem 0 .3rem}
.step p{margin:0;color:var(--ink-soft)}

/* ---------- Stats band ---------- */
.stats{display:grid;gap:var(--space-3);text-align:center}
@media (min-width:720px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat b{display:block;font-family:var(--font-display);font-weight:700;font-size:var(--fs-5);color:var(--amber);line-height:1;font-variant-numeric:tabular-nums}
.stat span{color:#C7D7EF;font-weight:700}
.stat small{display:block;color:#9FB6D9;margin-top:.2rem}

/* ---------- Condition / location / article cards ---------- */
.card-cond{display:flex;align-items:center;gap:.9rem;background:var(--card);border:1px solid var(--mist);border-radius:var(--r-m);padding:1rem 1.1rem;text-decoration:none;font-weight:700;color:var(--navy-ink);transition:border-color .15s,box-shadow .15s,transform .15s}
.card-cond:hover{border-color:var(--sky);box-shadow:var(--shadow-s);transform:translateY(-2px);color:var(--navy)}
.card-cond .icon{width:44px;height:44px;flex:none;border-radius:10px;background:var(--sky-tint);display:grid;place-items:center;color:var(--navy)}
.card-cond .icon svg{width:24px;height:24px}
.card-cond .n{margin-left:auto;color:var(--ink-soft);font-size:.85rem;font-weight:700;background:var(--paper);border:1px solid var(--mist);border-radius:999px;padding:.15rem .6rem;white-space:nowrap}

.card-loc{background:var(--card);border:1px solid var(--mist);border-radius:var(--r-m);overflow:hidden;box-shadow:var(--shadow-s);display:flex;flex-direction:column;transition:box-shadow .18s,transform .18s;position:relative}
.card-loc:hover{box-shadow:var(--shadow-m);transform:translateY(-3px)}
.card-loc .ph{aspect-ratio:16/9;background:linear-gradient(140deg,var(--sky-tint),var(--mist));position:relative}
.card-loc .ph img{width:100%;height:100%;object-fit:cover}
.card-loc .body{padding:1.1rem 1.2rem 1.2rem;display:flex;flex-direction:column;gap:.35rem}
.card-loc .city{color:var(--sky);font-weight:700;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase}
.card-loc h3{font-size:var(--fs-1);margin:0}
.card-loc h3 a{color:var(--navy-ink);text-decoration:none}
.card-loc h3 a::after{content:"";position:absolute;inset:0}
.card-loc .pi{color:var(--ink-soft);font-size:.95rem}
.card-loc .n-studies{margin-top:.5rem;font-weight:700;color:var(--navy);font-size:.92rem}

.card-art{background:var(--card);border:1px solid var(--mist);border-radius:var(--r-m);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .18s,transform .18s;position:relative;box-shadow:var(--shadow-s)}
.card-art:hover{box-shadow:var(--shadow-m);transform:translateY(-3px)}
.card-art .ph{aspect-ratio:16/9;overflow:hidden;background:var(--sky-tint)}
.card-art .ph img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}
.card-art:hover .ph img{transform:scale(1.04)}
.card-art .body{padding:1.1rem 1.2rem 1.3rem;display:flex;flex-direction:column;gap:.4rem;flex:1}
.card-art .k{color:var(--sky);font-weight:700;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase}
.card-art h3{font-size:var(--fs-1);margin:0}
.card-art h3 a{color:var(--navy-ink);text-decoration:none}
.card-art h3 a::after{content:"";position:absolute;inset:0}
.card-art p{color:var(--ink-soft);margin:0;font-size:.98rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-art time{margin-top:auto;padding-top:.6rem;color:var(--ink-soft);font-size:.88rem}

/* ---------- Filters (archives) ---------- */
.filterbar{display:flex;flex-wrap:wrap;gap:.5rem;margin:var(--space-3) 0 var(--space-4)}
.filterbar .chip{font-size:.92rem;padding:.45rem 1rem}
.searchbox{display:flex;gap:.6rem;max-width:520px;margin-top:var(--space-2)}
.searchbox input{flex:1;min-height:52px;border:2px solid var(--mist);border-radius:var(--r-s);padding:.6rem 1rem;font:inherit;background:#fff}
.searchbox input:focus{outline:none;border-color:var(--sky);box-shadow:0 0 0 3px var(--sky-tint)}

/* ---------- Page hero (interior) ---------- */
.page-hero{background:linear-gradient(150deg,var(--navy-deep),var(--navy));color:#E8EFF9;padding-block:var(--space-4)}
.page-hero h1{color:#fff;margin-bottom:.25em;font-size:var(--fs-5)}
.page-hero .lede{color:#C9D9F0}
.crumbs{font-size:.9rem;color:#A9C0E4;margin-bottom:var(--space-2)}
.crumbs a{color:#D5E2F6;text-decoration:none;font-weight:700}
.crumbs a:hover{color:var(--amber)}
.crumbs .sep{margin:0 .5rem;opacity:.6}

/* ---------- Single study layout ---------- */
.study-grid{display:grid;gap:var(--space-4)}
@media (min-width:1000px){.study-grid{grid-template-columns:minmax(0,1fr) 360px;align-items:start}}
.facts{background:var(--card);border:1px solid var(--mist);border-left:5px solid var(--amber);border-radius:var(--r-m);padding:1.4rem;box-shadow:var(--shadow-s)}
.facts h3{font-size:var(--fs-1);margin-bottom:.9rem}
.facts dl{margin:0;display:grid;gap:.75rem}
.facts .f{display:flex;gap:.8rem;align-items:flex-start}
.facts .f .i{width:22px;height:22px;color:var(--sky);flex:none;margin-top:2px}
.facts dt{font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}
.facts dd{margin:0;font-weight:700;color:var(--navy-ink)}
.sidebar-cta{position:sticky;top:96px;display:flex;flex-direction:column;gap:var(--space-3)}
.joinbox{background:linear-gradient(160deg,var(--navy-deep),var(--navy));border-radius:var(--r-m);color:#E8EFF9;padding:1.5rem;box-shadow:var(--shadow-m)}
.joinbox h3{color:#fff;margin-bottom:.4rem}
.joinbox p{color:#C7D7EF;font-size:.98rem}
.joinbox .btn{width:100%}
.joinbox .alt{margin-top:.7rem;text-align:center;font-size:.92rem}
.joinbox .alt a{color:#fff}

.crit{display:grid;gap:var(--space-3)}
@media (min-width:760px){.crit{grid-template-columns:1fr 1fr}}
.crit-list{background:var(--card);border:1px solid var(--mist);border-radius:var(--r-m);padding:1.3rem 1.4rem}
.crit-list.yes{border-top:5px solid var(--ok)}
.crit-list.no{border-top:5px solid #C25050}
.crit-list h3{font-size:var(--fs-1)}
.crit-list ul{margin:0;padding:0;list-style:none;display:grid;gap:.6rem}
.crit-list li{display:flex;gap:.7rem;align-items:flex-start}
.crit-list .i{width:20px;height:20px;flex:none;margin-top:3px}
.crit-list.yes .i{color:var(--ok)}
.crit-list.no .i{color:#C25050}
.note-doc{background:var(--sky-tint);border-left:4px solid var(--sky);border-radius:var(--r-s);padding:.9rem 1.1rem;font-size:.95rem;color:var(--navy-ink)}

/* Locations inside study */
.loc-row{display:flex;gap:1rem;align-items:center;background:var(--card);border:1px solid var(--mist);border-radius:var(--r-m);padding:.9rem 1.1rem}
.loc-row .i{width:24px;height:24px;color:var(--sky);flex:none}
.loc-row b a{color:var(--navy-ink);text-decoration:none}
.loc-row b a:hover{color:var(--sky)}
.loc-row small{display:block;color:var(--ink-soft)}
.loc-row .btn{margin-left:auto}

/* ---------- Prose (WYSIWYG content) ---------- */
.prose{max-width:72ch}
.prose h2{font-size:var(--fs-3);margin-top:1.6em}
.prose h3{font-size:var(--fs-2);margin-top:1.4em}
.prose ul,.prose ol{padding-left:1.3rem;margin:0 0 1.1em}
.prose li{margin:.35em 0}
.prose img{border-radius:var(--r-m);margin-block:1.4em}
.prose blockquote{margin:1.4em 0;padding:1rem 1.3rem;background:var(--sky-tint);border-left:4px solid var(--sky);border-radius:var(--r-s);font-style:italic}
.prose table{width:100%;border-collapse:collapse;margin:1.4em 0}
.prose th,.prose td{border:1px solid var(--mist);padding:.6rem .8rem;text-align:left}
.prose th{background:var(--paper)}

/* Reviewed-by badge */
.reviewed{display:inline-flex;align-items:center;gap:.6rem;background:var(--card);border:1px solid var(--mist);border-radius:999px;padding:.45rem 1rem .45rem .6rem;font-size:.9rem;color:var(--ink-soft)}
.reviewed .i{width:26px;height:26px;color:var(--ok)}
.reviewed b{color:var(--navy-ink)}

/* ---------- FAQ accordion ---------- */
.faq{display:grid;gap:.8rem;max-width:840px}
.faq details{background:var(--card);border:1px solid var(--mist);border-radius:var(--r-m);padding:0;overflow:hidden}
.faq summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:.9rem;padding:1.1rem 1.3rem;font-weight:700;font-family:var(--font-display);font-size:var(--fs-1);color:var(--navy-ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";margin-left:auto;font-size:1.6rem;color:var(--sky);transition:transform .2s;line-height:1}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details[open]{border-color:var(--sky)}
.faq .a{padding:0 1.3rem 1.2rem;color:var(--ink-soft)}

/* ---------- Testimonials ---------- */
.quotes{display:grid;gap:var(--space-3)}
@media (min-width:900px){.quotes{grid-template-columns:repeat(3,1fr)}}
.quote{background:var(--card);border:1px solid var(--mist);border-radius:var(--r-m);padding:1.5rem;position:relative;box-shadow:var(--shadow-s)}
.quote::before{content:"\201C";position:absolute;top:-6px;left:14px;font-family:var(--font-display);font-size:4.6rem;color:var(--sky-soft);line-height:1}
.quote p{margin:0 0 .9rem;padding-top:1rem;color:var(--ink)}
.quote cite{font-style:normal;font-weight:700;color:var(--navy);display:flex;align-items:center;gap:.5rem}
.quote cite::before{content:"";width:22px;height:2px;background:var(--amber)}
.quotes-note{margin-top:var(--space-3);font-size:.9rem;color:var(--ink-soft);font-style:italic;text-align:center}

/* ---------- Partners ---------- */
.partners{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:2.2rem 3.2rem}
.partners img{height:44px;width:auto;filter:grayscale(1) brightness(.5) sepia(.2) hue-rotate(180deg) saturate(2);opacity:.75;transition:filter .2s,opacity .2s}
.partners img:hover{filter:none;opacity:1}
.partners .p-name{font-family:var(--font-display);font-weight:700;font-size:1.3rem;color:var(--ink-soft);opacity:.8}

/* ---------- Newsletter / community ---------- */
.community{background:linear-gradient(150deg,var(--navy-deep),var(--navy));border-radius:var(--r-l);color:#E8EFF9;padding:clamp(1.8rem,4vw,3.2rem);display:grid;gap:var(--space-3);box-shadow:var(--shadow-m);position:relative;overflow:hidden}
.community::after{content:"";position:absolute;right:-90px;top:-90px;width:280px;height:280px;border-radius:50%;border:2px dashed rgba(168,196,232,.35)}
@media (min-width:900px){.community{grid-template-columns:1.1fr .9fr;align-items:center}}
.community h2{color:#fff;font-size:var(--fs-4);margin-bottom:.3em}
.community p{color:#C7D7EF;margin:0}

/* ---------- Fluent Forms skin ---------- */
.ff-jas .frm-fluent-form,.ff-jas .fluentform{--ff-space:1.1rem}
.fluentform .ff-el-group{margin-bottom:1.15rem}
.fluentform .ff-el-input--label label{font-weight:700;color:var(--navy-ink);font-size:1rem}
.fluentform .ff-el-form-control{width:100%;min-height:52px;border:2px solid var(--mist);border-radius:var(--r-s);padding:.65rem 1rem;font:inherit;font-size:1.0625rem;background:#fff;color:var(--ink)}
.fluentform textarea.ff-el-form-control{min-height:120px}
.fluentform .ff-el-form-control:focus{outline:none;border-color:var(--sky);box-shadow:0 0 0 3px var(--sky-tint)}
.fluentform .ff-el-form-check{margin:.35rem 0}
.fluentform .ff-el-form-check label{display:flex;gap:.7rem;align-items:flex-start;font-weight:400;cursor:pointer}
.fluentform .ff-el-form-check-input{width:22px;height:22px;flex:none;margin-top:2px;accent-color:var(--navy)}
.fluentform .ff-btn-submit,.fluentform .ff-btn-next,.fluentform .ff-btn-prev{background:var(--amber)!important;color:var(--navy-deep)!important;border:none!important;border-radius:var(--r-s)!important;min-height:52px;padding:.8rem 1.7rem!important;font-weight:700!important;font-size:1.0625rem!important;box-shadow:0 3px 0 var(--amber-deep);cursor:pointer}
.fluentform .ff-btn-prev{background:transparent!important;color:var(--navy)!important;border:2px solid var(--navy)!important;box-shadow:none}
.fluentform .ff-step-header{margin-bottom:1.2rem}
.fluentform .ff-el-progress{height:10px;background:var(--mist);border-radius:999px;overflow:hidden}
.fluentform .ff-el-progress-bar{background:linear-gradient(90deg,var(--sky),var(--navy));border-radius:999px}
.fluentform .ff-el-progress-status{font-weight:700;color:var(--navy);margin-bottom:.4rem;font-size:.95rem}
.fluentform .ff-step-titles li{font-weight:700}
.fluentform .ff-step-titles li.ff_active{color:var(--navy)}
.fluentform .ff-el-is-error .ff-el-form-control{border-color:#C25050}
.fluentform .error,.fluentform .ff-errors-in-stack{color:#A33B3B;font-weight:700}
.fluentform .ff-message-success{background:#EAF6EF;border:1px solid var(--ok);border-radius:var(--r-m);padding:1.2rem 1.4rem;color:#14563A;font-weight:700}
.consent-panel{background:var(--paper);border:1px solid var(--mist);border-radius:var(--r-m);padding:1.1rem 1.2rem;font-size:.95rem}
.consent-panel .fine{color:var(--ink-soft);font-size:.88rem}

/* ---------- Footer ---------- */
.site-foot{background:var(--navy-deep);color:#B9CCE9;margin-top:var(--space-6)}
.foot-main{display:grid;gap:var(--space-4);padding-block:var(--space-5)}
@media (min-width:900px){.foot-main{grid-template-columns:1.3fr 1fr 1fr 1.2fr}}
.site-foot h4{color:#fff;font-size:1.05rem;letter-spacing:.06em;text-transform:uppercase;margin-bottom:1rem}
.site-foot ul{margin:0;padding:0;list-style:none;display:grid;gap:.55rem}
.site-foot a{color:#CFDDF3;text-decoration:none}
.site-foot a:hover{color:var(--amber)}
.foot-brand img{height:56px;width:auto;margin-bottom:1rem}
.foot-brand p{font-size:.95rem;max-width:34ch}
.foot-contact li{display:flex;gap:.6rem;align-items:flex-start}
.foot-contact .i{width:19px;height:19px;color:var(--sky-soft);flex:none;margin-top:4px}
.foot-legal{border-top:1px solid rgba(168,196,232,.22);padding-block:1.3rem;font-size:.88rem;display:flex;flex-wrap:wrap;gap:.8rem 2rem;justify-content:space-between;align-items:center}
.foot-legal .disc{max-width:56ch;color:#93AAD1}
.foot-legal nav{display:flex;flex-wrap:wrap;gap:1.2rem}

/* ---------- Motion ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s cubic-bezier(.2,.7,.3,1),transform .6s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
.hero [data-stagger]{opacity:0;transform:translateY(18px);animation:rise .7s cubic-bezier(.2,.7,.3,1) forwards}
@keyframes rise{to{opacity:1;transform:none}}
.hero [data-stagger="1"]{animation-delay:.05s}.hero [data-stagger="2"]{animation-delay:.16s}.hero [data-stagger="3"]{animation-delay:.27s}.hero [data-stagger="4"]{animation-delay:.38s}.hero [data-stagger="5"]{animation-delay:.52s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.hero [data-stagger]{animation:none;opacity:1;transform:none}.card-study:hover,.card-path:hover,.card-loc:hover,.card-art:hover{transform:none}}

/* ---------- Utilities ---------- */
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.stack-head{display:flex;flex-wrap:wrap;align-items:end;justify-content:space-between;gap:1rem;margin-bottom:var(--space-3)}
.stack-head .more{font-weight:700;white-space:nowrap}
.pagination{display:flex;gap:.4rem;justify-content:center;margin-top:var(--space-4)}
.pagination .page-numbers{display:inline-grid;place-items:center;min-width:46px;height:46px;padding:0 .6rem;border:2px solid var(--mist);border-radius:var(--r-s);text-decoration:none;font-weight:700;color:var(--navy)}
.pagination .page-numbers.current{background:var(--navy);color:#fff;border-color:var(--navy)}
.pagination a.page-numbers:hover{border-color:var(--sky)}
.visually-hidden{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
.map-embed{border:1px solid var(--mist);border-radius:var(--r-m);overflow:hidden}
.map-embed iframe{display:block;width:100%;height:340px;border:0}
.lang-switch{display:inline-flex;gap:.15rem;border:1px solid rgba(255,255,255,.35);border-radius:999px;padding:.1rem}
.lang-switch a,.lang-switch span{padding:.15rem .65rem;border-radius:999px;font-size:.85rem;font-weight:700;color:#fff;text-decoration:none}
.lang-switch .on{background:#fff;color:var(--navy-deep)}
.sr-skip-target:target{scroll-margin-top:100px}

/* ---------- QA fixes (2026-07) ---------- */
/* wp_nav_menu outputs <li> items; fallback markup used bare <a>. Neutralise list boxes/markers everywhere menus render. */
.nav ul,.nav li,.foot-legal nav ul,.foot-legal nav li{list-style:none;margin:0;padding:0;display:contents}
/* Default icon size — some contexts (e.g. .card-path .go) had none, letting SVGs blow up to intrinsic size. */
svg.i{width:20px;height:20px;flex:none}
/* .path-node is a <span>: without display:block, width/height/margin:auto don't apply and it renders as a stray inline blip. */
.path-node{display:block}
/* Fade the care-path rail out at its end instead of stopping abruptly above the footer. */
.pathline::before{background:linear-gradient(180deg,var(--sky-soft),var(--sky) 88%,transparent)}
