/* =========================================================
   SUNSET FARMS Stylesheet
   Editorial. Warm. Honest. Built by Timpson Marketing.
   ========================================================= */

/* ---------- 0. Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img,picture,video,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}

/* ---------- 1. Tokens ---------- */
:root{
  /* color */
  --cream:#F5F0E1;
  --warm-white:#FBFAF5;
  --ink:#1F2D24;
  --green:#2E5D3A;
  --green-deep:#1F3F27;
  --green-soft:#4A7C4A;
  --gold:#D4A642;
  --gold-deep:#B58A2B;
  --sunset:#C7611F;       /* warm sunset orange for hero italics + accents */
  --sunset-deep:#9F4A11;  /* deeper for hover */
  --soil:#6B4423;
  --stone:#9A9A92;
  --graphite:#3B3B38;
  --line:rgba(31,45,36,.12);
  --line-strong:rgba(31,45,36,.22);

  /* type */
  --serif:'Playfair Display','Canela','Tiempos','Georgia',serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,Arial,sans-serif;
  --mono:'JetBrains Mono','IBM Plex Mono',ui-monospace,Menlo,monospace;

  /* layout */
  --max:1280px;
  --gutter:clamp(20px,4vw,48px);
  --radius:6px;
  --radius-lg:14px;

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

/* ---------- 2. Typography ---------- */
h1,h2,h3,h4,h5{font-family:var(--serif);font-weight:500;letter-spacing:-.015em;line-height:1.08;color:var(--ink)}
h1{font-size:clamp(2.6rem,6vw,5.2rem);font-weight:400}
h2{font-size:clamp(2rem,4.5vw,3.6rem);font-weight:400}
h3{font-size:clamp(1.5rem,2.6vw,2.1rem);font-weight:500;line-height:1.2}
h4{font-size:1.25rem;font-weight:500}
p{max-width:64ch}
.lead{font-size:clamp(1.15rem,1.6vw,1.35rem);line-height:1.55;color:var(--graphite)}

/* fancy italics */
em,.italic{font-family:var(--serif);font-style:italic;font-weight:400}

/* eyebrow / kicker */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-size:13px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--green);
}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--green)}

/* sustained editorial drop cap */
.dropcap::first-letter{
  font-family:var(--serif);font-weight:500;
  float:left;font-size:5.4em;line-height:.85;
  padding:.08em .12em 0 0;color:var(--green);
}

/* ---------- 3. Layout helpers ---------- */
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--gutter)}
.wrap--narrow{max-width:880px;margin:0 auto;padding:0 var(--gutter)}
.section{padding:clamp(64px,9vw,140px) 0}
.section--tight{padding:clamp(48px,6vw,96px) 0}
.section--cream{background:var(--cream)}
.section--white{background:var(--warm-white)}
.section--ink{background:var(--green-deep);color:var(--cream)}
.section--ink h1,.section--ink h2,.section--ink h3{color:var(--cream)}
.section--ink .eyebrow{color:var(--gold)}
.section--ink .eyebrow::before{background:var(--gold)}

.grid{display:grid;gap:clamp(24px,3vw,40px)}
.grid--2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}
.grid--3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid--4{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}

.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,96px);align-items:center}
@media(max-width:860px){.split{grid-template-columns:1fr}}

.center{text-align:center}
.muted{color:var(--graphite)}

