/* ============================================================
   WIZDOM / Gil Luxenbourg — Design System
   Single source of truth. Light theme = "Quiet Authority".
   Dark theme = "Modern Clinic". One component kit, two themes.
   Switch theme with <html data-theme="dark"> (or auto by OS).
   ============================================================ */

/* ---- 1. FONTS (loaded via <link> in each page head) ----
   Display : Fraunces        — editorial serif, the brand's voice
   Sans    : Hanken Grotesk  — UI + body, warm contemporary grotesk
   Mono    : DM Mono         — eyebrows, labels, data, "receipts"
*/

/* ---- 2. DESIGN TOKENS ---- */
:root{
  /* Light theme — Quiet Authority */
  --paper:#F7F4EE;          /* page background        */
  --surface:#FFFFFF;        /* cards, raised surfaces  */
  --surface-2:#F1ECE0;      /* sunken / alt sections   */
  --ink:#16140F;            /* primary text            */
  --mid:#544F45;            /* secondary text          */
  --faint:#8A8273;          /* tertiary text / hints   */
  --rule:#E3DDCF;           /* hairline borders        */
  --rule-strong:#D2C9B5;
  --brand:#1F3D32;          /* pine — primary brand     */
  --brand-deep:#16291F;     /* deepest pine            */
  --brand-tint:#EAEFEA;     /* pine wash               */
  --accent:#A8843E;         /* brass — fine accents     */
  --accent-soft:#EFE7D4;
  --clay:#9C5B43;           /* warm secondary (sparingly)*/
  --on-brand:#F7F4EE;       /* text on pine            */
  --shadow:0 6px 24px rgba(22,20,15,.07);
  --shadow-sm:0 2px 10px rgba(22,20,15,.05);

  /* Type families */
  --font-display:'Fraunces',Georgia,serif;
  --font-sans:'Hanken Grotesk','Inter',system-ui,sans-serif;
  --font-mono:'DM Mono','SFMono-Regular',monospace;

  /* Type scale (fluid) */
  --t-display:clamp(2.6rem,1.6rem + 4vw,4.4rem);
  --t-h1:clamp(2.2rem,1.5rem + 2.8vw,3.4rem);
  --t-h2:clamp(1.7rem,1.3rem + 1.6vw,2.4rem);
  --t-h3:1.35rem;
  --t-lead:clamp(1.05rem,1rem + .4vw,1.25rem);
  --t-body:1.0625rem;     /* 17px */
  --t-small:.92rem;
  --t-eyebrow:.72rem;

  /* Spacing scale */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px;
  --s-6:32px; --s-7:48px; --s-8:64px; --s-9:96px; --s-10:128px;

  /* Layout */
  --wrap:1080px;          /* default container        */
  --wrap-narrow:720px;    /* prose / reading width    */
  --wrap-wide:1280px;
  --radius:6px;
  --radius-lg:12px;
  --radius-pill:999px;
  --section:clamp(56px,8vw,112px); /* vertical section rhythm */

  --ease:cubic-bezier(.2,.7,.2,1);
}

/* Dark theme — Modern Clinic */
:root[data-theme="dark"]{
  --paper:#14241C;
  --surface:#1B2E25;
  --surface-2:#101D17;
  --ink:#EFE9DC;
  --mid:#BCCABF;
  --faint:#8AA093;
  --rule:#2A4034;
  --rule-strong:#38503F;
  --brand:#7FA38B;          /* sage — brand reads light on dark */
  --brand-deep:#0E1A14;
  --brand-tint:#1B2E25;
  --accent:#D49A3A;         /* honey accent             */
  --accent-soft:#26352B;
  --clay:#C97A52;
  --on-brand:#0E1A14;
  --shadow:0 10px 30px rgba(0,0,0,.35);
  --shadow-sm:0 3px 12px rgba(0,0,0,.25);
}

/* Default is the LIGHT theme (most legible for a 35+/elder audience).
   Dark mode applies only when the reader opts in via the toggle. */

