:root{
  --bg:#faf9f7; --band:#f1efe9; --ink:#1a1917; --soft:#55524d; --faint:#8b8782;
  --accent:#d11f26; --accent2:#e8443f; --line:#e6e3dd; --card:#ffffff;
  --display:"Anton",system-ui,sans-serif; --body:"Archivo",system-ui,sans-serif; --script:"Caveat",cursive;
  --container:min(92%,1680px); --read:min(92%,1180px);
  --radius:14px; --radius-sm:9px;
  --shadow:0 1px 2px rgba(40,30,20,.05),0 10px 26px -14px rgba(40,30,20,.18);
  --shadow-sm:0 6px 16px -12px rgba(40,30,20,.28);
  --band-ink:var(--ink); --band-soft:var(--soft);
  --strip:#161514; --strip-ink:#ffffff;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
html,body{max-width:100%;overflow-x:hidden}
body{background:var(--bg);color:var(--ink);font-family:var(--body);line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{width:var(--container);margin-inline:auto}
.read{width:var(--read);margin-inline:auto}
.eyebrow{font-family:var(--body);font-weight:700;text-transform:uppercase;letter-spacing:.16em;
  font-size:.74rem;color:var(--accent)}
.script{font-family:var(--script);color:var(--accent);font-weight:600}

/* ---- top bar (non-sticky) ---- */
.topbar{background:var(--strip);border-bottom:1px solid var(--line)}
.topbar.dark{background:var(--strip);border-bottom:none}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:14px;
  min-height:40px;padding-block:7px;flex-wrap:wrap}
.topbar .promo{font-size:.78rem;font-weight:600;letter-spacing:.04em;color:var(--strip-ink)}
.topbar .socials{display:flex;gap:13px}
.topbar .socials a{width:22px;height:22px;display:grid;place-items:center;color:var(--strip-ink);opacity:.8}
.topbar .socials a:hover{opacity:1}
.topbar .socials svg{width:15px;height:15px;fill:currentColor}

/* ---- masthead / header (non-sticky) ---- */
.head{background:var(--bg);border-bottom:1px solid var(--line)}
.head .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;
  min-height:80px;padding-block:16px;flex-wrap:wrap}
.brand{font-family:var(--display);text-transform:uppercase;letter-spacing:.04em;font-weight:700;color:var(--ink);
  font-size:clamp(1.45rem,3.2vw,2.05rem);line-height:1;min-width:0}
.brand b{color:var(--accent);font-weight:inherit}
.brand.center{text-align:center;width:100%}
nav.mainnav{display:flex;align-items:center;gap:clamp(14px,2.2vw,26px);flex-wrap:wrap}
nav.mainnav a{font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;
  color:var(--soft);padding-block:5px;position:relative;transition:color .15s}
nav.mainnav a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;
  background:var(--accent);transition:right .22s ease}
nav.mainnav a:hover{color:var(--ink)}
nav.mainnav a:hover::after{right:0}
@media(max-width:680px){nav.mainnav a:not(.keep){display:none} .head .wrap{justify-content:center}}

/* ---- hero variants ---- */
.masthead{position:relative;min-height:clamp(340px,52vw,560px);display:grid;place-items:center;
  text-align:center;overflow:hidden;background:var(--band)}