/* ---------- 4. Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--sans);font-weight:600;font-size:15px;letter-spacing:.02em;
  padding:16px 28px;border-radius:999px;transition:all .35s var(--ease);
  white-space:nowrap;
}
.btn--primary{background:var(--green);color:var(--cream)}
.btn--primary:hover{background:var(--green-deep);transform:translateY(-2px);box-shadow:0 16px 32px -16px rgba(46,93,58,.55)}
.btn--gold{background:var(--gold);color:var(--ink)}
.btn--gold:hover{background:var(--gold-deep);color:var(--cream);transform:translateY(-2px);box-shadow:0 16px 32px -16px rgba(212,166,66,.55)}
.btn--ghost{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--cream)}
.btn--ghost-light{background:transparent;color:var(--cream);border:1px solid var(--cream)}
.btn--ghost-light:hover{background:var(--cream);color:var(--ink)}
.btn--text{padding:0;background:none;color:var(--green);border-radius:0;border-bottom:1px solid currentColor;padding-bottom:3px}
.btn--text:hover{color:var(--green-deep)}

.btn .arrow{transition:transform .35s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- 5. Header / Nav ---------- */
.banner{
  background:var(--green-deep);color:var(--cream);
  font-size:13px;letter-spacing:.06em;
  padding:10px var(--gutter);text-align:center;
  font-weight:500;
}
.banner a{text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}

.banner--promo{
  background:var(--ink);
  display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;
  font-size:13.5px;
}
.banner--promo strong{color:var(--gold);font-weight:700;letter-spacing:.02em}
.banner--promo a{color:var(--gold);font-weight:600;text-decoration:none;border-bottom:1px solid var(--gold);padding-bottom:1px}
.banner--promo a:hover{color:var(--cream);border-color:var(--cream)}
.banner__pulse{
  width:8px;height:8px;border-radius:50%;background:var(--gold);position:relative;display:inline-block;
}
.banner__pulse::after{
  content:"";position:absolute;inset:-4px;border-radius:50%;background:var(--gold);opacity:.4;
  animation:banner-pulse 1.6s ease-out infinite;
}
@keyframes banner-pulse{0%{transform:scale(.6);opacity:.55}100%{transform:scale(2.6);opacity:0}}

.product-card--feature{
  position:relative;
  outline:2px solid var(--gold);
  outline-offset:-2px;
}
.product-card--feature::before{
  content:"Limited · 6 left";
  position:absolute;top:14px;left:14px;z-index:2;
  background:var(--gold);color:var(--ink);
  font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  padding:6px 12px;border-radius:4px;
  box-shadow:0 6px 16px -6px rgba(31,45,36,.35);
}

.nav{
  position:sticky;top:0;z-index:60;
  background:rgba(245,240,225,.85);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
  transition:padding .3s var(--ease),background .3s var(--ease);
}
.nav__inner{
  max-width:var(--max);margin:0 auto;padding:18px var(--gutter);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.nav.scrolled{background:rgba(245,240,225,.95)}
.nav.scrolled .nav__inner{padding:12px var(--gutter)}

.brand{display:flex;align-items:center;gap:14px;font-family:var(--serif);font-weight:500;font-size:22px;letter-spacing:-.01em;color:var(--ink)}
.brand__mark{width:36px;height:36px;flex-shrink:0}
.brand__logo{
  height:54px;width:auto;display:block;flex-shrink:0;
  transition:transform .35s var(--ease);
}
.brand:hover .brand__logo{transform:scale(1.04)}
.brand__name{line-height:1}
.brand__sub{display:block;font-family:var(--sans);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--green);margin-top:4px;font-weight:600}
.brand__sub--solo{margin-top:0;padding-left:14px;border-left:1px solid var(--line);line-height:1.4;align-self:center}
@media(max-width:600px){
  .brand__logo{height:46px}
  .brand__sub--solo{display:none}
}

.nav__links{display:flex;align-items:center;gap:32px}
.nav__links a{font-size:15px;font-weight:500;color:var(--ink);position:relative;transition:color .25s}
.nav__links a:hover{color:var(--green)}
.nav__links a.active{color:var(--green)}
.nav__links a::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--green);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.nav__links a:hover::after,.nav__links a.active::after{transform:scaleX(1)}

.nav__cta{display:flex;align-items:center;gap:12px}

