/* =========================================================================
   I COOK WITH WINE — "Cellar & Parchment"
   Maps to GeneratePress: :root vars => Global Colours, this file => Additional CSS
   ========================================================================= */

/* ---- Design tokens ---------------------------------------------------- */
:root{
  /* Global Colours (GeneratePress slots 1–7) */
  --bordeaux:#6B1F2E;     /* G1  headlines on light, primary buttons */
  --aubergine:#3A1420;    /* G2  dark sections, footer */
  --parchment:#F6EFE1;    /* G3  page background */
  --cream:#FBF7EF;        /* G4  cards, panels, Wine Note */
  --charcoal:#2B2622;     /* G5  body text */
  --brass:#A8814E;        /* G6  hairlines, icons, borders, fills on dark */
  --brass-dark:#8A6736;   /* G7  small text: eyebrows + links (AA-safe) */

  /* Derived */
  --hairline:rgba(168,129,78,.45);
  --ink-70:rgba(43,38,34,.72);
  --ink-55:rgba(43,38,34,.55);
  --cream-70:rgba(251,247,239,.72);
  --shadow:0 24px 60px -32px rgba(58,20,32,.45);
  --shadow-sm:0 12px 30px -22px rgba(58,20,32,.5);

  /* Type */
  --display:"Fraunces",Georgia,"Times New Roman",serif;
  --body:"Mulish",-apple-system,"Segoe UI",sans-serif;

  /* Fluid scale */
  --h1:clamp(2.6rem,6.2vw,4.4rem);
  --h2:clamp(2rem,4vw,3rem);
  --h3:clamp(1.25rem,2vw,1.5rem);
  --lead:clamp(1.18rem,1.6vw,1.4rem);
  --body-size:1.075rem;
  --eyebrow:.78rem;

  /* Space */
  --container:1140px;
  --narrow:720px;
  --section:clamp(72px,11vw,132px);
  --gutter:clamp(20px,5vw,40px);
}

/* ---- Reset ------------------------------------------------------------ */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--body);
  font-size:var(--body-size);
  line-height:1.72;
  color:var(--charcoal);
  background:var(--parchment);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit}
h1,h2,h3,h4{margin:0;font-family:var(--display);font-weight:600;line-height:1.06;letter-spacing:-.01em;color:var(--bordeaux)}
p{margin:0 0 1.1em}
ul{margin:0;padding:0}

/* ---- Paper grain (very subtle) ---------------------------------------- */
body::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---- Layout primitives ------------------------------------------------ */
.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.container--narrow{max-width:var(--narrow)}
.section{padding-block:var(--section)}
.section--cream{background:var(--cream)}
.section--dark{background:var(--aubergine);color:var(--cream-70)}
.section--dark h2,.section--dark h3{color:var(--cream)}

/* ---- Shared bits ------------------------------------------------------ */
.eyebrow{
  font-family:var(--body);font-weight:700;font-size:var(--eyebrow);
  text-transform:uppercase;letter-spacing:.2em;color:var(--brass-dark);
  margin:0 0 1.1rem;display:inline-flex;align-items:center;gap:.7rem;
}
.section--dark .eyebrow{color:var(--brass)}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--brass)}
.eyebrow--center{justify-content:center}

.lead{font-size:var(--lead);line-height:1.55;color:var(--ink-70);font-weight:400}
.section--dark .lead{color:var(--cream-70)}

.hairline{height:1px;background:var(--hairline);border:0;margin:0}

/* ---- Buttons ---------------------------------------------------------- */
.btn{
  --bg:var(--bordeaux);--fg:var(--cream);
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--body);font-weight:700;font-size:.95rem;letter-spacing:.01em;
  background:var(--bg);color:var(--fg);
  padding:.95em 1.7em;border-radius:3px;border:1px solid var(--bg);
  text-decoration:none;cursor:pointer;
  transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s,background .3s;
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.btn--brass{--bg:var(--brass);--fg:var(--aubergine)}
.btn--ghost{--bg:transparent;--fg:var(--bordeaux);border-color:var(--hairline)}
.section--dark .btn--ghost{--fg:var(--cream);border-color:rgba(168,129,78,.5)}

.tlink{
  font-family:var(--body);font-weight:700;font-size:.95rem;color:var(--brass-dark);
  text-decoration:none;display:inline-flex;align-items:center;gap:.45rem;
  border-bottom:1px solid transparent;transition:gap .3s,border-color .3s;
}
.tlink:hover{gap:.8rem;border-color:var(--brass)}
.section--dark .tlink{color:var(--brass)}

