/* ===== Yin & Yang Method homepage — warm editorial wellness =====
   Rules live in DESIGN.md. Self-hosted fonts (GDPR-clean, no Google CDN). */

@font-face{
  font-family:'Fraunces';
  src:url('fonts/Fraunces.ttf') format('truetype');
  font-weight:300 700; font-display:swap; font-style:normal;
}
@font-face{
  font-family:'Nunito Sans';
  src:url('fonts/NunitoSans.ttf') format('truetype');
  font-weight:300 800; font-display:swap; font-style:normal;
}

:root{
  --paper:#FBF8F2;
  --sand:#F4ECDD;
  --ink:#2E2A24;
  --muted:#6E665A;
  --gold:#B68A3E;
  --gold-deep:#9c7430;
  --gold-soft:#E7D3A6;
  --slate:#2C3A38;
  --border:#E6DCC9;
  --shadow:0 18px 50px rgba(44,58,56,.10);
  --shadow-sm:0 8px 22px rgba(44,58,56,.10);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:'Nunito Sans',sans-serif;
  font-size:19px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
em{font-style:italic}

.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}

/* ---- shared layout ---- */
.col{max-width:680px;margin:0 auto;padding:0 24px}
.center{text-align:center}
.muted{color:var(--muted)}
h1,h2{font-family:'Fraunces',serif;font-weight:500;line-height:1.12;letter-spacing:-.01em;color:var(--ink)}
h1{font-size:clamp(2.5rem,5.4vw,3.7rem)}
h2{font-size:clamp(1.85rem,3.4vw,2.45rem);margin-bottom:.6em}
p{margin:0 0 1.05em}
p:last-child{margin-bottom:0}

.kicker{
  font-family:'Nunito Sans',sans-serif;font-weight:700;
  text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;
  color:var(--gold);margin-bottom:1rem;
}
.kicker.center{display:block;text-align:center}
.strong-line{font-family:'Fraunces',serif;font-size:1.22em;color:var(--ink);font-weight:500;line-height:1.4}

/* ---- header ---- */
.site-head{padding:22px 24px;max-width:1100px;margin:0 auto}
.brand{display:inline-flex;align-items:center;gap:13px;text-decoration:none;color:var(--ink)}
.brand-mark{width:40px;height:40px;flex:none}
.brand-words{display:flex;flex-direction:column;line-height:1.1}
.brand-name{font-family:'Fraunces',serif;font-weight:600;font-size:1.2rem}
.brand-tag{font-size:.72rem;letter-spacing:.09em;text-transform:uppercase;color:var(--muted)}

