/* =========================================================================
   Hearthstone Table — warm, rustic, editorial. Serif display + soft sans body.
   Terracotta + cream, rounded cards, magazine asymmetry.
   ========================================================================= */
:root{
  --bg:#faf4ea; --surface:#fffdf8; --surface-2:#f3e8d6; --border:#e6d6bf;
  --text:#2c2118; --muted:#7a6a57; --faint:#a9967e;
  --accent:#b4471f; --accent-2:#8a3414; --accent-soft:#f6e3d6;
  --on-accent:#fff8f0; --green:#5a6b3b;
  --head:'Zodiak',Georgia,'Times New Roman',serif;
  --body:'Satoshi',system-ui,-apple-system,sans-serif;
  --radius:22px; --shadow:0 18px 40px -22px rgba(70,40,15,.35);
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--body);line-height:1.65;
  font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-2)}
h1,h2,h3,h4{font-family:var(--head);font-weight:700;line-height:1.12;letter-spacing:-.01em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.skip{position:absolute;left:-999px}.skip:focus{left:12px;top:12px;background:var(--accent);color:#fff;padding:8px 14px;border-radius:8px;z-index:99}

/* Header */
.site-header{position:sticky;top:0;z-index:40;background:rgba(250,244,234,.92);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 24px}
.brand{display:flex;align-items:center;gap:11px;color:var(--accent)}
.brand-text{display:flex;flex-direction:column;line-height:1;font-family:var(--head)}
.brand-text strong{font-size:22px;color:var(--text);font-weight:700}
.brand-text em{font-style:italic;font-size:13px;color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin-top:2px}
.site-nav{display:flex;gap:6px}
.site-nav a{padding:9px 15px;border-radius:999px;color:var(--text);font-weight:500;font-size:15px}
.site-nav a:hover{background:var(--accent-soft)}
.site-nav a.active{background:var(--accent);color:var(--on-accent)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2.5px;background:var(--text);border-radius:2px;transition:.3s}

/* Hero — asymmetric magazine */
.hero{padding:46px 0 30px}
.hero-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:44px;align-items:center}
.hero-eyebrow{display:inline-block;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
  font-size:12.5px;color:var(--accent);background:var(--accent-soft);padding:6px 14px;border-radius:999px}
.hero h1{font-size:clamp(34px,5vw,58px);margin:18px 0 16px}
.hero-excerpt{font-size:19px;color:var(--muted);max-width:38ch;margin-bottom:18px}
.hero-meta{font-size:13.5px;color:var(--faint);text-transform:uppercase;letter-spacing:.08em;font-weight:500}
.hero-figure{position:relative}
.hero-figure img{border-radius:28px;box-shadow:var(--shadow);aspect-ratio:4/3;object-fit:cover;width:100%}
.hero-figure::after{content:"";position:absolute;inset:auto -18px -18px auto;width:120px;height:120px;
  background:repeating-linear-gradient(45deg,var(--accent-soft),var(--accent-soft) 6px,transparent 6px,transparent 12px);
  border-radius:24px;z-index:-1}
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:var(--on-accent);
  padding:13px 26px;border-radius:999px;font-weight:600;border:0;cursor:pointer;font-family:var(--body);font-size:16px}