/* ---- Image placeholders (swap for real photography) ------------------- */
.img-ph{
  position:relative;border-radius:4px;overflow:hidden;
  background:
    radial-gradient(120% 140% at 18% 12%,rgba(168,129,78,.18),transparent 55%),
    linear-gradient(150deg,#efe3cf 0%,#e7d3bd 48%,#d9bfa6 100%);
  display:grid;place-items:center;color:var(--brass-dark);
}
.img-ph::after{
  content:"";width:46px;height:46px;opacity:.5;
  background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238A6736' stroke-width='1.1' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 3h10l-1 6.2a4 4 0 0 1-8 0L7 3z'/%3E%3Cpath d='M12 14v6M8.5 20h7'/%3E%3C/svg%3E");
}
.img-ph__label{
  position:absolute;left:14px;bottom:12px;font-family:var(--body);font-weight:700;
  font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-dark);
  opacity:.8;max-width:80%;
}
.img-ph--hero{aspect-ratio:4/5}
.img-ph--wide{aspect-ratio:3/2}
.img-ph--card{aspect-ratio:4/5}
.img-ph--tall{aspect-ratio:3/4}

/* ======================================================================
   HEADER
   ====================================================================== */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(246,241,225,.82);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--hairline);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding-block:.95rem}
.brand{
  font-family:var(--display);font-weight:600;font-size:1.32rem;letter-spacing:-.01em;
  color:var(--bordeaux);text-decoration:none;display:inline-flex;align-items:center;gap:.55rem;
}
.brand b{font-weight:600}
.brand-mark{color:var(--brass);font-size:1.1rem}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{
  font-family:var(--body);font-weight:600;font-size:.92rem;text-decoration:none;color:var(--charcoal);
  letter-spacing:.01em;padding-bottom:3px;border-bottom:1.5px solid transparent;transition:border-color .3s,color .3s;
}
.nav-links a:hover,.nav-links a[aria-current]{color:var(--bordeaux);border-color:var(--brass)}
.nav-cta{margin-left:.3rem}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:6px;color:var(--bordeaux)}
.nav-toggle svg{width:26px;height:26px}

/* ======================================================================
   HERO — asymmetric, not centred
   ====================================================================== */
.hero{position:relative;border-bottom:1px solid var(--hairline)}
.hero__grid{
  display:grid;grid-template-columns:1.05fr .95fr;align-items:stretch;
  min-height:min(82vh,760px);
}
.hero__text{padding:clamp(48px,8vw,104px) clamp(24px,5vw,72px);display:flex;flex-direction:column;justify-content:center;max-width:640px;margin-left:auto}
.hero h1{font-size:var(--h1);margin-bottom:1.1rem}
.hero h1 em{font-style:italic;color:var(--brass-dark)}
.hero__lead{margin-bottom:2rem;max-width:30ch}
.hero__actions{display:flex;align-items:center;gap:1.6rem;flex-wrap:wrap}
.hero__media{position:relative}
.hero__media .img-ph{position:absolute;inset:0;border-radius:0}
.hero__media::after{ /* darken inner edge for any text bleed / depth */
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(58,20,32,.28),transparent 38%);
}

/* ======================================================================
   PAIN — narrow, held breath
   ====================================================================== */
.pain{text-align:left}
.pain h2{font-size:var(--h2);margin-bottom:1.4rem;max-width:18ch}
.pain .pull{
  font-family:var(--display);font-style:italic;font-weight:400;
  font-size:clamp(1.3rem,2.4vw,1.7rem);line-height:1.4;color:var(--bordeaux);
  border-left:2px solid var(--brass);padding-left:1.4rem;margin:2.2rem 0 0;max-width:34ch;
}

/* ======================================================================
   SOLUTION — full width, the exhale
   ====================================================================== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:center}
.split__media .img-ph{box-shadow:var(--shadow)}
.split h2{font-size:var(--h2);margin-bottom:1.3rem}
.split p{color:var(--ink-70)}
.split .btn{margin-top:.8rem}

/* ======================================================================
   FEATURES -> BENEFITS
   ====================================================================== */