.masthead img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.masthead::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,15,12,.18),rgba(20,15,12,.52))}
.masthead .inner{position:relative;z-index:2;color:#fff;padding:2rem 1.2rem;width:min(92%,900px)}
.masthead .kick{font-family:var(--body);font-weight:700;text-transform:uppercase;
  letter-spacing:.22em;font-size:.78rem;color:#fff;opacity:.92;margin-bottom:.9rem}
.masthead h1{font-family:var(--display);font-weight:800;
  font-size:clamp(2.4rem,7vw,5rem);line-height:1.02;letter-spacing:-.01em;
  text-shadow:0 2px 22px rgba(0,0,0,.32)}
.masthead p.tag{margin-top:1rem;font-size:clamp(1.02rem,2vw,1.3rem);color:#fff;opacity:.95}
.masthead .scroll{margin-top:1.6rem;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;opacity:.85}

.hero-strip{background:var(--band);padding-block:clamp(2rem,4.5vw,3.4rem)}
.hero-strip .inner{text-align:center;width:min(92%,820px);margin-inline:auto;color:var(--band-ink)}
.hero-strip h1{font-family:var(--display);font-weight:800;font-size:clamp(2rem,5vw,3.4rem);
  line-height:1.05;letter-spacing:-.01em}
.hero-strip p{margin-top:.8rem;font-size:clamp(1rem,2vw,1.22rem);color:var(--band-soft)}

.intro{padding-block:clamp(1.8rem,3.4vw,2.8rem);text-align:center}
.intro .kick{margin-bottom:.7rem}
.intro p{font-family:var(--display);font-size:clamp(1.15rem,2.4vw,1.65rem);line-height:1.4;
  color:var(--ink);width:min(92%,760px);margin-inline:auto;font-weight:500}
.intro p em{color:var(--accent);font-style:italic}

/* ---- featured split ---- */
.feature{padding-block:clamp(1.6rem,3.4vw,3rem)}
.feature .split{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow);display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr));align-items:stretch}
.feature .ph{position:relative;min-height:300px;background:var(--band)}
.feature .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.feature .cp{padding:clamp(1.6rem,3.4vw,3rem);display:flex;flex-direction:column;
  justify-content:center;gap:1rem}
.feature h2{font-family:var(--display);font-weight:700;font-size:clamp(1.7rem,3.6vw,2.6rem);
  line-height:1.1;letter-spacing:-.01em;max-width:16ch}
.feature .dek{color:var(--soft);font-size:1.04rem;max-width:42ch}
.feature .ml{display:flex;flex-wrap:wrap;gap:.5rem 1.1rem;font-size:.82rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.08em;color:var(--faint)}

/* ---- lead + minis (archetype A) ---- */
.loving{padding-block:clamp(1.6rem,3.4vw,3rem)}
.feat-grid{display:grid;gap:clamp(1rem,2vw,1.6rem);
  grid-template-columns:repeat(auto-fit,minmax(min(100%,340px),1fr))}
.feat-lead{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .2s}
.feat-lead:hover{transform:translateY(-4px)}
.feat-lead .m{position:relative;aspect-ratio:16/10;background:var(--band)}
.feat-lead .m img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.feat-lead .b{padding:1.3rem 1.4rem 1.5rem;display:flex;flex-direction:column;gap:.5rem}
.feat-lead h3{font-family:var(--display);font-weight:700;font-size:clamp(1.4rem,2.8vw,1.9rem);
  line-height:1.14}
.feat-lead .dek{color:var(--soft);font-size:.98rem}
.feat-side{display:flex;flex-direction:column;gap:clamp(1rem,2vw,1.6rem)}
.feat-mini{display:grid;grid-template-columns:minmax(0,116px) 1fr;gap:1rem;align-items:center;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius-sm);
  overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .18s;flex:1}