.nav__toggle{display:none;width:44px;height:44px;align-items:center;justify-content:center;border-radius:8px}
.nav__toggle span{display:block;width:22px;height:2px;background:var(--ink);position:relative}
.nav__toggle span::before,.nav__toggle span::after{content:"";position:absolute;left:0;width:22px;height:2px;background:var(--ink);transition:transform .3s var(--ease)}
.nav__toggle span::before{top:-7px}
.nav__toggle span::after{top:7px}
.nav.open .nav__toggle span{background:transparent}
.nav.open .nav__toggle span::before{transform:translateY(7px) rotate(45deg)}
.nav.open .nav__toggle span::after{transform:translateY(-7px) rotate(-45deg)}

@media(max-width:900px){
  .nav__links,.nav__cta .btn--ghost{display:none}
  .nav__toggle{display:flex}
  .nav.open .nav__links{
    display:flex;flex-direction:column;align-items:flex-start;gap:8px;
    position:absolute;top:100%;left:0;right:0;background:var(--cream);
    padding:24px var(--gutter) 32px;border-bottom:1px solid var(--line);
    box-shadow:0 24px 40px -24px rgba(0,0,0,.2);
  }
  .nav.open .nav__links a{font-size:18px;padding:8px 0;width:100%}
  .nav.open .nav__links a::after{display:none}
}

/* ---------- 6. Hero (editorial split) ---------- */
.hero{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);
  min-height:88vh;
  background:var(--warm-white);
  overflow:hidden;
}
.hero--editorial{align-items:stretch}

.hero__panel{
  position:relative;z-index:2;
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(56px,7vw,120px) clamp(32px,5vw,88px);
  background:
    radial-gradient(ellipse 80% 60% at 0% 100%, rgba(212,138,50,.08) 0%, transparent 60%),
    linear-gradient(180deg, var(--warm-white) 0%, var(--cream) 100%);
}
.hero__panel::before{
  content:"";position:absolute;top:0;bottom:0;right:-1px;width:1px;
  background:linear-gradient(180deg, transparent, var(--line) 30%, var(--line) 70%, transparent);
  z-index:3;
}
.hero__eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--sans);font-size:12px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold-deep);font-weight:700;
  margin-bottom:32px;
}
.hero__eyebrow::before{content:"";width:36px;height:1px;background:var(--gold-deep)}
.hero h1{
  color:var(--ink);max-width:14ch;
  font-family:var(--serif);
  font-size:clamp(2.4rem,5.4vw,5rem);font-weight:400;line-height:1.02;
  letter-spacing:-.025em;
}
.hero h1 em{
  color:var(--sunset);font-weight:500;font-style:normal;
  font-family:var(--serif);
}
.hero__sub{
  margin-top:28px;max-width:48ch;
  font-size:clamp(1.05rem,1.25vw,1.2rem);line-height:1.6;
  color:var(--graphite);font-weight:400;
}
.hero__cta{margin-top:40px;display:flex;flex-wrap:wrap;gap:14px}

.hero__meta{
  margin-top:auto;padding-top:48px;
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--stone);
}
.hero__meta-dot{width:4px;height:4px;background:var(--gold);border-radius:50%;display:inline-block}

.hero__photo{
  position:relative;overflow:hidden;background:var(--ink);
}
.hero__photo img{
  width:100%;height:100%;object-fit:cover;object-position:center center;
  animation:kenburns 22s ease-out infinite alternate;
}
.hero__photo::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(90deg, var(--cream) 0%, transparent 8%),
    linear-gradient(180deg, transparent 70%, rgba(31,45,36,.35) 100%);
  pointer-events:none;
}
@keyframes kenburns{from{transform:scale(1.04) translate(0,0)}to{transform:scale(1.12) translate(-1%,-1%)}}

@media(max-width:980px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero__photo{order:-1;aspect-ratio:5/4;min-height:48vh}
  .hero__photo::after{
    background:linear-gradient(180deg, transparent 60%, var(--cream) 100%);
  }
  .hero__panel{padding:clamp(40px,8vw,72px) clamp(24px,5vw,48px) clamp(56px,9vw,96px)}
  .hero__panel::before{display:none}
}