.section-head{max-width:46ch;margin-bottom:clamp(36px,5vw,60px)}
.section-head--center{margin-inline:auto;text-align:center}
.section-head h2{font-size:var(--h2)}
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,30px)}
.feature{
  background:var(--cream);border:1px solid var(--hairline);border-radius:5px;
  padding:clamp(24px,3vw,34px);transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s;
}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.feature__icon{width:34px;height:34px;color:var(--brass);margin-bottom:1rem}
.feature__icon svg{width:100%;height:100%}
.feature h3{font-size:1.28rem;line-height:1.18;margin-bottom:.6rem;color:var(--bordeaux)}
.feature p{margin:0;color:var(--ink-70);font-size:1rem}

/* ======================================================================
   SOCIAL PROOF — dark band
   ====================================================================== */
.stats{display:flex;flex-wrap:wrap;gap:clamp(20px,5vw,64px);margin:2.6rem 0 3.4rem;border-top:1px solid rgba(168,129,78,.3);border-bottom:1px solid rgba(168,129,78,.3);padding-block:1.8rem}
.stat__num{font-family:var(--display);font-size:clamp(2rem,3.4vw,2.7rem);color:var(--brass);line-height:1}
.stat__label{font-size:.9rem;color:var(--cream-70);margin-top:.4rem;max-width:22ch}
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,28px)}
.quote{
  background:var(--cream);color:var(--charcoal);border-radius:5px;
  padding:clamp(24px,3vw,34px);position:relative;
}
.quote::before{content:"\201C";position:absolute;top:.1em;left:.3em;font-family:var(--display);font-size:4rem;color:var(--brass);opacity:.5;line-height:1}
.quote p{position:relative;font-size:1.05rem;line-height:1.6;margin:.6rem 0 1.2rem}
.quote cite{font-style:normal;font-weight:700;font-size:.85rem;color:var(--brass-dark);letter-spacing:.04em}
.ph-tag{display:inline-block;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-55);margin-top:.3rem}

/* ======================================================================
   JOIN (free)
   ====================================================================== */
.join-panel{
  background:var(--cream);border:1px solid var(--brass);border-left-width:3px;border-radius:6px;
  display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,5vw,56px);
  padding:clamp(30px,5vw,56px);box-shadow:var(--shadow);
}
.join-panel h2{font-size:clamp(1.8rem,3.2vw,2.5rem);margin-bottom:.9rem}
.join-list{list-style:none;margin:1.4rem 0 0;display:grid;gap:.75rem}
.join-list li{position:relative;padding-left:1.7rem;font-size:1rem;color:var(--charcoal)}
.join-list li::before{
  content:"";position:absolute;left:0;top:.45em;width:11px;height:11px;border-radius:50%;
  background:var(--brass);box-shadow:0 0 0 3px rgba(168,129,78,.18);
}
.signup{display:flex;flex-direction:column;justify-content:center}
.signup label{font-family:var(--body);font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.14em;color:var(--brass-dark);margin-bottom:.6rem}
.field{
  width:100%;padding:.9em 1em;border:1px solid var(--hairline);border-radius:3px;background:#fff;
  font-family:var(--body);font-size:1rem;color:var(--charcoal);margin-bottom:.9rem;
}
.field:focus{outline:2px solid var(--brass-dark);outline-offset:1px;border-color:transparent}
.signup .btn{width:100%;justify-content:center}
.signup small{display:block;margin-top:.9rem;color:var(--ink-55);font-size:.82rem;line-height:1.5}

/* ======================================================================
   FINAL CTA — full bleed
   ====================================================================== */
.cta{position:relative;color:var(--cream);overflow:hidden;border-top:1px solid var(--hairline)}
.cta .img-ph{position:absolute;inset:0;border-radius:0}
.cta__veil{position:absolute;inset:0;background:linear-gradient(90deg,rgba(36,12,20,.9) 0%,rgba(58,20,32,.78) 42%,rgba(58,20,32,.28) 100%)}
.cta__inner{position:relative;padding-block:clamp(80px,12vw,150px)}
.cta__panel{max-width:560px}
.cta h2{color:var(--cream);font-size:var(--h2);margin-bottom:1rem}
.cta p{color:var(--cream-70);font-size:var(--lead)}
.cta .signup-inline{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1.6rem}
.cta .field{margin:0;flex:1 1 240px;background:rgba(255,255,255,.95)}

/* ======================================================================
   FOOTER
   ====================================================================== */