.feat-mini:hover{transform:translateY(-3px)}
.feat-mini .m{position:relative;align-self:stretch;min-height:104px;background:var(--band)}
.feat-mini .m img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.feat-mini .b{padding:.7rem .9rem .7rem 0;min-width:0}
.feat-mini h4{font-family:var(--display);font-weight:700;font-size:1.08rem;line-height:1.16}
.feat-mini .dek{color:var(--soft);font-size:.86rem;margin-top:.2rem;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ---- section heads ---- */
.section{padding-block:clamp(1.8rem,4vw,3.2rem)}
.section.band{background:var(--band)}
.section.band.dark{color:#fff}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;
  flex-wrap:wrap;margin-bottom:1.2rem}
.sec-head h2{font-family:var(--display);font-weight:700;font-size:clamp(1.5rem,3.2vw,2.2rem);
  letter-spacing:-.01em;position:relative;padding-left:.8rem}
.sec-head h2::before{content:"";position:absolute;left:0;top:.18em;bottom:.18em;width:5px;
  border-radius:3px;background:linear-gradient(180deg,var(--accent),var(--accent2))}
.sec-head .meta{font-size:.86rem;color:var(--faint)}
.sec-head.center{justify-content:center;text-align:center;flex-direction:column;align-items:center;gap:.4rem}
.sec-head.center h2{padding-left:0}
.sec-head.center h2::before{display:none}

/* ---- category rail ---- */
.cats{display:grid;gap:clamp(.8rem,1.6vw,1.3rem);
  grid-template-columns:repeat(auto-fill,minmax(min(100%,180px),1fr))}
.cat{position:relative;aspect-ratio:4/3;border-radius:var(--radius-sm);overflow:hidden;
  box-shadow:var(--shadow-sm);display:grid;place-items:center;transition:transform .2s}
.cat img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s}
.cat::after{content:"";position:absolute;inset:0;background:rgba(25,18,14,.28)}
.cat:hover{transform:translateY(-3px)}
.cat:hover img{transform:scale(1.06)}
.cat .lab{position:relative;z-index:2;color:#fff;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;font-size:.84rem;text-shadow:0 2px 10px rgba(0,0,0,.5)}

/* ---- filters ---- */
.filters{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:1.4rem}
.filter{font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:.74rem;
  color:var(--soft);background:var(--card);border:1.5px solid var(--line);border-radius:999px;
  padding:.5rem 1rem;cursor:pointer;transition:all .15s}
.filter:hover{border-color:var(--accent)}
.filter[aria-pressed="true"]{background:var(--accent);border-color:var(--accent);color:#fff}

/* ---- search band ---- */
.searchband{background:var(--band);padding-block:clamp(1.8rem,3.6vw,2.8rem)}
.searchband h2{font-family:var(--display);text-align:center;font-weight:700;
  font-size:clamp(1.3rem,2.8vw,1.9rem);margin-bottom:1rem;color:var(--band-ink)}
.search-field{display:flex;align-items:center;background:#fff;border:1px solid var(--line);
  border-radius:999px;padding:.35rem .35rem .35rem 1.1rem;width:min(100%,460px);margin-inline:auto;
  box-shadow:var(--shadow-sm)}
.search-field input{border:0;outline:0;background:transparent;font-family:var(--body);font-size:1rem;
  color:var(--ink);flex:1;min-width:0;padding-block:.55rem}
.search-field input::placeholder{color:var(--faint)}
.search-field button{width:42px;height:42px;border-radius:50%;border:0;flex:none;background:var(--accent);
  color:#fff;cursor:pointer;display:grid;place-items:center;transition:background .15s}
.search-field button:hover{background:var(--accent2)}
.search-field button svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2.4}

/* ---- recipe card grid ---- */
.grid{display:grid;gap:clamp(1rem,2vw,1.7rem);
  grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr))}
.card{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .2s ease,box-shadow .2s ease;height:100%}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.card .m{position:relative;aspect-ratio:4/3;background:var(--band);overflow:hidden}
.card .m img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s}
.card:hover .m img{transform:scale(1.05)}
.card .tag{position:absolute;left:11px;top:11px;z-index:2;background:#fff;color:var(--accent);
  font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.66rem;
  padding:.3rem .65rem;border-radius:999px;box-shadow:0 3px 10px -4px rgba(0,0,0,.35)}
.card .b{padding:1rem 1.1rem 1.2rem;display:flex;flex-direction:column;gap:.45rem;flex:1}
.card .k{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent)}
.card h3{font-family:var(--display);font-weight:700;font-size:1.24rem;line-height:1.18;letter-spacing:-.005em}
.card .dek{color:var(--soft);font-size:.9rem;line-height:1.45;flex:1}
.card .meta{display:flex;flex-wrap:wrap;gap:.4rem .9rem;margin-top:.3rem;padding-top:.7rem;
  border-top:1px solid var(--line);font-size:.74rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.06em;color:var(--faint)}
.empty{grid-column:1/-1;text-align:center;padding:3.5rem 1rem;color:var(--faint);
  font-family:var(--display);font-style:italic;font-size:1.25rem}

/* ---- newsletter ---- */
.nl{background:var(--band);padding-block:clamp(2rem,4.5vw,3.4rem);text-align:center}
.nl h2{font-family:var(--display);font-weight:700;font-size:clamp(1.6rem,3.4vw,2.4rem);
  margin:.4rem auto .5rem;max-width:20ch;color:var(--band-ink)}
.nl p{color:var(--band-soft);max-width:46ch;margin:0 auto 1.4rem}

