/* Neurodivergent Me — dark, calm, accessible.
   Brief: dark backgrounds + soft colourful gradients, large readable text,
   high contrast, minimal motion, no busy patterns. Accessibility is the design,
   not a bolt-on. Lexend + Atkinson Hyperlegible. */
:root{
  --bg:#0a1330;          /* deep navy — matches her logo badge */
  --bg-2:#0f1a3e;
  --surface:#19224a;     /* cards */
  --surface-2:#212c5c;
  --line:rgba(173,188,255,.16);
  --text:#eef1fb;        /* near-white, high contrast on dark */
  --text-soft:#b9c4e8;   /* muted but ≥4.5:1 on --bg */
  --teal:#36c9c0; --blue:#4a7dff; --violet:#9d6bff; --pink:#ff7ab0; --orange:#ff9d4d; --gold:#ffb24d;
  --brand:#7b8cff; --accent:#ff9d4d;
  --focus:#9fd0ff;
  /* Her brand: vibrant gradient — blue, teal, purple, pink, orange */
  --grad:linear-gradient(120deg,#36c9c0,#4a7dff 26%,#9d6bff 52%,#ff7ab0 76%,#ff9d4d);
  --grad-soft:linear-gradient(135deg,rgba(54,201,192,.16),rgba(74,125,255,.16) 30%,rgba(157,107,255,.16) 55%,rgba(255,122,176,.15) 80%,rgba(255,157,77,.14));
  --r:14px; --r-lg:22px; --maxw:1140px; --measure:64ch;
  --shadow:0 24px 60px -30px rgba(0,0,0,.7);
  --font-head:'Lexend',system-ui,sans-serif;
  --font-body:'Atkinson Hyperlegible','Lexend',system-ui,-apple-system,Segoe UI,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}}
body{margin:0;font-family:var(--font-body);color:var(--text);background:var(--bg);
  font-size:1.15rem;line-height:1.75;-webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(60rem 40rem at 85% -10%,rgba(74,125,255,.20),transparent 60%),
    radial-gradient(50rem 40rem at -10% 10%,rgba(54,201,192,.16),transparent 55%),
    radial-gradient(46rem 40rem at 95% 60%,rgba(255,122,176,.12),transparent 55%),
    radial-gradient(50rem 50rem at 50% 120%,rgba(157,107,255,.14),transparent 60%);
  background-attachment:fixed}