/* ---- section bands / rhythm ---- */
section{padding:92px 0}
.band-cream{background:var(--paper)}
.band-sand{background:var(--sand)}
.band-slate{background:var(--slate);color:#F2ECE0}

/* ---- hero ---- */
.hero{
  max-width:1100px;margin:0 auto;padding:48px 24px 84px;
  display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;
}
.hero-text{max-width:560px}
.hero h1{margin-bottom:.35em}
.hero-support{font-family:'Fraunces',serif;font-size:1.4rem;line-height:1.3;color:var(--gold-deep);margin-bottom:.7em}
.sub{font-size:1.12rem;color:var(--muted);margin-bottom:1.6em}
.hero-media img{
  border-radius:18px;box-shadow:var(--shadow);
  width:100%;height:auto;aspect-ratio:1/1;object-fit:cover;
}

/* ---- opt-in form (Kit slot) ---- */
.optin{display:flex;gap:10px;max-width:480px}
.optin input{
  flex:1;min-width:0;font:inherit;font-size:1rem;
  padding:15px 18px;border:1.5px solid var(--border);border-radius:10px;
  background:#fff;color:var(--ink);
}
.optin input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-soft)}
.optin button{
  font:inherit;font-weight:700;font-size:1rem;cursor:pointer;white-space:nowrap;
  padding:15px 26px;border:none;border-radius:10px;
  background:var(--gold);color:#fff;box-shadow:var(--shadow-sm);
  transition:transform .18s ease,background .18s ease;
}
.optin button:hover{background:var(--gold-deep);transform:translateY(-2px)}
.microcopy{font-size:.92rem;color:var(--muted);margin-top:.8em}
/* Kit error slot: hidden until the script fills it */
.formkit-alert{list-style:none;margin:.7em 0 0;padding:0;font-size:.9rem;color:#a3361a}
.formkit-alert:empty{display:none}
.formkit-submit .formkit-spinner{display:none}
.optin.on-dark input{background:rgba(255,255,255,.96);border-color:transparent}
.microcopy.on-dark{color:#cdbfa6}

/* ---- proof row ---- */
.proof-row{list-style:none;margin-top:1.9em;display:flex;flex-wrap:wrap;gap:10px 26px}
.proof-row li{display:flex;align-items:center;gap:9px;font-size:.92rem;color:var(--ink)}
.tick{width:18px;height:18px;border-radius:50%;background:var(--gold-soft);position:relative;flex:none}
.tick::after{content:"";position:absolute;left:5px;top:4px;width:5px;height:9px;border:solid var(--gold-deep);border-width:0 2px 2px 0;transform:rotate(45deg)}

/* ---- B. truth + pull-quote ---- */
.truth p{margin-bottom:1.1em}
.pull{margin:1.5em 0;padding:6px 0 6px 26px;border-left:3px solid var(--gold)}
.pull p{font-family:'Fraunces',serif;font-size:1.5rem;line-height:1.35;color:var(--ink);font-weight:400;margin:0}

/* ---- D. sampler trio ---- */
.sampler .col{max-width:760px;margin-bottom:48px}
.smoothie-trio{
  list-style:none;max-width:1000px;margin:0 auto 38px;padding:0 24px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:26px;
}
.smoothie-trio li{text-align:center}
.smoothie-trio img{
  width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:16px;
  box-shadow:var(--shadow-sm);margin-bottom:14px;
}
.smoothie-trio span{font-family:'Fraunces',serif;font-size:1.12rem;color:var(--ink)}

/* ---- buttons-as-link ---- */
.btn-link{
  display:inline-block;font-weight:700;text-decoration:none;
  padding:16px 32px;border-radius:10px;background:var(--gold);color:#fff;
  box-shadow:var(--shadow-sm);transition:transform .18s ease,background .18s ease;
}
.btn-link:hover{background:var(--gold-deep);transform:translateY(-2px)}

/* ---- E. story ---- */
.story-grid{
  max-width:1000px;margin:0 auto;padding:0 24px;
  display:grid;grid-template-columns:300px 1fr;gap:54px;align-items:start;
}
.story-photo{position:sticky;top:32px;text-align:center}
.headshot{width:100%;display:block;border-radius:16px;box-shadow:var(--shadow-sm);object-fit:cover}
.photo-wrap{position:relative;display:inline-block;width:100%}
.cert-badge{position:absolute;right:-8px;bottom:-8px;width:34%;max-width:150px;height:auto;filter:drop-shadow(0 4px 10px rgba(0,0,0,.18))}
.badge-note{margin-top:16px;font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gold-deep);font-weight:700;line-height:1.5}
.story-col{max-width:600px}
.disclaimer-inline{font-style:italic;color:var(--muted);font-size:.95rem;margin-top:-.4em}

/* ---- F. newsletter ---- */
.gets{
  list-style:none;max-width:620px;margin:1.8em auto 0;
  background:#fff;border:1px solid var(--border);border-radius:16px;
  box-shadow:var(--shadow-sm);padding:30px 34px;
}
.gets li{position:relative;padding:14px 0 14px 34px;border-bottom:1px solid var(--border)}
.gets li:last-child{border-bottom:none}
.gets li::before{
  content:"";position:absolute;left:0;top:21px;width:16px;height:16px;border-radius:50%;
  background:var(--gold-soft);
}
.gets li::after{content:"";position:absolute;left:5px;top:25px;width:5px;height:8px;border:solid var(--gold-deep);border-width:0 2px 2px 0;transform:rotate(45deg)}
.newsletter .muted{margin-top:1.4em}

/* ---- G. signup band ---- */
.band-slate h2{color:#fff}
.signup .optin{margin:1.8em auto 0;justify-content:center}

/* ---- footer ---- */
.site-foot{background:var(--slate);color:#bdb09b;padding:46px 0}
.site-foot .legal{font-size:.82rem;line-height:1.6;color:#9d9281;margin-bottom:1.4em}
.foot-links{display:flex;flex-wrap:wrap;gap:8px 22px;align-items:center;font-size:.9rem}
.foot-links a{color:#cdbfa6;text-decoration:none}
.foot-links a:hover{text-decoration:underline}
.copyr{color:#cdbfa6;font-weight:700}

/* ---- cookie / privacy notice banner ---- */
.cc-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:9999;max-width:760px;margin:0 auto;
  background:var(--slate);color:#f2ece0;padding:16px 20px;border-radius:12px;
  display:flex;gap:16px 20px;align-items:center;justify-content:center;flex-wrap:wrap;
  font-size:.9rem;line-height:1.45;box-shadow:0 10px 34px rgba(0,0,0,.22)}
.cc-banner a{color:var(--gold-soft);text-decoration:underline}
.cc-banner button{font:inherit;font-weight:700;cursor:pointer;border:none;border-radius:8px;
  padding:10px 24px;background:var(--gold);color:#fff;white-space:nowrap}
.cc-banner button:hover{background:var(--gold-deep)}

/* ---- motion (whisper) ---- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ---- mobile ---- */
@media (max-width:860px){
  body{font-size:18px}
  section{padding:64px 0}
  .hero{grid-template-columns:1fr;gap:34px;padding:24px 22px 60px}
  .hero-text,.hero-media{min-width:0;max-width:none}
  .hero-text{order:2}
  .hero-media{order:1}
  .hero-media img{width:100%;max-width:100%;margin:0 auto}
  .story-grid{grid-template-columns:1fr;gap:30px}
  .story-photo{position:static;max-width:300px;margin:0 auto}
  .smoothie-trio{grid-template-columns:1fr;max-width:380px;gap:22px}
  .optin{flex-direction:column}
  .optin button{width:100%}
}

/* ===== Multi-page nav + interior pages (added 2026-06-22) ===== */

/* header becomes brand-left / nav-right (augments the .site-head rule above) */
.site-head{display:flex;align-items:center;justify-content:space-between;gap:14px 24px;flex-wrap:wrap}
.site-nav{display:flex;gap:2px;flex-wrap:wrap}
.site-nav a{
  font-family:'Nunito Sans',sans-serif;font-weight:700;font-size:.92rem;
  color:var(--muted);text-decoration:none;padding:8px 15px;border-radius:9px;
  transition:color .15s ease,background .15s ease;
}
.site-nav a:hover{color:var(--ink);background:var(--sand)}
.site-nav a[aria-current="page"]{color:var(--gold-deep);background:var(--sand)}

/* interior page heading block */
h3{font-family:'Fraunces',serif;font-weight:500;font-size:1.5rem;line-height:1.2;letter-spacing:-.01em;color:var(--ink);margin-bottom:.45em}
.page-hero{max-width:820px;margin:0 auto;padding:72px 24px 0;text-align:center}
.page-hero .lead{font-size:1.18rem;color:var(--muted);max-width:640px;margin:1.1em auto 0}

/* apps umbrella cards */
.app-cards{max-width:980px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1fr 1fr;gap:28px}
.app-card{
  background:#fff;border:1px solid var(--border);border-radius:18px;
  box-shadow:var(--shadow-sm);padding:38px 34px;display:flex;flex-direction:column;
}
.app-card .eyebrow{
  font-family:'Nunito Sans',sans-serif;font-weight:700;text-transform:uppercase;
  letter-spacing:.13em;font-size:.74rem;color:var(--gold);margin-bottom:.7rem;
}
.app-card p{color:var(--muted)}
.app-card .btn-link{align-self:flex-start;margin-top:22px}

/* status pill (honest readiness label) */
.app-status{
  display:inline-block;font-family:'Nunito Sans',sans-serif;font-weight:700;
  font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;
  padding:5px 13px;border-radius:999px;margin-bottom:1.1rem;
}
.app-status.live{background:var(--gold-soft);color:var(--gold-deep)}
.app-status.soon{background:#e8e1d3;color:var(--muted)}

@media (max-width:860px){
  .site-head{padding:16px 20px}
  .site-nav{width:100%;justify-content:center}
  .app-cards{grid-template-columns:1fr}
  .page-hero{padding-top:48px}
}