.btn:hover{background:var(--accent-2);color:#fff}

/* Section frames */
.section{padding:50px 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:30px;
  border-bottom:2px solid var(--border);padding-bottom:14px}
.section-head h2{font-size:clamp(26px,3.4vw,38px)}
.section-head .kicker{color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:12.5px}
.section-head p{color:var(--muted);font-size:15px}

/* Category strip */
.cats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.cat{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:1/1.08;box-shadow:var(--shadow)}
.cat img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.cat:hover img{transform:scale(1.07)}
.cat-label{position:absolute;inset:auto 0 0 0;padding:18px 16px 14px;color:#fff;
  background:linear-gradient(transparent,rgba(40,25,12,.85))}
.cat-label h3{font-size:20px;color:#fff}
.cat-label p{font-size:13px;opacity:.9;margin-top:2px}

/* Recipe cards grid */
.recipes{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.rcard{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);transition:transform .25s ease,box-shadow .25s ease}
.rcard:hover{transform:translateY(-6px);box-shadow:0 26px 50px -24px rgba(70,40,15,.5)}
.rcard a{color:inherit;display:block}
.rcard .thumb{aspect-ratio:3/2;overflow:hidden}
.rcard .thumb img{width:100%;height:100%;object-fit:cover}
.rcard-body{padding:18px 20px 22px}
.rcard .tag{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent)}
.rcard h3{font-size:20px;margin:7px 0 8px}
.rcard p{color:var(--muted);font-size:14.5px}
.rcard .time{margin-top:12px;font-size:13px;color:var(--faint);display:flex;align-items:center;gap:6px;font-weight:500}

/* Editor picks — feature row */
.picks{display:grid;grid-template-columns:2fr 1fr 1fr;gap:22px}
.pick{position:relative;border-radius:var(--radius);overflow:hidden;min-height:240px;box-shadow:var(--shadow)}
.pick img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pick .cap{position:absolute;inset:auto 0 0 0;padding:22px;color:#fff;
  background:linear-gradient(transparent,rgba(40,25,12,.9))}
.pick .cap h3{color:#fff;font-size:22px}
.pick .cap p{font-size:14px;opacity:.92;margin-top:5px}
.pick:first-child{grid-row:span 1}

/* Seasonal band */
.seasonal{background:var(--accent);color:var(--on-accent);border-radius:30px;padding:44px;margin-top:8px;
  display:grid;grid-template-columns:1.2fr 1fr;gap:36px;align-items:center}
.seasonal h2{color:var(--on-accent);font-size:clamp(26px,3.5vw,40px)}
.seasonal p{opacity:.92;margin:14px 0 0;font-size:17px}
.seasonal .pill-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.seasonal .pill-list span{background:rgba(255,255,255,.18);padding:8px 16px;border-radius:999px;font-size:14px;font-weight:500}
.seasonal-fig img{border-radius:20px;aspect-ratio:4/3;object-fit:cover}

/* Tips */
.tips{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tip{background:var(--surface-2);border-radius:var(--radius);padding:26px;border-left:5px solid var(--accent)}
.tip h3{font-size:20px;margin-bottom:8px}
.tip p{color:var(--muted);font-size:15px}

/* Author strip */
.author{display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:center;
  background:var(--surface);border:1px solid var(--border);border-radius:30px;padding:34px}
.author .avatar{width:96px;height:96px;border-radius:50%;background:var(--accent-soft);
  display:grid;place-items:center;color:var(--accent);font-family:var(--head);font-size:40px;font-weight:700}
.author h2{font-size:26px;margin-bottom:8px}
.author p{color:var(--muted)}
.author .sig{margin-top:10px;font-style:italic;color:var(--accent);font-family:var(--head)}

/* Newsletter */
.newsletter{background:var(--surface-2);border-radius:30px;padding:44px;text-align:center;border:1px dashed var(--accent)}
.newsletter h2{font-size:clamp(24px,3vw,34px)}
.newsletter p{color:var(--muted);max-width:46ch;margin:12px auto 22px}
.nl-form{display:flex;gap:10px;max-width:460px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.nl-form input{flex:1;min-width:220px;padding:13px 18px;border:1px solid var(--border);border-radius:999px;
  font-family:var(--body);font-size:16px;background:#fff}
.nl-status{margin-top:12px;color:var(--green);font-weight:500;font-size:14px}

/* Page hero (interior) */
.page-hero{padding:56px 0 30px;background:var(--surface-2);border-bottom:1px solid var(--border)}
.page-hero .eyebrow{color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:13px}
.page-hero h1{font-size:clamp(32px,4.5vw,50px);margin:10px 0}
.page-lede{color:var(--muted);font-size:19px;max-width:62ch}
.page-hero .updated{color:var(--faint);font-size:14px;margin-top:8px}

/* Legal / prose */
.prose{max-width:760px}
.prose h2{font-size:24px;margin:30px 0 10px;color:var(--accent-2)}
.prose p{margin-bottom:14px;color:var(--text)}
.prose ul{margin:0 0 16px 22px}
.prose li{margin-bottom:8px}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:40px}
.field{margin-bottom:16px;display:flex;flex-direction:column;gap:6px}
.field label{font-weight:600;font-size:14px}
.field input,.field select,.field textarea{padding:12px 14px;border:1px solid var(--border);
  border-radius:14px;font-family:var(--body);font-size:16px;background:#fff}
.form-note{font-size:13px;color:var(--faint);margin-top:10px}
.form-status{color:var(--green);font-weight:500;margin-top:10px}
.contact-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:22px;margin-bottom:16px}
.contact-card h3{font-size:18px;margin-bottom:6px}
.contact-card p{color:var(--muted);font-size:15px}
.contact-line{color:var(--accent);font-weight:600}

/* Credits */
.credits-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.credit{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:14px;display:flex;gap:14px;align-items:center}
.credit img{width:72px;height:72px;border-radius:12px;object-fit:cover;flex:none}
.credit .meta{font-size:13.5px}
.credit .meta strong{display:block;font-size:14.5px;margin-bottom:3px}
.credit .meta span{color:var(--muted)}

/* Footer */
.site-footer{background:var(--text);color:#e8dcc9;margin-top:64px;padding:48px 0 24px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:30px}
.foot-brand{display:flex;gap:12px;color:var(--accent-soft)}
.foot-brand p{color:#c9b89e;font-size:14px}
.foot-brand strong{color:#fff;font-family:var(--head);font-size:18px}
.foot-col h4{color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px;font-family:var(--body)}
.foot-col a{display:block;color:#c9b89e;margin-bottom:8px;font-size:14.5px}
.foot-col a:hover{color:#fff}
.foot-note p{color:#c9b89e;font-size:14px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:30px;padding-top:18px}
.footer-bottom p{color:#a08d72;font-size:13px}

@media(max-width:900px){
  .hero-grid,.contact-grid,.seasonal,.author{grid-template-columns:1fr}
  .hero-figure{order:-1}
  .cats,.recipes,.picks,.tips,.footer-grid{grid-template-columns:repeat(2,1fr)}
  .author{text-align:center;justify-items:center}
}
@media(max-width:620px){
  .nav-toggle{display:flex}
  .site-nav{position:absolute;top:64px;left:0;right:0;flex-direction:column;background:var(--surface);
    border-bottom:1px solid var(--border);padding:10px 24px;display:none}
  .site-nav.open{display:flex}
  .site-nav a{padding:12px 0;border-radius:0;border-bottom:1px solid var(--border)}
  .cats,.recipes,.picks,.tips,.footer-grid{grid-template-columns:1fr}
  .seasonal,.newsletter,.author{padding:28px}
}