/* ---- 3. BASE ---- */
*{box-sizing:border-box;margin:0;padding:0}
/* Base size tuned up for readability. Reader can adjust with A- / A / A+. */
html{scroll-behavior:smooth;font-size:112.5%}      /* default ~18px */
html[data-fontscale="sm"]{font-size:100%}           /* 16px */
html[data-fontscale="md"]{font-size:112.5%}         /* 18px */
html[data-fontscale="lg"]{font-size:125%}           /* 20px */
html[data-fontscale="xl"]{font-size:140%}           /* ~22px */
body{
  font-family:var(--font-sans);
  background:var(--paper);color:var(--ink);
  font-size:var(--t-body);line-height:1.75;
  -webkit-font-smoothing:antialiased;
  transition:background .4s var(--ease),color .4s var(--ease);
}
img{max-width:100%;display:block}
::selection{background:var(--accent);color:var(--on-brand)}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:1.08;letter-spacing:-.015em;color:var(--ink)}
h1{font-size:var(--t-h1);margin-bottom:var(--s-4)}
h2{font-size:var(--t-h2);margin-bottom:var(--s-4)}
h3{font-size:var(--t-h3);margin-bottom:var(--s-2);letter-spacing:-.01em}
p{margin-bottom:var(--s-4);color:var(--mid)}
strong{color:var(--ink);font-weight:600}
em{font-style:italic}
a{color:var(--brand);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--accent)}
small{font-size:var(--t-small)}

/* ---- 4. LAYOUT ---- */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--s-5)}
.wrap-narrow{max-width:var(--wrap-narrow);margin:0 auto;padding:0 var(--s-5)}
.wrap-wide{max-width:var(--wrap-wide);margin:0 auto;padding:0 var(--s-5)}
.section{padding:var(--section) 0}
.section--alt{background:var(--surface-2)}
.section--brand{background:var(--brand-deep);color:#EDE7DA}
.section--brand h1,.section--brand h2,.section--brand h3{color:#F7F4EE}
.section--brand p{color:rgba(247,244,238,.80)}
.divider{height:1px;background:var(--rule);border:0}

/* ---- 5. ATOMS ---- */
.eyebrow{
  font-family:var(--font-mono);font-size:var(--t-eyebrow);
  letter-spacing:.22em;text-transform:uppercase;color:var(--accent);
  display:inline-block;margin-bottom:var(--s-4);font-weight:500;
}
.lead{font-size:var(--t-lead);color:var(--ink);font-family:var(--font-display);
  font-style:italic;line-height:1.45;font-weight:400}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-sans);font-weight:600;font-size:.95rem;
  letter-spacing:.01em;padding:13px 26px;border-radius:var(--radius);
  cursor:pointer;border:1px solid transparent;transition:all .2s var(--ease);
}
.btn--primary{background:var(--brand);color:var(--on-brand)}
.btn--primary:hover{background:var(--brand-deep);color:var(--on-brand);transform:translateY(-1px)}
:root[data-theme="dark"] .btn--primary{background:var(--accent);color:var(--brand-deep)}
.btn--ghost{background:transparent;color:var(--brand);border-color:var(--brand)}
.btn--ghost:hover{background:var(--brand);color:var(--on-brand)}
.btn--accent{background:var(--accent);color:var(--brand-deep)}
.btn--accent:hover{filter:brightness(1.05);transform:translateY(-1px)}
.btn--lg{padding:16px 32px;font-size:1.02rem}

/* Tag / pill */
.tag{display:inline-block;font-family:var(--font-mono);font-size:.7rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.pill{display:inline-block;font-family:var(--font-mono);font-size:.74rem;
  letter-spacing:.12em;text-transform:uppercase;color:var(--mid);
  padding:6px 14px;border:1px solid var(--rule);border-radius:var(--radius-pill)}

/* ---- 6. HEADER / NAV ---- */
.site-header{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--paper) 88%,transparent);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--rule)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:var(--s-5);padding-top:var(--s-4);padding-bottom:var(--s-4);max-width:var(--wrap-wide)}
.brandmark{font-family:var(--font-display);font-size:1.3rem;font-weight:600;letter-spacing:.01em;color:var(--ink);display:inline-flex;align-items:center;gap:8px}
.brandmark .mark{color:var(--accent);font-size:.7em}
.nav{display:flex;align-items:center;gap:var(--s-6);font-size:.93rem}
.nav a{color:var(--mid);font-weight:500}
.nav a:hover{color:var(--ink)}
.nav .btn{padding:9px 18px;font-size:.88rem}
.theme-toggle{background:none;border:1px solid var(--rule);color:var(--mid);
  width:38px;height:38px;border-radius:var(--radius-pill);cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;font-size:1.05rem;transition:all .2s var(--ease)}