/* ---- footer ---- */
footer.site{background:var(--ink);color:#fff;padding-block:clamp(2rem,4vw,3rem);text-align:center}
footer.site .mark{font-family:var(--display);font-weight:700;font-size:clamp(1.3rem,2.6vw,1.8rem)}
footer.site .tag{font-family:var(--script);font-size:1.4rem;color:#fff;opacity:.85;margin:.2rem 0 .8rem}
footer.site .line{color:rgba(255,255,255,.6);font-size:.86rem}

/* ===================== RECIPE PAGE ===================== */
.r-hero{display:grid;gap:clamp(1.4rem,3vw,2.6rem);align-items:center;
  grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr));
  padding-block:clamp(1.8rem,3.6vw,3rem)}
.r-hero .m{position:relative;aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);background:var(--band)}
.r-hero .m img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.r-back{display:inline-block;font-weight:600;font-size:.82rem;color:var(--accent);margin-bottom:.6rem}
.r-title{font-family:var(--display);font-weight:800;font-size:clamp(2rem,4.6vw,3.2rem);
  line-height:1.06;letter-spacing:-.01em;margin:.2rem 0 .6rem}
.r-dek{color:var(--soft);font-size:1.08rem;max-width:46ch}
.r-meta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.2rem}
.r-meta .item{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:.6rem .9rem;min-width:84px}
.r-meta .k{display:block;font-size:.68rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--faint)}
.r-meta .v{display:block;font-family:var(--display);font-weight:700;font-size:1.05rem;margin-top:.15rem}
.r-body{display:grid;gap:clamp(1.6rem,3vw,3rem);
  grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr));
  padding-bottom:clamp(2rem,4vw,3.4rem);align-items:start}
.ingredients{background:var(--band);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(1.3rem,2.4vw,1.8rem)}
.r-sectiontitle{font-family:var(--display);font-weight:700;font-size:1.4rem;margin-bottom:1rem;
  padding-bottom:.5rem;border-bottom:2px solid var(--accent);display:inline-block}
.ing-group{margin-bottom:1rem}
.ing-group .name{font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--accent);margin-bottom:.4rem}
.ing-list{list-style:none;display:flex;flex-direction:column;gap:.55rem}
.ing-list li{display:grid;grid-template-columns:auto 1fr;gap:.6rem;align-items:baseline;
  padding-bottom:.55rem;border-bottom:1px dashed var(--line)}
.ing-qty{font-weight:700;color:var(--ink);white-space:nowrap}
.ing-item{color:var(--soft)}
.dir-list{list-style:none;counter-reset:step;display:flex;flex-direction:column;gap:1.1rem}
.dir-list li{counter-increment:step;position:relative;padding-left:3rem;color:var(--ink);font-size:1.02rem}
.dir-list li::before{content:counter(step);position:absolute;left:0;top:-.1rem;width:2rem;height:2rem;
  border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;
  font-family:var(--display);font-weight:700;font-size:.95rem}
.r-notes{background:var(--band);border-left:4px solid var(--accent);border-radius:var(--radius-sm);
  padding:1rem 1.2rem;margin-top:1.6rem}
.r-notes .label{font-weight:700;font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent)}
.r-notes p{margin-top:.4rem;color:var(--soft)}
.r-source{margin-top:1.4rem;font-size:.9rem;color:var(--faint)}
.r-source a{color:var(--accent);font-weight:600}

/* nutrition hook — consistent across ALL styles for the future ring component */
.nutrition{margin-top:1.6rem;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);padding:clamp(1.2rem,2.4vw,1.6rem)}
.nutrition .n-head{font-family:var(--display);font-weight:700;font-size:1.15rem;margin-bottom:.2rem}
.nutrition .n-sub{font-size:.78rem;color:var(--faint);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.9rem}
.nutrition .n-grid{display:grid;gap:.7rem;grid-template-columns:repeat(auto-fill,minmax(min(100%,120px),1fr))}
.nutrition .n-cell{background:var(--band);border-radius:var(--radius-sm);padding:.7rem .8rem;text-align:center}
.nutrition .n-val{font-family:var(--display);font-weight:700;font-size:1.3rem;color:var(--accent);line-height:1}
.nutrition .n-lab{font-size:.7rem;text-transform:uppercase;letter-spacing:.07em;color:var(--faint);margin-top:.3rem}
.nutrition .n-empty{color:var(--faint);font-size:.92rem}

.r-more{padding-block:clamp(1.8rem,3.6vw,3rem)}

@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}
  .card:hover,.feat-lead:hover,.feat-mini:hover,.cat:hover{transform:none}}