img,svg{max-width:100%;display:block}
a{color:#a9b6ff;text-underline-offset:.18em}
a:hover{color:#c7d0ff}
:focus-visible{outline:3px solid var(--focus);outline-offset:3px;border-radius:6px}
h1,h2,h3,h4{font-family:var(--font-head);line-height:1.2;color:#fff;margin:0 0 .5em;font-weight:600;letter-spacing:-.01em}
h1{font-size:clamp(2.3rem,1.5rem+3.4vw,3.7rem)}
h2{font-size:clamp(1.8rem,1.3rem+1.8vw,2.5rem)}
h3{font-size:1.4rem}
p{margin:0 0 1.1em;max-width:var(--measure)}
.wrap{width:min(100% - 2.4rem,var(--maxw));margin-inline:auto}
.muted{color:var(--text-soft)}
.small{font-size:.95rem}
.skip{position:absolute;left:-9999px;top:0;background:var(--surface);color:#fff;padding:.7rem 1.1rem;border-radius:0 0 8px 0;z-index:200}
.skip:focus{left:0}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* buttons — large tap targets, strong contrast */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-head);font-weight:600;font-size:1.02rem;
  background:var(--grad);color:#10142b;border:0;border-radius:999px;
  padding:.85em 1.7em;text-decoration:none;cursor:pointer;transition:transform .2s,filter .2s;box-shadow:0 10px 30px -12px rgba(123,140,255,.6)}
.btn:hover{transform:translateY(-2px);filter:brightness(1.06);color:#10142b}
.btn--ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.34);box-shadow:none}
.btn--ghost:hover{background:rgba(255,255,255,.08);color:#fff}
.btn--small{padding:.55em 1.1em;font-size:.95rem}

/* header / nav */
.site-head{position:sticky;top:0;z-index:100;background:rgba(14,20,48,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.site-head__inner{display:flex;align-items:center;gap:1rem;padding:.7rem 0;flex-wrap:wrap}
.brand{display:inline-flex;align-items:center;gap:.6rem;text-decoration:none;color:#fff}
.brand__mark{display:inline-flex}
.brand__name{font-family:var(--font-head);font-weight:700;font-size:1.2rem}
.nav{display:flex;align-items:center;gap:.2rem;margin-left:auto;flex-wrap:wrap}
.nav a{font-family:var(--font-head);font-weight:500;color:var(--text-soft);text-decoration:none;padding:.55em .85em;border-radius:9px}
.nav a:hover{color:#fff;background:rgba(255,255,255,.07)}
.nav a[aria-current=page]{color:#fff;box-shadow:inset 0 -2px 0 var(--accent)}
.nav__cta{background:var(--grad)!important;color:#10142b!important;border-radius:999px;padding:.55em 1.2em!important;font-weight:600}
.nav__cta:hover{filter:brightness(1.05)}
.nav-toggle{display:none;margin-left:auto;flex-direction:column;gap:5px;background:none;border:0;padding:8px;cursor:pointer}
.nav-toggle span{width:26px;height:3px;background:#fff;border-radius:3px}
@media (max-width:880px){
  .nav-toggle{display:flex}
  .nav{display:none;flex-direction:column;align-items:stretch;width:100%;margin-top:.5rem;gap:.2rem}
  .nav.open{display:flex}.nav a{padding:.85em 1em}.nav__cta{text-align:center}
}

/* sections */
.section{padding:clamp(3.2rem,6vw,5.8rem) 0}
.section--soft{background:var(--bg-2)}
.section--panel{background:linear-gradient(180deg,var(--bg-2),var(--bg))}
.eyebrow{display:inline-block;font-family:var(--font-head);font-weight:600;font-size:.82rem;letter-spacing:.13em;
  text-transform:uppercase;color:#10142b;background:var(--grad);padding:.4em .9em;border-radius:999px;margin-bottom:1.1rem}
.lede{font-size:1.3rem;color:var(--text-soft);max-width:58ch}
.section__head{max-width:62ch;margin-bottom:2.6rem}
.center{text-align:center;margin-inline:auto}.center p{margin-inline:auto}

/* hero — her brand gradient banner with a dark scrim so white text stays high-contrast */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line);
  background-image:linear-gradient(90deg,rgba(8,12,32,.94),rgba(8,12,32,.6) 46%,rgba(8,12,32,.22)),url('/static/img/hero-banner.png');
  background-size:cover;background-position:center}
.hero__inner{position:relative;padding:clamp(3.8rem,9vw,7rem) 0;max-width:44rem}
.hero h1{font-size:clamp(2.5rem,1.6rem+4vw,4.2rem)}
.hero__lede{font-size:1.35rem;color:var(--text-soft);max-width:40ch}
.hero__cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:2rem}
.hero__infinity{position:absolute;right:-30px;bottom:-20px;width:min(46%,380px);opacity:.5}

/* grids / cards */
.grid{display:grid;gap:1.4rem}
.grid--3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.8rem;box-shadow:var(--shadow)}
.card h3{margin-bottom:.4rem;color:#fff}
.card p{margin-bottom:0;color:var(--text-soft)}
.card__icon{width:50px;height:50px;display:grid;place-items:center;border-radius:14px;background:var(--grad-soft);color:#fff;margin-bottom:1rem;border:1px solid var(--line)}
.card__icon svg{width:26px;height:26px}

/* split */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:center}
@media (max-width:820px){.split{grid-template-columns:1fr}}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.7rem,4vw,2.7rem);box-shadow:var(--shadow)}
.panel--grad{background:var(--grad-soft);border-color:rgba(189,123,255,.3)}

.prose{max-width:var(--measure)}
.prose p{font-size:1.18rem;color:var(--text-soft)}
.prose strong{color:#fff}

/* service list */
.services{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.8rem;list-style:none;padding:0;margin:0}
.services li{display:flex;align-items:flex-start;gap:.7rem;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:.9rem 1.1rem;color:var(--text)}
.services li::before{content:"";flex:none;width:1.4rem;height:1.4rem;margin-top:.15rem;border-radius:6px;background:var(--grad)}
.services li .soon{display:block;font-size:.82rem;color:var(--gold);font-family:var(--font-head);font-weight:600}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:.6rem;list-style:none;padding:0;margin:1.4rem 0 0}
.chips li{background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:.5em 1.05em;font-weight:500;color:#fff}

/* admired orgs */
.orgs{display:flex;flex-wrap:wrap;gap:.7rem;list-style:none;padding:0;margin:1.2rem 0 0}
.orgs li{background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:.55em 1em;color:var(--text-soft);font-size:.98rem}

/* article cards */
.articles{display:grid;gap:1.4rem;grid-template-columns:repeat(auto-fill,minmax(290px,1fr))}
.article-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.article-card img{width:100%;aspect-ratio:16/9;object-fit:cover}
.article-card__body{padding:1.4rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.article-card__date{font-size:.88rem;color:var(--text-soft)}
.article-card h3{margin:0;color:#fff}
.article-card a.more{margin-top:auto;font-family:var(--font-head);font-weight:600;text-decoration:none;color:#a9b6ff}

/* join / cta */
.cta{position:relative;overflow:hidden;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(2.2rem,5vw,3.6rem);text-align:center}
.cta::before{content:"";position:absolute;inset:0;background:var(--grad-soft);pointer-events:none}
.cta>*{position:relative}
.cta h2{color:#fff}.cta p{color:var(--text-soft);margin-inline:auto}

/* forms */
.field{margin-bottom:1.1rem}
.field label{display:block;font-family:var(--font-head);font-weight:600;margin-bottom:.4rem;color:#fff}
.field input,.field textarea,.field select{width:100%;font:inherit;font-size:1.05rem;color:#fff;background:var(--bg);
  border:2px solid var(--line);border-radius:12px;padding:.75em .95em}
.field input::placeholder,.field textarea::placeholder{color:#8b97c4}
.field input:focus,.field textarea:focus{border-color:var(--brand);outline:none}
.field textarea{min-height:9rem;resize:vertical}
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(1.6rem,4vw,3rem);align-items:start}
@media (max-width:820px){.contact-grid{grid-template-columns:1fr}}
.info-list{list-style:none;padding:0;margin:0}
.info-list li{padding:.95rem 0;border-bottom:1px solid var(--line);color:var(--text-soft)}
.info-list strong{display:block;font-family:var(--font-head);color:#fff}

/* flash */
.flash{margin:1rem 0;padding:.95rem 1.1rem;border-radius:12px;font-weight:500;border:1px solid var(--line)}
.flash--success{background:rgba(58,208,192,.15);color:#baf1e9}
.flash--error{background:rgba(255,143,182,.14);color:#ffc6d8}

/* footer */
.site-foot{background:var(--bg-2);color:var(--text-soft);margin-top:2rem;border-top:1px solid var(--line)}
.site-foot__inner{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2rem;padding:clamp(2.4rem,5vw,3.6rem) 0 1.6rem}
@media (max-width:760px){.site-foot__inner{grid-template-columns:1fr 1fr}}
.site-foot .brand__name{color:#fff}
.site-foot h2{font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;color:#8b97c4}
.site-foot a{display:block;color:var(--text-soft);text-decoration:none;padding:.28rem 0}
.site-foot a:hover{color:#fff;text-decoration:underline}
.site-foot__base{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;border-top:1px solid var(--line);padding:1.2rem 0;margin-top:1rem}
.socials{display:flex;gap:1rem}.socials a{color:#8b97c4}

/* cookie banner — quiet bottom bar, never a blocking pop-up */
.cookie{position:fixed;left:1rem;right:1rem;bottom:1rem;max-width:560px;margin-inline:auto;background:var(--surface);color:#fff;
  border:1px solid var(--line);border-radius:14px;padding:.9rem 1.1rem;display:flex;gap:1rem;align-items:center;box-shadow:var(--shadow);z-index:170}
.cookie[hidden]{display:none}   /* author display:flex was overriding the hidden attribute — this restores it */
.cookie p{margin:0;font-size:.95rem}.cookie a{color:var(--accent)}
.cookie .btn{flex:none}
/* keep the banner clear of the accessibility button (bottom-right) on narrow screens */
@media (max-width:680px){.cookie{bottom:5.4rem}}

/* admin */
.admin{max-width:880px;margin:2rem auto;padding:0 1.2rem}
.admin h1{font-size:1.7rem}
.admin-nav{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.6rem}
.admin-nav a{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:.5em .9em;text-decoration:none;font-weight:500;color:var(--text)}
.admin-nav a:hover{background:var(--surface-2)}
.admin-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:1.4rem;margin-bottom:1.2rem}
.admin table{width:100%;border-collapse:collapse}
.admin th,.admin td{text-align:left;padding:.6rem;border-bottom:1px solid var(--line);vertical-align:top}

/* ================= ACCESSIBILITY MODES (user-controlled) ================= */
/* Text size — scales rem-based type site-wide */
html{font-size:100%}
html[data-textsize="lg"]{font-size:112%}
html[data-textsize="xl"]{font-size:125%}
html[data-textsize="xxl"]{font-size:140%}

/* Light mode — calm warm light, never harsh white */
html[data-theme="light"]{
  --bg:#ecebf4; --bg-2:#e3e2ef; --surface:#ffffff; --surface-2:#f3f2fa;
  --line:rgba(40,52,110,.16); --text:#1b2147; --text-soft:#46517a;
  --shadow:0 22px 50px -32px rgba(40,52,110,.35);
}
html[data-theme="light"] body{
  background:var(--bg);
  background-image:
    radial-gradient(60rem 40rem at 90% -10%,rgba(123,140,255,.14),transparent 60%),
    radial-gradient(50rem 40rem at -10% 10%,rgba(58,208,192,.12),transparent 55%);
}
html[data-theme="light"] h1,html[data-theme="light"] h2,html[data-theme="light"] h3,html[data-theme="light"] h4,
html[data-theme="light"] .card h3,html[data-theme="light"] .article-card h3,html[data-theme="light"] .field label,
html[data-theme="light"] .info-list strong,html[data-theme="light"] .chips li,html[data-theme="light"] .site-foot .brand__name{color:#1b2147}
html[data-theme="light"] a{color:#3a49c4}
html[data-theme="light"] .nav a{color:#46517a}
html[data-theme="light"] .nav a:hover{background:rgba(40,52,110,.08);color:#1b2147}

/* High contrast */
html[data-contrast="high"]{--text:#fff;--text-soft:#fff;--line:rgba(255,255,255,.55)}
html[data-contrast="high"][data-theme="light"]{--text:#000;--text-soft:#000;--line:rgba(0,0,0,.6)}
html[data-contrast="high"] .muted,html[data-contrast="high"] .prose p,html[data-contrast="high"] .card p{color:var(--text)}
html[data-contrast="high"] a{text-decoration:underline}
html[data-contrast="high"] .card,html[data-contrast="high"] .panel,html[data-contrast="high"] .services li,html[data-contrast="high"] .field input,html[data-contrast="high"] .field textarea{border-width:2px}
html[data-contrast="high"] .eyebrow,html[data-contrast="high"] .btn{background:var(--text)!important;color:var(--bg)!important}
html[data-contrast="high"] .grad-text{-webkit-text-fill-color:currentColor;color:var(--text)}

/* Dyslexia-friendly font + spacing */
html[data-font="dyslexic"]{
  --font-body:'OpenDyslexic','Comic Sans MS','Atkinson Hyperlegible',sans-serif;
  --font-head:'OpenDyslexic','Comic Sans MS','Lexend',sans-serif;
}
html[data-font="dyslexic"] body{letter-spacing:.03em;word-spacing:.14em;line-height:1.9}
html[data-font="dyslexic"] p{max-width:60ch}
@font-face{font-family:'OpenDyslexic';font-display:swap;src:local('OpenDyslexic'),
  url('https://cdn.jsdelivr.net/gh/antijingoist/opendyslexic@master/compiled/OpenDyslexic-Regular.woff2') format('woff2')}

/* Reduced motion (user toggle, on top of prefers-reduced-motion) */
html[data-motion="off"] *{animation:none!important;transition:none!important;scroll-behavior:auto!important}

/* Colour overlay (Irlen-style tint) */
#a11yOverlay{position:fixed;inset:0;pointer-events:none;z-index:140;opacity:0;transition:opacity .2s,background .2s}
html[data-overlay="cream"] #a11yOverlay{opacity:.18;background:#f6e7c4}
html[data-overlay="peach"] #a11yOverlay{opacity:.2;background:#ffcaa3}
html[data-overlay="blue"]  #a11yOverlay{opacity:.2;background:#9fc2f0}
html[data-overlay="green"] #a11yOverlay{opacity:.2;background:#a9e0b4}
html[data-overlay="rose"]  #a11yOverlay{opacity:.2;background:#f3b9d6}
html[data-overlay="grey"]  #a11yOverlay{opacity:.26;background:#9aa0ad}

/* Reading focus ruler */
#a11yRulerTop,#a11yRulerBot{position:fixed;left:0;right:0;background:rgba(6,9,24,.62);pointer-events:none;z-index:135;display:none}
html[data-ruler="on"] #a11yRulerTop,html[data-ruler="on"] #a11yRulerBot{display:block}
html[data-theme="light"] #a11yRulerTop,html[data-theme="light"] #a11yRulerBot{background:rgba(20,24,60,.32)}

/* Toolbar */
.a11y-fab{position:fixed;right:1rem;bottom:1rem;z-index:160;display:inline-flex;align-items:center;gap:.5rem;
  background:var(--grad);color:#10142b;border:0;border-radius:999px;padding:.7em 1.1em;font-family:var(--font-head);font-weight:700;
  cursor:pointer;box-shadow:0 12px 30px -10px rgba(0,0,0,.6)}
.a11y-fab svg{width:22px;height:22px}
.a11y-panel{position:fixed;right:1rem;bottom:4.6rem;z-index:161;width:min(360px,calc(100vw - 2rem));max-height:80vh;overflow:auto;
  background:var(--surface);color:var(--text);border:1px solid var(--line);border-radius:18px;padding:1.2rem;box-shadow:var(--shadow);display:none}
.a11y-panel[aria-hidden="false"]{display:block}
.a11y-panel h2{font-size:1.2rem;margin:0 0 .2rem}
.a11y-grp{margin:1rem 0 0}.a11y-grp h3{font-size:.95rem;margin:0 0 .5rem}
.a11y-opts{display:flex;flex-wrap:wrap;gap:.4rem}
.a11y-opts button{font:inherit;font-size:.92rem;font-family:var(--font-head);background:var(--bg);color:var(--text);
  border:2px solid var(--line);border-radius:10px;padding:.45em .8em;cursor:pointer}
.a11y-opts button[aria-pressed="true"]{background:var(--grad);color:#10142b;border-color:transparent}
.a11y-swatch{width:34px;height:34px;border-radius:8px;border:2px solid var(--line);cursor:pointer;padding:0}
.a11y-swatch[aria-pressed="true"]{outline:3px solid var(--focus)}
.a11y-reset{margin-top:1.1rem;width:100%;background:transparent;color:var(--text);border:2px solid var(--line);border-radius:10px;padding:.6em;font-family:var(--font-head);font-weight:600;cursor:pointer}

/* Real logo */
.brand__logo{height:42px;width:auto;display:block;border-radius:50%}
.hero__logo{position:absolute;right:-10px;bottom:-10px;width:min(40%,300px);opacity:.92;filter:drop-shadow(0 16px 40px rgba(0,0,0,.5))}
@media (max-width:760px){.hero__logo{opacity:.4;width:55%}}

/* Gentle, dyslexia-friendly reveal animations (added via JS so no-JS shows everything).
   No movement when reduced-motion is preferred or the user turns motion off. */
/* Only hidden when 'anim' is set (added pre-paint only if motion is allowed),
   so no-JS / reduced-motion / motion-off users always see everything. */
.anim .reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .65s cubic-bezier(.22,.61,.36,1)}
.anim .reveal.in{opacity:1;transform:none}
html[data-motion="off"] .reveal{opacity:1!important;transform:none!important;transition:none!important}

/* Welcome feature graphic */
.welcome-img{width:100%;border-radius:var(--r-lg);border:1px solid var(--line);box-shadow:var(--shadow);display:block}