.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}
/* Signature logotype */
.brand-signature{font-family:'Mr Dafoe',cursive;font-size:2rem;line-height:.9;color:var(--ink);display:inline-flex;align-items:flex-end;gap:10px}
.brand-signature .desc{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);padding-bottom:7px}
/* Accessibility text-size control */
.fontscale{display:inline-flex;align-items:center;border:1px solid var(--rule);border-radius:var(--radius-pill);overflow:hidden}
.fontscale button{background:none;border:0;cursor:pointer;color:var(--mid);font-family:var(--font-sans);font-weight:600;padding:6px 11px;line-height:1;transition:all .15s var(--ease)}
.fontscale button:hover{color:var(--accent)}
.fontscale button[aria-pressed="true"]{background:var(--accent);color:var(--on-brand)}
.fontscale .a1{font-size:.78rem}.fontscale .a2{font-size:.92rem}.fontscale .a3{font-size:1.06rem}
.skip-link{position:absolute;left:-999px;top:0;background:var(--accent);color:var(--on-brand);padding:10px 16px;border-radius:0 0 var(--radius) 0;z-index:200}
.skip-link:focus{left:0}

/* ---- 7. HERO ---- */
.hero{padding:var(--section) 0;position:relative;overflow:hidden}
.hero--brand{background:var(--brand-deep);color:#EDE7DA}
.hero--brand h1,.hero--brand .lead{color:#F7F4EE}
.hero--brand .eyebrow{color:var(--accent)}
/* Pills sit on dark bands too — keep them legible (default .pill is dark-on-light) */
.hero--brand .pill,.cta .pill,.section--brand .pill{color:#F7F4EE;border-color:rgba(247,244,238,.42)}
.hero-grid{display:grid;grid-template-columns:1.35fr .9fr;gap:var(--s-8);align-items:center}
.hero h1{font-size:var(--t-display);letter-spacing:-.025em}
.hero h1 em{color:var(--brand);font-style:italic}
.hero--brand h1 em{color:var(--accent)}
.hero .lead{max-width:46ch;margin-bottom:var(--s-5)}
.hero-ctas{display:flex;gap:var(--s-3);flex-wrap:wrap;margin-top:var(--s-5)}
.hero-photo{aspect-ratio:4/5;background:var(--surface-2) center/cover no-repeat;
  border-radius:var(--radius-lg);border:1px solid var(--rule);box-shadow:var(--shadow)}

/* ---- 8. STAT / CREDS STRIP ---- */
.stat-strip{border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);background:var(--surface)}
.stat-strip .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-5);padding:var(--s-6) var(--s-5);max-width:var(--wrap-wide)}
.stat{display:flex;flex-direction:column;gap:4px}
.stat .num{font-family:var(--font-display);font-size:1.9rem;color:var(--ink);line-height:1}
.stat .lab{font-size:.82rem;color:var(--faint);letter-spacing:.02em}

/* ---- 9. PATH TILES (find your path) ---- */
.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-4)}
.tile{background:var(--surface);border:1px solid var(--rule);border-radius:var(--radius-lg);
  padding:var(--s-6) var(--s-5);display:flex;flex-direction:column;color:inherit;transition:all .25s var(--ease)}
.tile:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:var(--shadow);color:inherit}
.tile .tag{margin-bottom:var(--s-3)}
.tile h3{color:var(--ink);margin-bottom:var(--s-3)}
.tile p{font-size:.95rem;flex:1;margin-bottom:var(--s-4)}
.tile .tile-cta{font-size:.88rem;color:var(--brand);font-weight:600}
.tile--featured{border-color:var(--accent);background:var(--accent-soft)}
:root[data-theme="dark"] .tile--featured{background:var(--accent-soft)}

/* ---- 10. PROSE / STORY ---- */
.prose{max-width:var(--wrap-narrow);margin:0 auto}
.prose p{font-size:1.12rem;line-height:1.8}
.prose h2{margin-top:var(--s-7)}
.pull{font-family:var(--font-display);font-size:clamp(1.4rem,1.1rem + 1vw,1.9rem);
  font-style:italic;color:var(--brand);line-height:1.35;
  border-left:3px solid var(--accent);padding:var(--s-2) 0 var(--s-2) var(--s-5);margin:var(--s-7) 0}
:root[data-theme="dark"] .pull{color:var(--accent)}