/* ---------- 7. Page Hero (interior pages) ---------- */
.page-hero{
  position:relative;min-height:90vh;display:flex;align-items:flex-end;
  color:var(--cream);overflow:hidden;
}
.page-hero__bg{position:absolute;inset:0;z-index:0}
.page-hero__bg img{width:100%;height:100%;object-fit:cover}
.page-hero__bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,25,18,0) 0%,rgba(15,25,18,.08) 35%,rgba(15,25,18,.58) 68%,rgba(15,25,18,.88) 100%);
}
.page-hero__content{position:relative;z-index:1;max-width:var(--max);margin:0 auto;padding:0 var(--gutter) clamp(48px,6vw,80px);width:100%}
.page-hero h1{color:var(--cream);max-width:18ch;font-weight:300;text-shadow:0 2px 16px rgba(0,0,0,.45)}
.page-hero__sub{text-shadow:0 1px 8px rgba(0,0,0,.35)}
.page-hero__sub strong{font-weight:700;color:#fff}
.page-hero .hero__eyebrow{color:var(--cream);text-shadow:0 1px 8px rgba(0,0,0,.6)}
.page-hero .hero__eyebrow::before{background:var(--cream)}
.page-hero__sub{margin-top:18px;max-width:60ch;color:rgba(245,240,225,.85);font-size:clamp(1.05rem,1.3vw,1.2rem);font-weight:300}

/* ---------- 8. Marquee strip ---------- */
.marquee{
  background:var(--green);color:var(--cream);
  padding:22px 0;overflow:hidden;border-bottom:1px solid var(--green-deep);
}
.marquee__track{display:flex;gap:64px;white-space:nowrap;animation:marquee 38s linear infinite}
.marquee__track span{font-family:var(--serif);font-style:italic;font-size:1.4rem;letter-spacing:.01em;display:inline-flex;align-items:center;gap:64px}
.marquee__track span::after{content:"✻";color:var(--gold);font-style:normal;margin-left:64px;font-size:1.1rem}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- 9. Story / split sections ---------- */
.story-img{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:4/5;
  box-shadow:0 1px 0 rgba(31,45,36,.06), 0 30px 60px -24px rgba(31,45,36,.35);
  border:1px solid rgba(31,45,36,.08);
}
.story-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.story-img:hover img{transform:scale(1.04)}
.story-img__caption{
  position:absolute;left:24px;bottom:24px;right:24px;color:var(--cream);
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  background:rgba(31,45,36,.6);padding:10px 14px;border-radius:6px;backdrop-filter:blur(6px);
}

/* signature */
.signature{
  font-family:var(--serif);font-style:italic;font-size:1.4rem;color:var(--green);
  margin-top:28px;display:inline-block;
}
.signature::before{content:""}

/* ---------- 10. Product cards ---------- */
.products{display:grid;gap:32px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.products--3up{grid-template-columns:repeat(3, minmax(0, 1fr))}
@media(max-width:900px){.products--3up{grid-template-columns:repeat(2, minmax(0, 1fr))}}
@media(max-width:560px){.products--3up{grid-template-columns:1fr}}
.product-card{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  background:var(--warm-white);
  border:1px solid rgba(31,45,36,.08);
  box-shadow:0 1px 0 rgba(31,45,36,.04), 0 12px 28px -20px rgba(31,45,36,.18);
  transition:transform .55s var(--ease),box-shadow .55s var(--ease),border-color .55s var(--ease);
  display:flex;flex-direction:column;
}
.product-card:hover{
  transform:translateY(-6px);
  border-color:rgba(31,45,36,.14);
  box-shadow:0 1px 0 rgba(31,45,36,.06), 0 32px 50px -22px rgba(31,45,36,.32);
}
.product-card__img{
  aspect-ratio:4/5;overflow:hidden;background:var(--green-deep);
  border-bottom:1px solid rgba(31,45,36,.08);
}
.product-card__img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.product-card:hover .product-card__img img{transform:scale(1.06)}
.product-card__body{padding:28px 28px 32px;display:flex;flex-direction:column;gap:8px;flex:1}
.product-card__cat{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep)}
.product-card__title{font-family:var(--serif);font-size:1.55rem;font-weight:500;color:var(--ink);line-height:1.15;margin-top:6px}
.product-card__copy{color:var(--graphite);font-size:15px;margin-top:8px;flex:1}
.product-card__link{margin-top:18px;font-family:var(--sans);font-size:14px;font-weight:600;color:var(--green);display:inline-flex;align-items:center;gap:8px}
.product-card__link .arrow{transition:transform .3s var(--ease)}
.product-card:hover .product-card__link .arrow{transform:translateX(4px)}

/* ---------- 11. Pillars / values ---------- */
.pillars{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.pillar{
  background:var(--warm-white);border:1px solid var(--line);
  padding:36px 32px;border-radius:var(--radius-lg);
  transition:transform .4s var(--ease),border-color .4s var(--ease);
}
.pillar:hover{transform:translateY(-4px);border-color:var(--green)}
.pillar__icon{width:44px;height:44px;color:var(--green);margin-bottom:20px}
.pillar h3{font-size:1.4rem;margin-bottom:10px}
.pillar p{font-size:15px;color:var(--graphite)}

/* ---------- 12. Pull quote ---------- */
.pullquote{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(1.6rem,3.4vw,2.6rem);line-height:1.25;
  color:var(--ink);max-width:24ch;letter-spacing:-.01em;
}
.pullquote::before{content:"\201C";display:block;font-size:4em;line-height:.4;color:var(--gold);margin-bottom:.2em}
.pullquote__attr{
  display:block;margin-top:24px;font-family:var(--sans);font-style:normal;
  font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--graphite);font-weight:600;
}

/* ---------- 13. Process / numbered steps ---------- */
.steps{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));counter-reset:step}
.step{
  background:var(--warm-white);padding:32px 28px 28px;border-radius:var(--radius-lg);
  border:1px solid var(--line);position:relative;counter-increment:step;
}
.step::before{
  content:counter(step,decimal-leading-zero);
  position:absolute;top:24px;right:28px;
  font-family:var(--serif);font-style:italic;font-size:2.6rem;color:var(--gold);line-height:1;
}
.step h3{font-size:1.25rem;margin-bottom:8px;padding-right:60px}
.step p{font-size:15px;color:var(--graphite)}

