/* ============================================================
   Red Lionale -- "Culinary Almanac" design system
   Heraldic green + gold + claret. Circular specimen plates,
   newspaper ledger index, typographic directory. ASCII-only.
   ============================================================ */
:root{
  --green:#143A2B; --green-deep:#0E2A20; --green-soft:#23503D;
  --gold:#C9A227; --gold-deep:#94701A;
  --claret:#7A1E1E; --claret-deep:#5C1414;
  --bone:#F4EFE3; --bone-2:#E9E0CC; --paper:#FCF9F1;
  --ink:#1C1B15; --ink-soft:#544e3f; --line:#D6CBB0; --line-soft:#E2D8C2;
  --tomato:#B53A2B;
  --maxw:1200px;
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --mono:"Spline Sans Mono",ui-monospace,"Courier New",monospace;
  --sans:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html,body{ overflow-x:hidden; max-width:100vw; }
html{ scroll-behavior:smooth; }
body{ font-family:var(--sans); color:var(--ink); background:var(--bone); line-height:1.62; -webkit-font-smoothing:antialiased; counter-reset:faqc; }
img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{ font-family:var(--serif); font-weight:600; line-height:1.05; color:var(--ink); letter-spacing:-.012em; }
.skip-link{ position:absolute; left:-999px; top:0; background:var(--green); color:#fff; padding:10px 16px; z-index:300; }
.skip-link:focus{ left:0; }
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.eyebrow{ font-family:var(--mono); font-weight:500; letter-spacing:.22em; text-transform:uppercase; font-size:.68rem; color:var(--gold-deep); }
.lede{ font-size:1.16rem; color:var(--ink-soft); }
.center{ text-align:center; } .muted{ color:var(--ink-soft); } .maxw-prose{ max-width:70ch; }

/* buttons */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:.5em; font-family:var(--mono); font-weight:500; font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; padding:14px 26px; border:1.5px solid transparent; border-radius:999px; cursor:pointer; transition:transform .12s, background .2s, color .2s, border-color .2s; }
.btn:active{ transform:translateY(1px); }
.btn-primary{ background:var(--green); color:#F4EFE3; }
.btn-primary:hover{ background:var(--green-deep); }
.btn-gold{ background:var(--gold); color:#241B02; }
.btn-gold:hover{ background:var(--gold-deep); color:#fff; }
.btn-outline{ border-color:var(--green); color:var(--green); background:transparent; }
.btn-outline:hover{ background:var(--green); color:#F4EFE3; }
.btn-ghost{ border-color:var(--line); color:var(--ink); background:var(--paper); }
.btn-ghost:hover{ border-color:var(--green); color:var(--green); }
.btn-sm{ padding:9px 16px; font-size:.68rem; } .btn-block{ width:100%; } .btn-lg{ padding:16px 30px; font-size:.82rem; }

/* ---- MASTHEAD: claret folio strip + centered crest + ruled nav ---- */
.util-bar{ background:var(--green-deep); color:#D9CBA0; font-family:var(--mono); font-size:.68rem; letter-spacing:.08em; }
.util-inner{ max-width:var(--maxw); margin:0 auto; padding:7px 28px; display:flex; justify-content:space-between; align-items:center; gap:16px; }
.util-tag{ text-transform:uppercase; letter-spacing:.16em; opacity:.92; }
.util-links{ display:flex; gap:20px; } .util-links a{ color:#E4D5A8; } .util-links a:hover{ color:#fff; }
.masthead{ position:sticky; top:0; z-index:100; background:rgba(244,239,227,.95); backdrop-filter:saturate(140%) blur(8px); -webkit-backdrop-filter:saturate(140%) blur(8px); border-bottom:2px solid var(--green); }
.masthead.scrolled{ box-shadow:0 6px 0 -4px rgba(20,58,43,.16); }
.masthead-inner{ max-width:var(--maxw); margin:0 auto; padding:16px 28px 12px; display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:14px; }
.brand{ grid-column:2; display:flex; align-items:center; gap:13px; justify-self:center; }
.crest{ display:block; flex:0 0 auto; }
.brand-words{ display:flex; flex-direction:column; line-height:1; text-align:center; }
.brand-name{ font-family:var(--serif); font-weight:700; font-size:1.7rem; color:var(--green); letter-spacing:.01em; }
.brand-sub{ font-family:var(--mono); font-size:.58rem; letter-spacing:.28em; text-transform:uppercase; color:var(--gold-deep); margin-top:5px; }
.masthead-actions{ grid-column:3; justify-self:end; display:flex; align-items:center; gap:6px; }
.cart-btn{ position:relative; width:44px; height:44px; display:grid; place-items:center; color:var(--green); border-radius:50%; }
.cart-btn:hover{ background:rgba(20,58,43,.08); }
.cart-count{ position:absolute; top:2px; right:0; min-width:18px; height:18px; padding:0 4px; background:var(--claret); color:#fff; font-family:var(--mono); font-size:.6rem; border-radius:999px; display:grid; place-items:center; border:2px solid var(--bone); }
.nav-toggle{ grid-column:1; justify-self:start; display:none; width:42px; height:42px; background:transparent; border:1.5px solid var(--green); border-radius:50%; cursor:pointer; flex-direction:column; gap:5px; align-items:center; justify-content:center; }
.nav-toggle span{ width:18px; height:2px; background:var(--green); }
.rule-nav{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:rgba(20,58,43,.03); }
.rule-nav ul{ max-width:var(--maxw); margin:0 auto; padding:0 28px; list-style:none; display:flex; flex-wrap:wrap; align-items:center; justify-content:center; }
.rule-nav li{ display:inline-flex; align-items:center; }
.rule-nav li + li::before{ content:"\2666"; color:var(--gold); font-size:.5rem; }
.rule-nav a{ display:inline-block; padding:11px 24px; font-family:var(--mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink); }
.rule-nav a:hover,.rule-nav a.is-active{ color:var(--claret); }

.drawer{ position:fixed; inset:0; z-index:200; visibility:hidden; } .drawer.open{ visibility:visible; }
.drawer-scrim{ position:absolute; inset:0; background:rgba(14,42,32,.6); opacity:0; transition:opacity .25s; } .drawer.open .drawer-scrim{ opacity:1; }
.drawer-panel{ position:absolute; top:0; right:0; height:100%; width:min(84vw,330px); background:var(--bone); border-left:4px solid var(--gold); padding:34px 28px; transform:translateX(100%); transition:transform .28s cubic-bezier(.4,0,.2,1); }
.drawer.open .drawer-panel{ transform:translateX(0); }
.drawer-close{ position:absolute; top:16px; right:20px; font-size:2rem; background:none; border:0; cursor:pointer; color:var(--green); }
.drawer-kicker{ font-family:var(--mono); font-size:.64rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-deep); margin:8px 0 18px; }
.drawer nav ul{ list-style:none; display:flex; flex-direction:column; }
.drawer nav a{ display:block; padding:13px 4px; font-family:var(--serif); font-size:1.3rem; border-bottom:1px solid var(--line); } .drawer nav a:hover{ color:var(--claret); }

/* ---- generic section + heading ---- */
.section{ padding:74px 0; } .section-tight{ padding:46px 0; }
.section-head{ margin-bottom:34px; } .section-head.center{ text-align:center; }
.section-head h2{ font-size:clamp(1.9rem,4vw,3rem); margin:8px 0 0; }
.section-head .eyebrow{ display:inline-block; }
.rule-gold{ height:2px; background:var(--gold); width:100%; margin-top:14px; position:relative; }
.section-head:not(.center) .rule-gold::before{ content:""; position:absolute; left:0; top:-1px; width:60px; height:4px; background:var(--claret); }
.center .rule-gold{ max-width:180px; margin:14px auto 0; }
.pill{ display:inline-flex; align-items:center; gap:6px; padding:5px 12px; border-radius:999px; font-family:var(--mono); font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; }
.pill-gold{ background:rgba(201,162,39,.18); color:var(--gold-deep); border:1px solid rgba(201,162,39,.45); }
.pill-crimson{ background:var(--claret); color:#F1E3CB; } .pill-lock{ background:var(--claret); color:#F1E3CB; }
.pill-olive{ background:rgba(20,58,43,.1); color:var(--green); border:1px solid rgba(20,58,43,.3); }
.tag-row{ display:flex; flex-wrap:wrap; gap:8px; }

/* ============================================================
   ALMANAC COVER HERO (full-bleed, centered, issue ribbon)
   ============================================================ */
.cover{ position:relative; min-height:80vh; display:grid; align-items:center; border-bottom:3px solid var(--gold); }
.cover-bg{ position:absolute; inset:0; } .cover-bg img{ width:100%; height:100%; object-fit:cover; }
.cover-veil{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(14,42,32,.82),rgba(11,30,24,.72)); }
.cover-inner{ position:relative; max-width:920px; margin:0 auto; padding:70px 28px; text-align:center; color:var(--bone); }
.cover-folio{ font-family:var(--mono); font-size:.7rem; letter-spacing:.34em; text-transform:uppercase; color:var(--gold); display:flex; gap:16px; justify-content:center; align-items:center; flex-wrap:wrap; }
.cover-folio span{ display:inline-flex; align-items:center; gap:16px; } .cover-folio span::after{ content:"\2666"; color:rgba(244,239,227,.5); }
.cover-folio span:last-child::after{ display:none; }
.cover-title{ color:#fff; font-size:clamp(2.8rem,7vw,5.6rem); line-height:.98; margin:22px 0 18px; }
.cover-title em{ font-style:italic; color:var(--gold); }
.cover-stand{ font-family:var(--serif); font-style:italic; font-size:1.3rem; color:#EFE6D2; max-width:30ch; margin:0 auto 30px; }
.cover-cta{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.cover-issue{ position:relative; border-top:1px solid rgba(244,239,227,.28); margin-top:40px; padding-top:18px; display:flex; gap:10px 26px; justify-content:center; flex-wrap:wrap; font-family:var(--mono); font-size:.7rem; letter-spacing:.08em; text-transform:uppercase; color:#E9DEC6; }
.cover-issue a:hover{ color:var(--gold); } .cover-issue b{ color:var(--gold); margin-right:8px; }

/* ============================================================
   LEDGER INDEX (newspaper contents -- typographic, no cards)
   ============================================================ */
.ledger{ background:var(--paper); border:1.5px solid var(--green); border-top:5px solid var(--green); }
.ledger-cap{ display:flex; justify-content:space-between; align-items:baseline; padding:18px 24px; border-bottom:1px solid var(--line); font-family:var(--mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--green); }
.ledger-cap b{ color:var(--claret); }
.ledger-cols{ columns:2; column-gap:0; padding:8px 0; }
.ix-row{ display:grid; grid-template-columns:auto auto 1fr auto; align-items:baseline; gap:10px; padding:11px 24px; break-inside:avoid; border-bottom:1px dotted var(--line); }
.ix-row:hover{ background:rgba(201,162,39,.08); }
.ix-no{ font-family:var(--mono); font-size:.7rem; color:var(--gold-deep); }
.ix-name{ font-family:var(--serif); font-size:1.04rem; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ix-key{ color:var(--claret); } .ix-key svg{ vertical-align:-1px; }
.ix-leader{ border-bottom:1px dotted var(--line); transform:translateY(-4px); }
.ix-meta{ font-family:var(--mono); font-size:.64rem; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-soft); white-space:nowrap; }

/* ============================================================
   CUISINE DIRECTORY (typographic index with chip thumbnails)
   ============================================================ */
.directory{ columns:2; column-gap:48px; }
.dir-row{ display:flex; align-items:center; gap:14px; padding:14px 0; border-bottom:1px solid var(--line); break-inside:avoid; }
.dir-chip{ width:46px; height:46px; flex:0 0 auto; border:1px solid var(--green); border-radius:50%; overflow:hidden; }
.dir-chip img{ width:100%; height:100%; object-fit:cover; }
.dir-name{ font-family:var(--serif); font-size:1.3rem; color:var(--ink); }
.dir-row:hover .dir-name{ color:var(--claret); }
.dir-leader{ flex:1; border-bottom:1px dotted var(--line); transform:translateY(-3px); }
.dir-count{ font-family:var(--mono); font-size:1rem; color:var(--gold-deep); }

/* ============================================================
   SPECIMEN PLATE recipe card (round dish photo on a label card)
   ============================================================ */
.grid-recipes{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.grid-recipes.cols-4{ grid-template-columns:repeat(4,1fr); }
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.plate{ background:var(--paper); border:1px solid var(--line); border-radius:4px; padding:18px 18px 0; text-align:center; display:flex; flex-direction:column; transition:border-color .2s, transform .16s; }
.plate:hover{ border-color:var(--green); transform:translateY(-3px); }
.plate-top{ display:flex; justify-content:space-between; align-items:center; font-family:var(--mono); font-size:.66rem; letter-spacing:.08em; color:var(--gold-deep); }
.plate-key{ display:inline-grid; place-items:center; width:24px; height:24px; border-radius:50%; background:var(--claret); color:#F1E3CB; }
.plate-key--free{ width:auto; padding:0 9px; border-radius:999px; background:transparent; border:1px solid var(--green); color:var(--green); font-size:.6rem; letter-spacing:.12em; }
.plate-disc{ display:block; width:170px; height:170px; margin:16px auto 0; border-radius:50%; overflow:hidden; border:3px solid var(--bone-2); outline:1px solid var(--line); position:relative; }
.plate-disc::after{ content:""; position:absolute; inset:0; border-radius:50%; box-shadow:inset 0 0 0 6px rgba(252,249,241,.5); }
.plate-disc img{ width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.plate:hover .plate-disc img{ transform:scale(1.08); }
.plate.is-locked .plate-disc{ border-color:#E5D6B0; outline-color:var(--gold); }
.plate-label{ padding:16px 4px 0; flex:1; }
.plate-cuisine{ font-family:var(--mono); font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-deep); }
.plate-name{ font-size:1.18rem; margin-top:6px; }
.plate-name a:hover,.plate-label a:hover .plate-name{ color:var(--claret); }
.plate-rail{ display:flex; justify-content:center; gap:16px; margin-top:14px; padding:12px 0; border-top:1px solid var(--line); font-family:var(--mono); font-size:.66rem; letter-spacing:.04em; color:var(--ink-soft); }
.plate-rail span:not(:last-child){ position:relative; }

/* ============================================================
   MANIFEST product rows
   ============================================================ */
.manifest-list{ display:grid; grid-template-columns:1fr 1fr; gap:0 40px; }
.manifest{ display:grid; grid-template-columns:92px 1fr auto; gap:18px; align-items:center; padding:20px 0; border-bottom:1px solid var(--line); }
.manifest-thumb{ width:92px; height:92px; border:1px solid var(--line); border-radius:4px; overflow:hidden; background:var(--bone-2); }
.manifest-thumb img{ width:100%; height:100%; object-fit:cover; transition:transform .5s; } .manifest:hover .manifest-thumb img{ transform:scale(1.06); }
.manifest-cat{ font-family:var(--mono); font-size:.62rem; letter-spacing:.1em; text-transform:uppercase; color:var(--gold-deep); }
.manifest-name{ font-size:1.12rem; margin:3px 0 4px; } .manifest-name a:hover{ color:var(--claret); }
.manifest-desc{ font-size:.84rem; color:var(--ink-soft); }
.manifest-buy{ text-align:right; display:flex; flex-direction:column; gap:8px; align-items:flex-end; }
.manifest-buy .price{ font-family:var(--serif); font-size:1.25rem; font-weight:700; color:var(--green); }

/* product detail still uses grid-products fallback */
.grid-products{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }

/* ============================================================
   LEDGER FEATURE (zigzag numbered editorial rows)
   ============================================================ */
.feature{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; padding:30px 0; }
.feature + .feature{ border-top:1px solid var(--line); }
.feature:nth-child(even) .feature-art{ order:2; }
.feature-art{ position:relative; aspect-ratio:5/4; overflow:hidden; border:1px solid var(--green); }
.feature-art img{ width:100%; height:100%; object-fit:cover; }
.feature-no{ font-family:var(--serif); font-size:3.4rem; color:var(--gold); line-height:1; }
.feature h3{ font-size:clamp(1.6rem,3vw,2.3rem); margin:8px 0 12px; }
.feature .eyebrow{ display:block; margin-bottom:8px; }

/* ============================================================
   MEMBERSHIP TICKET (perforated coupon)
   ============================================================ */
.ticket{ position:relative; background:var(--green); color:var(--bone); border-radius:8px; padding:46px 40px; text-align:center; overflow:hidden; }
.ticket::before,.ticket::after{ content:""; position:absolute; top:50%; transform:translateY(-50%); width:34px; height:34px; border-radius:50%; background:var(--bone); }
.ticket::before{ left:-17px; } .ticket::after{ right:-17px; }
.ticket-perf{ position:absolute; left:24px; right:24px; top:50%; border-top:2px dashed rgba(201,162,39,.45); }
.ticket h2{ color:#fff; } .ticket .eyebrow{ color:var(--gold); }
.ticket-stub{ font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); }

/* ============================================================
   PHOTO STRIP / MOSAIC / GALLERY (kept but recolored)
   ============================================================ */
.photo-strip{ display:grid; grid-template-columns:repeat(6,1fr); gap:8px; }
.photo-strip .sq{ aspect-ratio:1/1; overflow:hidden; border:1px solid var(--green); }
.photo-strip .sq img{ width:100%; height:100%; object-fit:cover; transition:transform .5s; } .photo-strip .sq:hover img{ transform:scale(1.08); }
.photo-mosaic{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:158px; gap:10px; }
.photo-mosaic .tile{ overflow:hidden; position:relative; border:1px solid var(--green); }
.photo-mosaic .tile img{ width:100%; height:100%; object-fit:cover; transition:transform .5s; } .photo-mosaic .tile:hover img{ transform:scale(1.06); }
.photo-mosaic .tile:nth-child(1){ grid-row:span 2; } .photo-mosaic .tile:nth-child(6){ grid-row:span 2; }
.tile-cap{ position:absolute; left:0; bottom:0; padding:8px 11px; background:var(--green); color:var(--bone); font-family:var(--mono); font-size:.64rem; letter-spacing:.06em; text-transform:uppercase; }
.recipe-gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.recipe-gallery figure{ overflow:hidden; border:1px solid var(--green); }
.recipe-gallery img{ width:100%; aspect-ratio:4/3; object-fit:cover; }

/* ---- category cards on directory listings still need a grid fallback ---- */
.grid-cats{ display:block; }

/* banners / splits / bands */
.free-banner{ background:var(--green); color:var(--bone); padding:22px 26px; display:flex; align-items:center; gap:20px; flex-wrap:wrap; border-left:5px solid var(--gold); border-radius:4px; }
.free-banner .fb-icon{ width:46px; height:46px; border:1px solid var(--gold); color:var(--gold); display:grid; place-items:center; flex:0 0 auto; border-radius:50%; }
.free-banner p{ flex:1; min-width:240px; font-size:.95rem; } .free-banner b{ color:var(--gold); }
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:46px; align-items:center; }
.split-art{ overflow:hidden; border:1px solid var(--green); aspect-ratio:5/4; box-shadow:14px 14px 0 -2px var(--gold); }
.split-art img{ width:100%; height:100%; object-fit:cover; }
.split--rev .split-art{ order:-1; }
.band{ background:var(--green); color:#e7ddc6; } .band h2{ color:#fff; }
.band-cream{ background:var(--bone-2); }
.band-crimson{ background:var(--claret); color:#F0DcC8; } .band-crimson h2,.band-crimson h3{ color:#fff; } .band-crimson .lede{ color:#EDCDBE; } .band-crimson .eyebrow{ color:#E3B57F; }
.band-green{ background:var(--green); color:#E4DCC6; } .band-green h2,.band-green h3{ color:#fff; } .band-green .lede{ color:#D7CDB2; } .band-green .eyebrow{ color:var(--gold); }

/* steps + ingredients */
.steps-list{ list-style:none; counter-reset:s; display:flex; flex-direction:column; gap:16px; }
.steps-list li{ counter-increment:s; position:relative; padding-left:58px; min-height:40px; }
.steps-list li::before{ content:"0" counter(s); position:absolute; left:0; top:-2px; width:40px; font-family:var(--mono); font-weight:600; font-size:1rem; color:var(--claret); border-bottom:2px solid var(--gold); padding-bottom:3px; }
.ingredients{ list-style:none; display:flex; flex-direction:column; }
.ingredients li{ display:flex; gap:12px; padding:10px 0; border-bottom:1px dashed var(--line); align-items:baseline; }
.ingredients li::before{ content:"\2666"; color:var(--gold-deep); flex:0 0 auto; font-size:.7rem; }
.meta-tiles{ display:grid; grid-template-columns:repeat(4,1fr); border:1px solid var(--green); }
.meta-tile{ background:var(--paper); padding:18px 14px; text-align:center; } .meta-tile + .meta-tile{ border-left:1px solid var(--line); }
.meta-tile b{ display:block; font-family:var(--serif); font-size:1.4rem; color:var(--green); }
.meta-tile span{ font-family:var(--mono); font-size:.6rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); }
.paywall{ background:var(--green); color:#ECE3CC; padding:40px; text-align:center; border:1px solid var(--green-deep); border-top:4px solid var(--gold); border-radius:6px; }
.paywall .pw-lock{ width:60px; height:60px; border:1px solid var(--gold); color:var(--gold); display:grid; place-items:center; margin:0 auto 18px; border-radius:50%; }
.paywall h3{ color:#fff; font-size:1.7rem; margin-bottom:10px; } .paywall p{ color:#E0D3B6; max-width:46ch; margin:0 auto 22px; }
.paywall .pw-feats{ list-style:none; max-width:430px; margin:22px auto 0; text-align:left; display:grid; gap:10px; }
.paywall .pw-feats li{ display:flex; gap:10px; color:#EFE6CE; font-size:.94rem; } .paywall .pw-feats svg{ flex:0 0 auto; color:var(--gold); margin-top:2px; }
.paywall .pw-cta{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:8px; }

/* interior page hero */
.page-hero{ position:relative; color:var(--bone); overflow:hidden; border-bottom:3px solid var(--gold); }
.page-hero .ph-bg{ position:absolute; inset:0; } .page-hero .ph-bg img{ width:100%; height:100%; object-fit:cover; }
.page-hero .ph-scrim{ position:absolute; inset:0; background:linear-gradient(115deg,rgba(14,42,32,.92),rgba(20,58,43,.66)); }
.page-hero .ph-inner{ position:relative; max-width:var(--maxw); margin:0 auto; padding:78px 28px; }
.page-hero h1{ color:#fff; font-size:clamp(2.2rem,5vw,3.6rem); max-width:16ch; margin:14px 0 12px; }
.page-hero .lede{ color:#EBE0C9; max-width:52ch; }
.crumbs{ font-family:var(--mono); font-size:.66rem; letter-spacing:.08em; text-transform:uppercase; color:#DDCB9E; } .crumbs a:hover{ color:#fff; }

/* forms */
.form-card{ background:var(--paper); border:1px solid var(--green); border-top:4px solid var(--gold); padding:32px; }
.field{ margin-bottom:16px; }
.field label{ display:block; font-family:var(--mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:7px; }
.field input,.field select,.field textarea{ width:100%; padding:12px 13px; border:1px solid var(--line); border-radius:4px; font-family:var(--sans); font-size:1rem; background:var(--bone); color:var(--ink); }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--green); box-shadow:0 0 0 3px rgba(20,58,43,.12); background:#fff; }
.field textarea{ min-height:130px; resize:vertical; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-note{ font-size:.82rem; color:var(--ink-soft); }
.alert{ padding:13px 16px; border-radius:4px; font-size:.92rem; margin-bottom:18px; border:1px solid; }
.alert-error{ background:#f6e3df; color:#7e1c14; border-color:#e0b2a8; } .alert-ok{ background:#e6efe2; color:#2c5520; border-color:#bcd2ac; }

/* cart */
.cart-row{ display:grid; grid-template-columns:84px 1fr auto auto auto; gap:16px; align-items:center; padding:18px 0; border-bottom:1px solid var(--line); }
.cart-row img{ width:84px; height:84px; object-fit:cover; border:1px solid var(--green); border-radius:4px; }
.cart-row .ci-name{ font-family:var(--serif); font-size:1.06rem; }
.qty{ display:inline-flex; align-items:center; border:1px solid var(--green); border-radius:999px; overflow:hidden; }
.qty button{ width:32px; height:32px; background:var(--paper); border:0; cursor:pointer; font-size:1.1rem; color:var(--green); } .qty button:hover{ background:var(--green); color:#fff; }
.qty span{ min-width:34px; text-align:center; font-family:var(--mono); }
.ci-remove{ background:none; border:0; color:var(--ink-soft); cursor:pointer; font-family:var(--mono); font-size:.68rem; text-transform:uppercase; letter-spacing:.06em; text-decoration:underline; } .ci-remove:hover{ color:var(--claret); }
.summary{ background:var(--paper); border:1px solid var(--green); border-top:4px solid var(--gold); padding:24px; position:sticky; top:120px; }
.summary-row{ display:flex; justify-content:space-between; padding:9px 0; font-size:.95rem; }
.summary-row.total{ border-top:1px solid var(--green); margin-top:8px; padding-top:14px; font-family:var(--serif); font-size:1.3rem; font-weight:700; }
.empty-state{ text-align:center; padding:64px 20px; } .empty-state .es-icon{ width:74px; height:74px; border:1px solid var(--green); border-radius:50%; display:grid; place-items:center; margin:0 auto 18px; }

/* pricing */
.plans{ display:grid; grid-template-columns:1fr 1fr; gap:22px; max-width:760px; margin:0 auto; }
.plan{ background:var(--paper); border:1px solid var(--green); padding:32px; position:relative; border-radius:4px; }
.plan.featured{ border-top:4px solid var(--gold); box-shadow:12px 12px 0 -2px var(--green); }
.plan .plan-badge{ position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--gold); color:#241B02; padding:5px 14px; font-family:var(--mono); font-size:.62rem; letter-spacing:.08em; text-transform:uppercase; border-radius:999px; }
.plan h3{ font-size:1.4rem; } .plan .price{ font-family:var(--serif); font-size:3rem; color:var(--green); line-height:1; margin:10px 0 4px; } .plan .price small{ font-size:1rem; color:var(--ink-soft); font-family:var(--mono); }
.plan ul{ list-style:none; margin:20px 0; display:grid; gap:11px; } .plan ul li{ display:flex; gap:10px; font-size:.93rem; color:var(--ink-soft); } .plan ul svg{ flex:0 0 auto; color:var(--green); margin-top:3px; }

/* faq */
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{ width:100%; text-align:left; background:none; border:0; cursor:pointer; padding:20px 40px 20px 40px; position:relative; font-family:var(--serif); font-size:1.16rem; font-weight:600; color:var(--ink); }
.faq-q::before{ content:counter(faqc,decimal-leading-zero); counter-increment:faqc; position:absolute; left:0; top:22px; font-family:var(--mono); font-size:.7rem; color:var(--gold-deep); }
.faq-q::after{ content:"+"; position:absolute; right:4px; top:50%; transform:translateY(-50%); font-size:1.5rem; color:var(--claret); } .faq-item.open .faq-q::after{ content:"-"; }
.faq-a{ display:none; padding:0 0 20px 40px; color:var(--ink-soft); max-width:70ch; } .faq-item.open .faq-a{ display:block; }

/* prose / legal */
.prose{ max-width:74ch; } .prose h2{ font-size:1.6rem; margin:32px 0 12px; } .prose h3{ font-size:1.22rem; margin:24px 0 10px; }
.prose p{ margin-bottom:16px; color:var(--ink-soft); } .prose ul,.prose ol{ margin:0 0 18px 22px; color:var(--ink-soft); } .prose li{ margin-bottom:8px; } .prose a{ color:var(--claret); text-decoration:underline; }
.legal-meta{ font-family:var(--mono); font-size:.72rem; letter-spacing:.04em; color:var(--ink-soft); margin-bottom:24px; padding-bottom:16px; border-bottom:1px solid var(--green); }
.toc{ background:var(--bone-2); border:1px solid var(--line); padding:22px 26px; margin-bottom:30px; } .toc ul{ list-style:none; columns:2; gap:20px; } .toc a{ color:var(--claret); font-size:.9rem; }
.data-table{ width:100%; border-collapse:collapse; margin:18px 0; font-size:.9rem; } .data-table th,.data-table td{ border:1px solid var(--line); padding:11px 13px; text-align:left; vertical-align:top; } .data-table th{ background:var(--bone-2); font-family:var(--mono); font-size:.7rem; letter-spacing:.05em; text-transform:uppercase; }

/* team / blog */
.team-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; } .team-card{ text-align:center; }
.team-card .tc-photo{ width:130px; height:130px; margin:0 auto 13px; overflow:hidden; border:1px solid var(--green); border-radius:50%; }
.team-card .tc-photo img{ width:100%; height:100%; object-fit:cover; } .team-card h4{ font-size:1.14rem; }
.team-card .tc-role{ font-family:var(--mono); color:var(--gold-deep); font-size:.64rem; letter-spacing:.06em; text-transform:uppercase; margin:4px 0 8px; } .team-card p{ font-size:.87rem; color:var(--ink-soft); }
.post-card{ background:var(--paper); border:1px solid var(--line); border-top:3px solid var(--gold); display:flex; flex-direction:column; transition:transform .16s,border-color .2s; }
.post-card:hover{ transform:translateY(-3px); border-color:var(--green); }
.post-card .card-media{ aspect-ratio:16/10; overflow:hidden; border-bottom:1px solid var(--line); } .post-card .card-media img{ width:100%; height:100%; object-fit:cover; }
.post-card .card-body{ padding:16px 18px 20px; } .post-card .card-cat{ font-family:var(--mono); font-size:.62rem; letter-spacing:.1em; text-transform:uppercase; color:var(--gold-deep); }
.post-card .card-title{ font-family:var(--serif); font-size:1.2rem; margin:6px 0; } .post-card .card-title a:hover,.post-card a:hover .card-title{ color:var(--claret); }
.post-card .card-desc{ font-size:.9rem; color:var(--ink-soft); }
.post-meta{ font-family:var(--mono); font-size:.66rem; letter-spacing:.04em; color:var(--ink-soft); }
.article-hero img{ width:100%; max-height:440px; object-fit:cover; border:1px solid var(--green); box-shadow:12px 12px 0 -2px var(--gold); }

/* cookie / toast */
.cookie-bar{ position:fixed; left:18px; right:18px; bottom:18px; z-index:120; background:var(--green); color:#e7dcc4; border-top:3px solid var(--gold); padding:16px 20px; display:flex; align-items:center; gap:18px; flex-wrap:wrap; box-shadow:0 14px 40px -16px rgba(0,0,0,.55); max-width:760px; margin:0 auto; border-radius:6px; }
.cookie-bar[hidden]{ display:none !important; } .cookie-bar p{ flex:1; min-width:240px; font-size:.85rem; } .cookie-bar a{ color:var(--gold); text-decoration:underline; } .cookie-actions{ display:flex; gap:10px; }
.toast{ position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(28px); z-index:250; background:var(--green); color:var(--bone); padding:13px 22px; border-left:3px solid var(--gold); font-family:var(--mono); font-size:.76rem; letter-spacing:.04em; border-radius:4px; box-shadow:0 14px 34px -14px rgba(0,0,0,.55); opacity:0; pointer-events:none; transition:opacity .25s, transform .25s; }
.toast.show{ opacity:1; transform:translateX(-50%) translateY(0); }

/* footer */
.site-foot{ background:var(--green-deep); color:#b9b094; margin-top:10px; border-top:4px solid var(--gold); }
.foot-top{ max-width:var(--maxw); margin:0 auto; padding:58px 28px 40px; display:grid; grid-template-columns:1.25fr 2fr; gap:48px; }
.brand--foot{ display:flex; align-items:center; gap:12px; } .brand--foot .brand-name{ color:#fff; }
.foot-tag{ margin:18px 0; font-size:.9rem; max-width:42ch; } .foot-support{ font-family:var(--mono); font-size:.76rem; letter-spacing:.04em; } .foot-support a{ color:var(--gold); }
.foot-cols{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.foot-col h4{ color:#fff; font-family:var(--mono); font-size:.64rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:14px; }
.foot-col ul{ list-style:none; display:grid; gap:9px; } .foot-col a{ font-size:.89rem; color:#b9b094; } .foot-col a:hover{ color:var(--gold); }
.foot-bottom{ border-top:1px solid rgba(255,255,255,.12); max-width:var(--maxw); margin:0 auto; padding:18px 28px; display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; font-family:var(--mono); font-size:.68rem; color:#8f876f; }

.mt-0{margin-top:0}.mt-1{margin-top:10px}.mt-2{margin-top:20px}.mt-3{margin-top:32px}.mt-4{margin-top:48px}.mb-2{margin-bottom:20px}.mb-3{margin-bottom:32px}
.flex{display:flex}.between{justify-content:space-between}.items-center{align-items:center}.gap{gap:14px}.wrap-gap{flex-wrap:wrap}

@media (max-width:1024px){
  .rule-nav{ display:none; } .nav-toggle{ display:flex; }
  .grid-recipes,.grid-recipes.cols-4{ grid-template-columns:repeat(2,1fr); }
  .grid-products{ grid-template-columns:repeat(3,1fr); }
  .manifest-list{ grid-template-columns:1fr; gap:0; }
  .directory{ columns:1; } .ledger-cols{ columns:1; }
  .foot-top{ grid-template-columns:1fr; gap:32px; } .team-grid{ grid-template-columns:repeat(2,1fr); }
  .split,.feature{ grid-template-columns:1fr; gap:26px; } .split--rev .split-art,.feature:nth-child(even) .feature-art{ order:0; }
}
@media (max-width:768px){
  .section{ padding:54px 0; } .util-tag{ display:none; }
  .grid-3,.grid-2{ grid-template-columns:1fr; } .grid-products{ grid-template-columns:repeat(2,1fr); }
  .photo-mosaic{ grid-template-columns:repeat(3,1fr); grid-auto-rows:128px; } .photo-strip{ grid-template-columns:repeat(4,1fr); } .recipe-gallery{ grid-template-columns:repeat(2,1fr); }
  .meta-tiles{ grid-template-columns:repeat(2,1fr); } .meta-tile:nth-child(3){ border-left:0; } .meta-tile:nth-child(n+3){ border-top:1px solid var(--line); }
  .plans{ grid-template-columns:1fr; } .field-row{ grid-template-columns:1fr; } .toc ul{ columns:1; }
  .cart-row{ grid-template-columns:66px 1fr auto; grid-row-gap:8px; } .cart-row img{ width:66px; height:66px; }
  .foot-cols{ grid-template-columns:repeat(2,1fr); } .foot-bottom{ flex-direction:column; }
  .manifest{ grid-template-columns:74px 1fr; } .manifest-buy{ grid-column:2; flex-direction:row; align-items:center; justify-content:space-between; }
}
@media (max-width:480px){
  .wrap,.masthead-inner,.foot-top,.util-inner,.cover-inner{ padding-left:18px; padding-right:18px; }
  .grid-recipes,.grid-recipes.cols-4,.grid-products{ grid-template-columns:1fr; }
  .photo-mosaic{ grid-template-columns:repeat(2,1fr); } .photo-strip{ grid-template-columns:repeat(3,1fr); } .recipe-gallery{ grid-template-columns:1fr; }
  .team-grid{ grid-template-columns:1fr; } .cover-cta{ flex-direction:column; } .cover-cta .btn{ width:100%; } .brand-sub{ display:none; }
}