/* ---- 11. TIMELINE / MILESTONE CARDS ---- */
.cards-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s-5)}
.card{background:var(--surface);border:1px solid var(--rule);border-radius:var(--radius-lg);padding:var(--s-6)}
.card .year{font-family:var(--font-mono);font-size:.82rem;color:var(--accent);letter-spacing:.12em;margin-bottom:var(--s-2)}
.card h3{margin-bottom:var(--s-2)}
.card p{font-size:.97rem;margin-bottom:0}

/* ---- 12. CTA BAND ---- */
.cta{background:var(--brand-deep);color:#EDE7DA;text-align:center;padding:var(--section) 0}
.cta h2{color:#F7F4EE;max-width:18ch;margin:0 auto var(--s-4)}
.cta p{color:rgba(247,244,238,.8);max-width:48ch;margin:0 auto var(--s-6);font-size:var(--t-lead)}

/* ---- 13. FAQ ACCORDION ---- */
.faq{max-width:var(--wrap-narrow);margin:0 auto}
.faq details{border-bottom:1px solid var(--rule);padding:var(--s-5) 0}
.faq summary{font-family:var(--font-display);font-size:1.2rem;color:var(--ink);cursor:pointer;
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:var(--s-4)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--font-sans);color:var(--accent);font-size:1.4rem;transition:transform .2s}
.faq details[open] summary::after{content:"–"}
.faq details[open] summary{margin-bottom:var(--s-3)}
.faq p{margin-bottom:0}

/* ---- 14. BLOG ---- */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-5)}
.post-card{background:var(--surface);border:1px solid var(--rule);border-radius:var(--radius-lg);overflow:hidden;
  display:flex;flex-direction:column;transition:all .25s var(--ease);color:inherit}
.post-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);color:inherit}
.post-card .thumb{aspect-ratio:16/9;background:var(--surface-2)}
.post-card .body{padding:var(--s-5);display:flex;flex-direction:column;flex:1}
.post-card .meta{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:var(--s-3)}
.post-card h3{color:var(--ink);font-size:1.25rem;margin-bottom:var(--s-3)}
.post-card p{font-size:.95rem;flex:1}
.article{max-width:var(--wrap-narrow);margin:0 auto}
.article .lead{font-style:italic;margin-bottom:var(--s-6)}
.article p,.article li{font-size:1.12rem;line-height:1.85;color:var(--mid)}
.article h2{margin:var(--s-7) 0 var(--s-3)}
.article img{border-radius:var(--radius-lg);margin:var(--s-6) 0}

/* ---- 15. FORMS ---- */
.field{margin-bottom:var(--s-5)}
.field label{display:block;font-size:.9rem;font-weight:600;color:var(--ink);margin-bottom:var(--s-2)}
.field input,.field textarea,.field select{
  width:100%;padding:13px 16px;font-family:var(--font-sans);font-size:1rem;
  background:var(--surface);color:var(--ink);border:1px solid var(--rule-strong);border-radius:var(--radius);transition:border .2s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}

/* ---- 16. FOOTER ---- */
.site-footer{background:var(--surface-2);border-top:1px solid var(--rule);padding:var(--s-8) 0 var(--s-7)}
.site-footer .wrap{max-width:var(--wrap-wide)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:var(--s-6);margin-bottom:var(--s-7)}
.footer-grid h4{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);font-weight:500;margin-bottom:var(--s-4)}
.footer-grid a{display:block;color:var(--mid);font-size:.92rem;margin-bottom:var(--s-3)}
.footer-grid a:hover{color:var(--accent)}
.footer-base{border-top:1px solid var(--rule);padding-top:var(--s-5);display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--s-3);font-size:.82rem;color:var(--faint)}

/* ---- 17. UTILITIES ---- */
.center{text-align:center}
.muted{color:var(--mid)}
.mx-auto{margin-left:auto;margin-right:auto}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.maxw-prose{max-width:58ch}
.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---- 18. RESPONSIVE ---- */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:var(--s-6)}
  .hero-photo{max-width:340px;order:-1}
  .tiles,.post-grid{grid-template-columns:repeat(2,1fr)}
  .stat-strip .wrap{grid-template-columns:repeat(2,1fr);gap:var(--s-5)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .tiles,.post-grid,.cards-2{grid-template-columns:1fr}
  .nav{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
}
                                                