/* ---------- 14. Recipe cards ---------- */
.recipe-card{
  display:block;border-radius:var(--radius-lg);overflow:hidden;
  background:var(--warm-white);
  border:1px solid rgba(31,45,36,.08);
  box-shadow:0 1px 0 rgba(31,45,36,.04), 0 12px 28px -20px rgba(31,45,36,.18);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s var(--ease);
}
.recipe-card:hover{
  transform:translateY(-6px);
  border-color:rgba(31,45,36,.14);
  box-shadow:0 1px 0 rgba(31,45,36,.06), 0 32px 50px -22px rgba(31,45,36,.32);
}
.recipe-card__img{
  aspect-ratio:5/4;overflow:hidden;background:var(--green-deep);
  border-bottom:1px solid rgba(31,45,36,.08);
}
.recipe-card__img img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.recipe-card:hover .recipe-card__img img{transform:scale(1.05)}
.recipe-card__body{padding:24px 28px 32px}
.recipe-card__cat{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep)}
.recipe-card__title{font-family:var(--serif);font-size:1.6rem;font-weight:500;line-height:1.2;margin-top:8px;color:var(--ink)}
.recipe-card__meta{margin-top:14px;font-size:13px;color:var(--graphite);display:flex;gap:18px;font-family:var(--mono);letter-spacing:.05em}