.site-footer{background:var(--aubergine);color:var(--cream-70);padding-block:clamp(48px,7vw,72px) 2rem}
.footer-top{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;align-items:flex-start}
.footer-brand{font-family:var(--display);font-size:1.5rem;color:var(--cream);margin-bottom:.5rem}
.footer-brand .brand-mark{color:var(--brass)}
.footer-cols{display:flex;gap:clamp(32px,6vw,72px);flex-wrap:wrap}
.footer-cols h4{font-family:var(--body);font-weight:700;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);margin-bottom:1rem}
.footer-cols ul{list-style:none;display:grid;gap:.6rem}
.footer-cols a{color:var(--cream-70);text-decoration:none;font-size:.95rem;transition:color .3s}
.footer-cols a:hover{color:var(--cream)}
.footer-bottom{border-top:1px solid rgba(168,129,78,.25);margin-top:2.6rem;padding-top:1.4rem;font-size:.82rem;color:rgba(251,247,239,.5);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}

/* ======================================================================
   ARCHIVE
   ====================================================================== */
.archive-head{padding-block:clamp(44px,6vw,72px) 0;border-bottom:1px solid var(--hairline)}
.archive-head h1{font-size:clamp(2.2rem,5vw,3.4rem);margin-bottom:.7rem}
.filters{display:flex;gap:.6rem;flex-wrap:wrap;padding-block:1.6rem}
.pill{
  font-family:var(--body);font-weight:600;font-size:.9rem;
  background:transparent;color:var(--charcoal);border:1px solid var(--hairline);
  padding:.5em 1.1em;border-radius:100px;cursor:pointer;transition:all .25s;
}
.pill:hover{border-color:var(--brass);color:var(--bordeaux)}
.pill[aria-pressed="true"]{background:var(--bordeaux);color:var(--cream);border-color:var(--bordeaux)}
.filter-meta{font-family:var(--display);font-style:italic;color:var(--ink-70);font-size:1.05rem;margin:.4rem 0 2.4rem}
.recipe-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,34px)}
.recipe-card{text-decoration:none;color:inherit;display:block;transition:transform .4s cubic-bezier(.2,.7,.2,1)}
.recipe-card:hover{transform:translateY(-5px)}
.recipe-card .img-ph{margin-bottom:1rem}
.recipe-card .tag{
  position:absolute;top:12px;left:12px;z-index:2;background:rgba(58,20,32,.85);color:var(--cream);
  font-family:var(--body);font-weight:700;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;
  padding:.35em .7em;border-radius:2px;
}
.recipe-card h3{font-size:1.3rem;color:var(--bordeaux);margin-bottom:.35rem;transition:color .3s}
.recipe-card:hover h3{color:var(--brass-dark)}
.recipe-card .meta-line{font-size:.85rem;color:var(--ink-55);font-family:var(--body)}
.archive-foot{text-align:center;margin-top:clamp(40px,6vw,64px)}
.is-hidden{display:none !important}

/* ======================================================================
   SINGLE RECIPE
   ====================================================================== */
.breadcrumb{font-size:.82rem;color:var(--ink-55);padding-block:1.4rem;letter-spacing:.02em}
.breadcrumb a{color:var(--brass-dark);text-decoration:none}
.recipe-hero{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,60px);align-items:center;padding-bottom:clamp(36px,5vw,56px)}
.recipe-hero .tag-inline{font-family:var(--body);font-weight:700;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-dark)}
.recipe-hero h1{font-size:clamp(2.3rem,5vw,3.6rem);margin:.7rem 0 1rem}
.recipe-hero .dek{font-family:var(--display);font-style:italic;font-size:1.25rem;color:var(--ink-70);line-height:1.45;margin-bottom:1.6rem}
.meta-row{display:flex;flex-wrap:wrap;gap:1.6rem;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);padding-block:1.1rem}
.meta-row .k{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brass-dark);font-weight:700;display:block;margin-bottom:.2rem}
.meta-row .v{font-family:var(--display);font-size:1.05rem;color:var(--bordeaux)}

.recipe-body{max-width:760px;margin-inline:auto}
.recipe-body p{color:var(--ink-70);font-size:1.12rem;line-height:1.78}
.recipe-body h2{font-size:1.7rem;margin:2.4rem 0 1rem}