/* ---------- 15. Newsletter ---------- */
.newsletter{
  background:var(--green-deep);color:var(--cream);
  padding:clamp(72px,9vw,120px) 0;position:relative;overflow:hidden;
}
.newsletter::before{
  content:"";position:absolute;top:-100px;right:-100px;width:400px;height:400px;
  border-radius:50%;background:radial-gradient(circle,rgba(212,166,66,.15) 0%,transparent 70%);
}
.newsletter h2{color:var(--cream);max-width:18ch}
.newsletter .lead{color:rgba(245,240,225,.8)}
.newsletter form{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px;max-width:520px}
.newsletter input{
  flex:1;min-width:240px;padding:18px 22px;border-radius:999px;
  background:rgba(245,240,225,.08);color:var(--cream);font-size:15px;
  border:1px solid rgba(245,240,225,.2);
  font-family:var(--sans);transition:border-color .3s,background .3s;
}
.newsletter input::placeholder{color:rgba(245,240,225,.5)}
.newsletter input:focus{outline:none;border-color:var(--gold);background:rgba(245,240,225,.12)}
.newsletter form button{flex-shrink:0}
.newsletter__note{margin-top:14px;font-size:12px;color:rgba(245,240,225,.6);font-family:var(--mono);letter-spacing:.04em}

/* ---------- 16. Footer ---------- */
.footer{
  background:var(--ink);color:rgba(245,240,225,.78);
  padding:clamp(64px,7vw,96px) 0 32px;font-size:14px;
}
.footer__grid{display:grid;gap:48px;grid-template-columns:1.4fr 1fr 1fr 1fr}
@media(max-width:860px){.footer__grid{grid-template-columns:1fr 1fr;gap:36px}}
@media(max-width:520px){.footer__grid{grid-template-columns:1fr}}
.footer h4{color:var(--cream);font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px}
.footer ul{display:flex;flex-direction:column;gap:10px}
.footer a{color:rgba(245,240,225,.78);transition:color .25s}
.footer a:hover{color:var(--gold)}
.footer__brand .brand{color:var(--cream)}
.footer__brand .brand__sub{color:var(--gold)}
.footer__brand p{margin-top:18px;font-size:14px;color:rgba(245,240,225,.7);max-width:34ch;line-height:1.65}
.footer__bottom{
  margin-top:64px;padding-top:24px;
  border-top:1px solid rgba(245,240,225,.12);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:12px;color:rgba(245,240,225,.5);font-family:var(--mono);letter-spacing:.04em;
}
.footer__social{display:flex;gap:14px;margin-top:18px}
.footer__social a{
  width:40px;height:40px;border:1px solid rgba(245,240,225,.2);border-radius:50%;
  display:flex;align-items:center;justify-content:center;transition:all .3s var(--ease);
}
.footer__social a:hover{background:var(--gold);border-color:var(--gold);color:var(--ink);transform:translateY(-2px)}
.footer__social svg{width:16px;height:16px}

/* ---------- 17. About / long form ---------- */
.long-form{max-width:740px;margin:0 auto;font-size:18px;line-height:1.75}
.long-form p{max-width:none;margin-bottom:1.4em;color:var(--graphite)}
.long-form p:first-of-type{font-size:1.2em;color:var(--ink)}
.long-form h2{margin-top:2em;margin-bottom:.5em}
.long-form h3{margin-top:2em;margin-bottom:.4em;font-size:1.4rem}

.kpi-row{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin:48px 0}
.kpi{padding:24px;border-left:2px solid var(--gold)}
.kpi__num{font-family:var(--serif);font-size:3.2rem;font-weight:400;color:var(--green);line-height:1}
.kpi__label{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--graphite);margin-top:8px}

/* ---------- 18. Contact / forms ---------- */
.contact-grid{display:grid;gap:64px;grid-template-columns:1.1fr .9fr;align-items:start}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr;gap:40px}}
.contact-info{padding:40px;background:var(--warm-white);border-radius:var(--radius-lg);border:1px solid var(--line)}
.contact-info h3{margin-bottom:8px;font-size:1.5rem}
.contact-info dl{display:grid;grid-template-columns:120px 1fr;gap:14px 16px;margin-top:24px;font-size:15px}
.contact-info dt{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--graphite);padding-top:4px}
.contact-info dd{color:var(--ink)}
.contact-info dd a{color:var(--green);border-bottom:1px solid currentColor;padding-bottom:1px}

.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.form-row label{font-family:var(--sans);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--graphite);font-weight:600}
.form-row input,.form-row textarea,.form-row select{
  padding:14px 16px;border:1px solid var(--line);border-radius:8px;
  background:var(--warm-white);font-family:var(--sans);font-size:15px;color:var(--ink);
  transition:border-color .3s,box-shadow .3s;
}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{
  outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(46,93,58,.12);
}
.form-row textarea{min-height:140px;resize:vertical}
.form-row--inline{flex-direction:row;align-items:center;gap:10px}
.form-row--inline input{margin:0}

/* ---------- 19. Recipe page ---------- */
.recipe-hero{
  display:grid;grid-template-columns:1fr 1fr;gap:0;min-height:75vh;
}
@media(max-width:860px){.recipe-hero{grid-template-columns:1fr}}
.recipe-hero__img{position:relative;overflow:hidden;background:var(--green-deep)}
.recipe-hero__img img{width:100%;height:100%;object-fit:cover}
.recipe-hero__body{padding:clamp(48px,7vw,96px) clamp(32px,6vw,80px);display:flex;flex-direction:column;justify-content:center;background:var(--warm-white)}
.recipe-hero__body h1{font-size:clamp(2.2rem,4.5vw,4rem)}
.recipe-meta{display:flex;flex-wrap:wrap;gap:32px;margin:32px 0;padding-top:24px;border-top:1px solid var(--line)}
.recipe-meta__item{font-size:13px}
.recipe-meta__label{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--graphite)}
.recipe-meta__val{font-family:var(--serif);font-size:1.4rem;color:var(--ink);margin-top:4px}