/* Wine Note — signature component */
.wine-note{
  background:var(--cream);border:1px solid var(--brass);border-left-width:3px;border-radius:6px;
  padding:clamp(24px,3.5vw,36px);margin:2.6rem 0;box-shadow:var(--shadow-sm);
}
.wine-note__head{display:flex;align-items:center;gap:.7rem;margin-bottom:1.2rem}
.wine-note__head svg{width:24px;height:24px;color:var(--brass)}
.wine-note__head span{font-family:var(--body);font-weight:800;font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-dark)}
.wine-note dl{margin:0;display:grid;gap:.85rem}
.wine-note dt{font-family:var(--display);font-weight:600;color:var(--bordeaux);font-size:1.05rem}
.wine-note dd{margin:.15rem 0 0;color:var(--ink-70)}

.ingredients{background:var(--cream);border:1px solid var(--hairline);border-radius:6px;padding:clamp(24px,3.5vw,36px);margin:2rem 0}
.ingredients h2{margin-top:0}
.ingredients ul{list-style:none;display:grid;gap:.6rem;margin-top:1rem}
.ingredients li{position:relative;padding-left:1.5rem;color:var(--charcoal)}
.ingredients li::before{content:"";position:absolute;left:0;top:.6em;width:6px;height:6px;border-radius:50%;background:var(--hairline)}
.ingredients li.is-wine{font-weight:700;color:var(--bordeaux)}
.ingredients li.is-wine::before{width:11px;height:11px;top:.45em;left:-2px;background:var(--brass);box-shadow:0 0 0 3px rgba(168,129,78,.2)}
.ingredients .serves{font-style:italic;color:var(--ink-55);font-family:var(--display);margin-bottom:.4rem}

.method{counter-reset:step;display:grid;gap:1.6rem;margin:1.4rem 0}
.method__step{display:grid;grid-template-columns:auto 1fr;gap:1.1rem;align-items:start}
.method__step::before{
  counter-increment:step;content:counter(step);
  font-family:var(--display);font-size:1.1rem;color:var(--cream);background:var(--bordeaux);
  width:2.1rem;height:2.1rem;border-radius:50%;display:grid;place-items:center;flex:none;
}
.method__step p{margin:.1rem 0 0;color:var(--charcoal)}
.tip{
  margin:.7rem 0 0;padding-left:.95rem;border-left:2px solid var(--brass);
  font-family:var(--display);font-style:italic;font-size:.98rem;color:var(--brass-dark);line-height:1.45;
}

.tools{
  position:sticky;bottom:0;display:flex;gap:.8rem;justify-content:center;
  background:rgba(246,241,225,.9);backdrop-filter:blur(8px);border-top:1px solid var(--hairline);
  padding:.8rem;margin:2.4rem 0 0;z-index:30;border-radius:6px 6px 0 0;
}
.tools button{
  font-family:var(--body);font-weight:700;font-size:.9rem;background:none;border:1px solid var(--hairline);
  color:var(--bordeaux);padding:.6em 1.2em;border-radius:4px;cursor:pointer;display:inline-flex;gap:.5rem;align-items:center;transition:all .25s;
}
.tools button:hover{border-color:var(--brass);background:var(--cream)}
.tools button.is-on{background:var(--bordeaux);color:var(--cream);border-color:var(--bordeaux)}

.userest{background:var(--cream);border-radius:6px;padding:clamp(20px,3vw,30px);margin:2.4rem 0;border:1px solid var(--hairline)}
.userest h3{font-size:1.2rem;margin-bottom:.5rem;color:var(--bordeaux)}
.userest p{margin:0;color:var(--ink-70)}
.userest p+p{margin-top:.8rem}

.related h2{font-size:var(--h2);margin-bottom:1.6rem}