.recipe-body{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:start}
@media(max-width:860px){.recipe-body{grid-template-columns:1fr;gap:32px}}
.recipe-body h3{font-size:1.3rem;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.ingredients{position:sticky;top:96px}
.ingredients ul{display:flex;flex-direction:column;gap:14px}
.ingredients li{display:flex;gap:12px;font-size:15px;color:var(--graphite);padding-bottom:14px;border-bottom:1px solid var(--line)}
.ingredients li strong{color:var(--ink);min-width:80px;font-family:var(--mono);font-size:13px;letter-spacing:.04em}
.method ol{display:flex;flex-direction:column;gap:24px;counter-reset:m}
.method li{counter-increment:m;display:grid;grid-template-columns:48px 1fr;gap:18px;align-items:start;font-size:16px;line-height:1.7;color:var(--graphite)}
.method li::before{
  content:counter(m,decimal-leading-zero);
  font-family:var(--serif);font-style:italic;font-size:1.6rem;color:var(--gold);line-height:1;padding-top:6px;
}

/* ---------- 20. FAQ ---------- */
.faq{display:flex;flex-direction:column;gap:0}
.faq details{border-bottom:1px solid var(--line);padding:24px 0}
.faq details:first-child{border-top:1px solid var(--line)}
.faq summary{
  list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:24px;
  font-family:var(--serif);font-size:1.3rem;font-weight:500;color:var(--ink);
  transition:color .25s;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary:hover{color:var(--green)}
.faq summary::after{content:"+";font-family:var(--sans);font-weight:300;font-size:1.6rem;color:var(--green);transition:transform .3s var(--ease)}
.faq details[open] summary::after{content:"";transform:rotate(45deg);background:var(--green);width:14px;height:2px;display:block}
.faq details[open] summary{color:var(--green)}
.faq__answer{margin-top:14px;color:var(--graphite);max-width:70ch;line-height:1.7}

/* ---------- 21. Reveal animation ---------- */
.js .reveal{opacity:0;transform:translateY(24px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.js .reveal.in{opacity:1;transform:none}
.reveal-d1{transition-delay:.1s}
.reveal-d2{transition-delay:.2s}
.reveal-d3{transition-delay:.3s}

/* ---------- 22. Utility ---------- */
.divider{height:1px;background:var(--line);margin:0;border:0}
.divider--gold{height:2px;width:60px;background:var(--gold);border:0;margin:0 0 24px}
.tag{display:inline-block;padding:6px 12px;background:rgba(46,93,58,.1);color:var(--green);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;border-radius:999px}

/* selection */
::selection{background:var(--gold);color:var(--ink)}

/* ---------- 23. Skip to content (accessibility) ---------- */
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:200;
  background:var(--gold);color:var(--ink);
  padding:14px 22px;border-radius:0 0 8px 0;
  font-family:var(--sans);font-weight:700;font-size:14px;letter-spacing:.04em;
  text-decoration:none;
}
.skip-link:focus{left:0;outline:2px solid var(--green-deep);outline-offset:2px}

/* ---------- 24. Focus states (accessibility) ---------- */
:focus-visible{
  outline:2px solid var(--green);
  outline-offset:3px;
  border-radius:4px;
}
.btn:focus-visible,.lp-btn:focus-visible{outline-color:var(--gold);outline-offset:4px}
.section--ink :focus-visible,.hero :focus-visible,.lp-hero :focus-visible{outline-color:var(--gold)}

/* ---------- 25. Reduced motion (accessibility) ---------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .hero__bg img,.lp-hero__bg img{animation:none !important;transform:none !important}
  .reveal{opacity:1 !important;transform:none !important}
  .marquee__track{animation:none !important}
  .banner__pulse::after,.lp-bar__pulse::after{animation:none !important}
  .hero__scroll-line::after{animation:none !important}
}

/* ---------- 26. Print styles ---------- */
@media print{
  .nav,.banner,.lp-bar,.lp-sticky,.footer__social,.newsletter form,form,iframe,.hero__scroll,.hero__meta{display:none !important}
  body{background:#fff;color:#000;font-size:12pt}
  .hero,.page-hero,.lp-hero{min-height:auto;padding:24pt 0;color:#000}
  .hero__bg,.page-hero__bg,.lp-hero__bg{display:none}
  .hero h1,.page-hero h1,.lp-hero h1{color:#000}
  .section--ink{background:#fff;color:#000}
  .section--ink h2,.section--ink h3{color:#000}
  a{color:#000;text-decoration:underline}
  a[href^="http"]::after{content:" (" attr(href) ")";font-size:10pt;color:#666}
  .product-card,.recipe-card,.pillar,.step,.lp-cut,.lp-step,.lp-product{break-inside:avoid;page-break-inside:avoid}
  h1,h2,h3{break-after:avoid;page-break-after:avoid}
  img{max-width:100%;page-break-inside:avoid}
}

/* ---------- 27. Image loading polish ---------- */
img{background-color:rgba(46,93,58,.05)}
.js img[loading="lazy"]:not([data-loaded="true"]){opacity:0;transition:opacity .6s ease}
.js img[loading="lazy"][data-loaded="true"]{opacity:1}

/* ---------- 28. Form polish ---------- */
button:disabled,input:disabled,select:disabled,textarea:disabled{
  opacity:.6;cursor:not-allowed;
}

/* ---------- 29. Smooth-scroll respect ---------- */
@supports (scroll-padding-top: 100px){
  html{scroll-padding-top:100px}
}