/* Cook mode — strips chrome, focuses recipe */
body.cook-mode .site-header,
body.cook-mode .recipe-hero .recipe-hero__media,
body.cook-mode .related,
body.cook-mode .site-footer,
body.cook-mode .recipe-cta,
body.cook-mode .userest,
body.cook-mode .story-block{display:none}
body.cook-mode .recipe-body{max-width:820px}
body.cook-mode{background:#fff}

/* ======================================================================
   GUIDE / HUB
   ====================================================================== */
.guide-hero{padding-block:clamp(48px,7vw,88px) 0;border-bottom:1px solid var(--hairline)}
.guide-hero h1{font-size:clamp(2.2rem,5vw,3.6rem);max-width:18ch;margin-bottom:1rem}
.guide-hero .lead{max-width:60ch}
.guide-hero .jump{margin-top:1.6rem}
.prose{max-width:760px;margin-inline:auto}
.prose h2{font-size:1.7rem;margin:2.6rem 0 1rem;scroll-margin-top:90px}
.prose p{color:var(--ink-70);font-size:1.1rem;line-height:1.78}
.prose .answer{font-size:1.18rem;color:var(--charcoal);border-left:3px solid var(--brass);padding-left:1.3rem;font-family:var(--display);line-height:1.55}
.prose a{color:var(--brass-dark);text-decoration:underline;text-decoration-color:var(--hairline);text-underline-offset:3px}
.prose a:hover{text-decoration-color:var(--brass)}
.sub-table{width:100%;border-collapse:collapse;margin:1.4rem 0;font-size:.98rem}
.sub-table th,.sub-table td{text-align:left;padding:.7em .8em;border-bottom:1px solid var(--hairline)}
.sub-table th{font-family:var(--body);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brass-dark)}
.faq{display:grid;gap:.8rem;margin-top:1.4rem}
.faq details{background:var(--cream);border:1px solid var(--hairline);border-radius:5px;padding:.4rem 1.2rem}
.faq summary{font-family:var(--display);font-size:1.15rem;color:var(--bordeaux);cursor:pointer;padding:.9rem 0;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--brass);font-family:var(--body);transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--ink-70);margin:0 0 1rem}

/* ======================================================================
   MOTION
   ====================================================================== */
[data-reveal]{opacity:0;transform:translateY(22px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
[data-reveal].is-visible{opacity:1;transform:none}
[data-reveal-stagger]>*{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
[data-reveal-stagger].is-visible>*{opacity:1;transform:none}
[data-reveal-stagger].is-visible>*:nth-child(2){transition-delay:.08s}
[data-reveal-stagger].is-visible>*:nth-child(3){transition-delay:.16s}
[data-reveal-stagger].is-visible>*:nth-child(4){transition-delay:.24s}
[data-reveal-stagger].is-visible>*:nth-child(5){transition-delay:.32s}
[data-reveal-stagger].is-visible>*:nth-child(6){transition-delay:.40s}

/* page-load hero stagger */
.hero__text>*{opacity:0;transform:translateY(20px);animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards}
.hero__text>*:nth-child(1){animation-delay:.1s}
.hero__text>*:nth-child(2){animation-delay:.22s}
.hero__text>*:nth-child(3){animation-delay:.34s}
.hero__text>*:nth-child(4){animation-delay:.46s}
@keyframes rise{to{opacity:1;transform:none}}

/* Focus visibility (accessibility spec) */
a:focus-visible,button:focus-visible,input:focus-visible,summary:focus-visible{
  outline:2px solid var(--brass-dark);outline-offset:3px;border-radius:2px;
}

@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important}
  [data-reveal],[data-reveal-stagger]>*{opacity:1;transform:none}
}

/* ======================================================================
   RESPONSIVE
   ====================================================================== */
@media (max-width:900px){
  .features,.testimonials,.recipe-grid{grid-template-columns:1fr 1fr}
  .hero__grid{grid-template-columns:1fr;min-height:auto}
  .hero__media{min-height:46vh}
  .hero__media .img-ph{position:relative}
  .split,.recipe-hero,.join-panel{grid-template-columns:1fr}
  .recipe-hero__media{order:-1}
}
@media (max-width:620px){
  .features,.testimonials,.recipe-grid{grid-template-columns:1fr}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;background:var(--parchment);
    flex-direction:column;align-items:flex-start;gap:0;padding:1rem var(--gutter) 1.5rem;
    border-bottom:1px solid var(--hairline);box-shadow:var(--shadow-sm);
    transform:translateY(-12px);opacity:0;pointer-events:none;transition:all .3s;
  }
  .nav-links.open{transform:none;opacity:1;pointer-events:auto}
  .nav-links li{width:100%}
  .nav-links a{display:block;padding:.8rem 0;border-bottom:1px solid var(--hairline);width:100%}
  .nav-toggle{display:inline-flex}
  .stats{gap:1.6rem}
}

/* Print — recipe card only (ink-light) */
@media print{
  body::before,.site-header,.recipe-hero__media,.tools,.related,.site-footer,
  .recipe-cta,.story-block,.breadcrumb,.userest{display:none !important}
  body{background:#fff;color:#000}
  .wine-note,.ingredients{border:1px solid #999;box-shadow:none;background:#fff}
  h1,h2,h3,.recipe-hero h1{color:#000}
  .method__step::before{background:#000}
}
