/* =========================================================================
   Hill & May — hillandmay.com
   A heritage country-shop shell, built deliberately UNLIKE its FBM siblings.
   Centred serif masthead, thin classic top bar, an underlined "shelf" nav row,
   a warm magazine footer. AGA-showroom country kitchen in print.

   Surfaces : warm parchment / clotted-cream, woven paper texture
   Chrome   : deep enamel-green top bar, newsletter, footer
   Signal   : heritage-green --accent (injected) + warm terracotta secondary
   Type     : Lora (refined serif headlines) over Mulish (soft humanist sans)
   Rules    : classic understated hairlines, never tech-mag drop shadows
   ========================================================================= */

:root{
  /* ink on parchment */
  --ink:#26271f;            /* warm near-black, faint olive */
  --ink-soft:#54564a;       /* muted bracken */
  --ink-faint:#857f6e;      /* soft sage-grey (AA on parchment) */

  /* parchment surfaces */
  --bg:#f6f1e6;             /* parchment page */
  --bg-card:#fffdf6;        /* clotted-cream card */
  --bg-tint:#ece4d2;        /* oatmeal tint */
  --bg-warm:#f2ead8;        /* warmer header band */

  /* hairlines */
  --line:#d8ccb3;           /* warm rule */
  --line-soft:#e6dcc6;      /* lighter rule */
  --line-strong:#c5b594;    /* emphatic rule */

  /* deep enamel-green chrome (this brand's "navy") */
  --navy:#2c382c;           /* enamel green — top bar, newsletter, footer */
  --navy-deep:#202a20;      /* deepest green — footer base */
  --cream:#f6f1e6;          /* type on green */
  --cream-soft:#cdd2c2;     /* muted type on green */
  --cream-faint:#9aa593;    /* faint type on green */

  /* signal accent — heritage green, injected as --accent:#5a6b4f / --accent-dark:#46533d.
     Defaults mirror those so the sheet is self-sufficient. */
  --accent:#5a6b4f;
  --accent-dark:#46533d;
  --accent-deep:#3b4632;    /* darker still for type-on-cream AA */

  /* warm terracotta secondary — the "hot enamel" warmth */
  --terra:#b5572f;
  --terra-deep:#8f3d1c;     /* AA text weight on cream */
  --terra-tint:#f0e1d3;

  --maxw:1080px;
  --maxw-read:720px;        /* article measure */
  --gut:clamp(20px,4.6vw,48px);
  --radius:6px;             /* restrained, cabinetmaker-square */
  --radius-sm:4px;
  --radius-pill:999px;

  /* understated, paper-soft shadows (hairline first, faint lift second) */
  --shadow-sm:0 0 0 1px var(--line-soft);
  --shadow:0 1px 0 var(--line), 0 16px 34px -26px rgba(44,56,44,.34);

  --sans:"Mulish",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --display:"Lora",Georgia,"Times New Roman",serif;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-size:1.0625rem;line-height:1.72;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
  /* faint woven-linen paper texture, very subtle */
  background-image:
    radial-gradient(circle at 20% 14%, rgba(90,107,79,.035), transparent 60%),
    radial-gradient(circle at 84% 86%, rgba(181,87,47,.03), transparent 55%);
  background-attachment:fixed;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.18;color:var(--ink);margin:0;letter-spacing:.002em}
::selection{background:var(--accent);color:#fff}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:3px}

.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.section{padding-top:clamp(46px,6.5vw,76px)}

.skip-link{position:absolute;left:-9999px;top:0;background:var(--accent);color:#fff;
  padding:10px 16px;border-radius:0 0 6px 0;z-index:200;font-weight:700}
.skip-link:focus{left:0}

/* hidden state-toggle for the mobile drawer */
.nav-toggle{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}

/* ---------- kicker / eyebrow (terracotta hairline + small caps) ---------- */
.kicker{display:inline-block;font:700 .68rem/1 var(--sans);
  letter-spacing:.2em;text-transform:uppercase;color:var(--accent-deep)}
.kicker::before{content:"";display:inline-block;width:16px;height:1px;
  background:var(--terra);vertical-align:middle;margin-right:9px;position:relative;top:-2px}
.kicker--lg{font-size:.74rem;letter-spacing:.22em}
.eyebrow{display:inline-block;font:700 .68rem/1 var(--sans);
  letter-spacing:.2em;text-transform:uppercase;color:var(--accent-deep)}
.eyebrow--light{color:color-mix(in srgb,var(--terra) 46%,#f2ead8)}

/* =========================================================================
   SHELL — the part that makes Hill & May structurally its own thing
   ========================================================================= */

/* ---------- thin classic top bar ---------- */
.shopbar{background:var(--navy);color:var(--cream-soft);
  border-bottom:1px solid rgba(246,241,230,.08)}
.shopbar-inner{display:flex;align-items:center;justify-content:space-between;
  gap:12px;min-height:34px;flex-wrap:wrap}
.shopbar-estd{font-family:var(--display);font-style:italic;font-size:.82rem;
  letter-spacing:.01em;color:var(--cream-soft)}
.shopbar-links{display:flex;align-items:center;gap:9px}
.shopbar-links a{color:var(--cream-soft);font-size:.7rem;font-weight:600;
  letter-spacing:.13em;text-transform:uppercase;
  border-bottom:1px solid transparent;padding-bottom:1px;transition:color .15s,border-color .15s}
.shopbar-links a:hover,.shopbar-links a:focus-visible{color:var(--cream);
  border-bottom-color:color-mix(in srgb,var(--terra) 72%,var(--cream))}
.shopbar-sep{color:var(--cream-faint);font-size:.7rem}

/* ---------- centred serif masthead ---------- */
.masthead{background:var(--bg-warm);
  border-bottom:1px double var(--line-strong)}
.masthead-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  gap:12px;padding:18px 0 16px}

.masthead-aside{display:flex;align-items:center;min-width:0}
.masthead-aside--left{justify-content:flex-start}
.masthead-aside--right{justify-content:flex-end}

/* brand: centred wordmark, ornament, tagline */
.brand{display:flex;flex-direction:column;align-items:center;gap:5px;text-align:center;
  grid-column:2;min-width:0}
.brand-mark{display:inline-flex;flex:none;color:var(--accent-deep)}
.brand-mark svg{height:38px;width:auto;display:block}
.brand-text{font-family:var(--display);font-weight:600;
  font-size:clamp(1.7rem,8vw,2.5rem);line-height:1;letter-spacing:.01em;
  color:var(--accent-deep);white-space:nowrap;position:relative}
/* an ornamental flourish under the wordmark — paired hairline + diamond */
.brand-text::after{content:"";display:block;width:62%;height:1px;margin:9px auto 0;
  background:linear-gradient(90deg,transparent,var(--line-strong) 22%,var(--line-strong) 78%,transparent)}
.brand-tagline{display:none}

/* ---------- left aside: burger (mobile) + desktop search ---------- */
.burger{display:inline-flex;align-items:center;gap:9px;cursor:pointer;
  color:var(--ink-soft);font:700 .7rem/1 var(--sans);text-transform:uppercase;
  background:none;border:0;padding:6px 2px}
.burger-lines{display:inline-flex;flex-direction:column;gap:5px}
.burger-lines span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px}
.burger-word{letter-spacing:.16em}

.search{position:relative;display:flex;align-items:center}
.search--desktop{display:none}
.search-input{width:100%;border:0;border-bottom:1px solid var(--line-strong);
  background:transparent;padding:7px 30px 7px 2px;
  font:.92rem var(--sans);color:var(--ink);transition:border-color .15s}
.search-input::placeholder{color:var(--ink-faint);font-style:italic}
.search-input:focus{outline:none;border-bottom-color:var(--accent)}
.search-btn{position:absolute;right:0;top:50%;transform:translateY(-50%);
  background:none;border:0;color:var(--ink-faint);cursor:pointer;padding:5px;display:flex}
.search-btn:hover{color:var(--accent)}

/* ---------- right aside: subscribe ---------- */
.subscribe-btn{display:inline-flex;align-items:center;
  background:transparent;color:var(--accent-deep);
  font-weight:700;font-size:.72rem;letter-spacing:.13em;text-transform:uppercase;
  padding:9px 18px;border:1px solid var(--accent);border-radius:var(--radius-sm);
  transition:background .15s,color .15s}
.subscribe-btn:hover,.subscribe-btn:focus-visible{background:var(--accent);color:#fff}

/* ---------- shelf nav: an elegant underlined centred row ---------- */
.shelf-nav{background:var(--bg-warm);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  display:none}
.shelf-nav-inner{display:flex;justify-content:center;align-items:center;
  flex-wrap:wrap;gap:0 clamp(16px,2.6vw,34px)}
.shelf-link{position:relative;display:inline-block;padding:13px 0;
  font-family:var(--display);font-weight:500;font-size:.98rem;letter-spacing:.01em;
  color:var(--ink-soft);transition:color .15s}
.shelf-link::after{content:"";position:absolute;left:0;right:0;bottom:9px;height:1px;
  background:var(--terra);transform:scaleX(0);transform-origin:center;
  transition:transform .2s ease}
.shelf-link:hover,.shelf-link:focus-visible{color:var(--accent-deep)}
.shelf-link:hover::after,.shelf-link:focus-visible::after{transform:scaleX(1)}
.shelf-home{color:var(--accent-deep)}
/* tiny diamond separators between items at desktop */
.shelf-link + .shelf-link::before{content:"\2666";position:absolute;left:calc(-1 * clamp(16px,2.6vw,34px)/2);
  top:50%;transform:translate(-50%,-50%);color:var(--line-strong);font-size:.5rem}

/* ---------- mobile drawer (CSS-only, label toggles #nav-toggle) ---------- */
.nav-scrim{position:fixed;inset:0;background:rgba(32,42,32,.5);opacity:0;visibility:hidden;
  transition:opacity .25s,visibility .25s;z-index:90;cursor:pointer}
.nav-drawer{position:fixed;top:0;left:0;height:100%;width:min(86vw,340px);
  background:var(--bg-card);transform:translateX(-100%);
  transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:100;
  border-right:1px solid var(--line);box-shadow:24px 0 50px -28px rgba(32,42,32,.5);
  padding:20px 24px 28px;overflow-y:auto;display:flex;flex-direction:column;gap:18px}
.nav-toggle:checked ~ .nav-scrim{opacity:1;visibility:visible}
.nav-toggle:checked ~ .nav-drawer{transform:none}
.drawer-head{display:flex;align-items:center;justify-content:space-between;
  padding-bottom:14px;border-bottom:1px solid var(--line)}
.drawer-title{font-family:var(--display);font-weight:600;font-size:1.2rem;color:var(--accent-deep)}
.drawer-close{font-size:1.9rem;line-height:1;color:var(--ink-faint);cursor:pointer;padding:0 6px}
.drawer-close:hover{color:var(--terra-deep)}
.search--drawer .search-input{width:100%;padding-right:2px;font-size:1rem}
.drawer-nav{display:flex;flex-direction:column}
.drawer-nav a{padding:13px 2px;font-family:var(--display);font-weight:500;font-size:1.06rem;
  color:var(--ink);border-bottom:1px solid var(--line-soft)}
.drawer-nav a:hover{color:var(--accent)}
.drawer-sub{justify-content:center;padding:13px;font-size:.78rem}

/* =========================================================================
   HOME — bespoke "plate + contents" magazine layout (per-site home.html)
   ========================================================================= */
.plate-wrap{padding-top:clamp(34px,5vw,58px)}
.plate{max-width:760px;margin-inline:auto;text-align:center;
  display:flex;flex-direction:column;align-items:center}
.plate-kicker{margin-bottom:14px}
.plate-frame{display:block;width:100%;margin:4px 0 6px;
  border:1px solid var(--line);background:var(--bg-card);padding:10px;border-radius:var(--radius)}
.plate-mat{display:block;overflow:hidden;border-radius:var(--radius-sm);
  background:var(--bg-tint);aspect-ratio:16/10}
.plate-mat img,.plate-mat .thumb-fallback{width:100%;height:100%}
.plate-mat img{object-fit:cover;transition:transform .6s ease}
.plate:hover .plate-mat img{transform:scale(1.03)}
.plate-title{font-weight:600;font-size:clamp(1.9rem,5.2vw,3rem);line-height:1.1;
  letter-spacing:.005em;margin:.45em 0 .3em;max-width:18ch}
.plate-title a:hover{color:var(--accent)}
.plate-dek{color:var(--ink-soft);font-size:clamp(1.05rem,2.2vw,1.22rem);line-height:1.55;
  margin:0 auto;max-width:52ch}
.plate-readmore{display:inline-flex;align-items:center;gap:8px;margin-top:22px;
  font-weight:700;font-size:.74rem;letter-spacing:.13em;text-transform:uppercase;
  color:var(--terra-deep);border-bottom:1px solid currentColor;padding-bottom:3px}
.plate-readmore svg{transition:transform .2s}
.plate-readmore:hover svg{transform:translateX(4px)}

/* contents list — a printed table of contents with leader dots */
.contents{max-width:820px;margin-inline:auto}
.contents-head{text-align:center;margin-bottom:clamp(22px,3vw,34px)}
.contents-title{font-size:clamp(1.5rem,3.2vw,2rem);position:relative;display:inline-block;padding:0 26px}
.contents-title::before,.contents-title::after{content:"\2766";position:absolute;top:50%;
  transform:translateY(-50%);color:var(--line-strong);font-size:.9rem}
.contents-title::before{left:-2px}.contents-title::after{right:-2px}
.contents-sub{color:var(--ink-faint);font-style:italic;font-family:var(--display);
  margin:.4em 0 0;font-size:1rem}
.contents-list{list-style:none;margin:0;padding:0;border-top:1px solid var(--line)}
.contents-item{border-bottom:1px solid var(--line)}
.contents-link{display:grid;grid-template-columns:auto 1fr auto;align-items:baseline;
  gap:14px;padding:18px 2px}
.contents-num{font-family:var(--display);font-style:italic;font-size:1.05rem;
  color:var(--terra-deep);min-width:2ch}
.contents-body{min-width:0}
.contents-entry{display:block;font-family:var(--display);font-weight:600;
  font-size:1.18rem;line-height:1.25;color:var(--ink)}
.contents-link:hover .contents-entry{color:var(--accent)}
.contents-cat{display:inline-block;margin-top:5px;font:700 .64rem/1 var(--sans);
  letter-spacing:.16em;text-transform:uppercase;color:var(--accent-deep)}
.contents-dek{display:block;margin-top:6px;color:var(--ink-soft);font-size:.96rem;
  line-height:1.5;max-width:60ch}
.contents-leaders{align-self:baseline;border-bottom:1px dotted var(--line-strong);
  min-width:18px;transform:translateY(-3px)}
.contents-page{font-family:var(--display);font-style:italic;font-size:.95rem;
  color:var(--ink-faint);white-space:nowrap}

/* =========================================================================
   HOME — shared template classes (.lead-feature / .rail-* )
   Styled so the shared home.html also looks at home on this shell.
   ========================================================================= */
.lead{display:grid;gap:clamp(30px,5vw,48px);padding-top:clamp(28px,4vw,46px)}
.lead-media{display:block;overflow:hidden;background:var(--bg-tint);
  border:1px solid var(--line);border-radius:var(--radius);aspect-ratio:16/9}
.lead-media img,.lead-media .thumb-fallback{width:100%;height:100%}
.lead-media img{object-fit:cover;transition:transform .6s ease}
.lead-feature:hover .lead-media img{transform:scale(1.03)}
.lead-feature-body{padding-top:18px}
.lead-title{font-weight:600;font-size:clamp(1.9rem,5vw,2.9rem);line-height:1.1;
  letter-spacing:.004em;margin:.3em 0 .3em}
.lead-title a:hover{color:var(--accent)}
.lead-dek{color:var(--ink-soft);font-size:clamp(1.05rem,2.2vw,1.2rem);line-height:1.55;
  margin:0;max-width:54ch}
.lead-readmore{display:inline-flex;align-items:center;gap:8px;margin-top:18px;
  font-weight:700;font-size:.74rem;letter-spacing:.13em;text-transform:uppercase;
  color:var(--terra-deep);border-bottom:1px solid currentColor;padding-bottom:3px}
.lead-readmore svg{transition:transform .2s}
.lead-readmore:hover svg{transform:translateX(4px)}

.lead-rail{align-self:start}
.rail-title{font-family:var(--display);font-weight:600;font-size:1.18rem;color:var(--ink);
  padding-bottom:12px;border-bottom:2px solid var(--accent-deep);margin:0 0 4px}
.rail-list{list-style:none;margin:0;padding:0}
.rail-item{border-bottom:1px solid var(--line)}
.rail-link{display:grid;grid-template-columns:88px 1fr;gap:15px;align-items:center;padding:16px 0}
.rail-thumb{display:block;width:88px;height:66px;overflow:hidden;border-radius:var(--radius-sm);
  background:var(--bg-tint);border:1px solid var(--line)}
.rail-thumb img,.rail-thumb .thumb-fallback{width:100%;height:100%;object-fit:cover}
.rail-text{display:flex;flex-direction:column;gap:7px;min-width:0}
.rail-headline{font-family:var(--display);font-weight:600;font-size:1.02rem;line-height:1.25;color:var(--ink)}
.rail-link:hover .rail-headline{color:var(--accent)}

/* image fallback (no photo yet) — engraved monogram tile */
.thumb-fallback{display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(circle at 30% 26%, color-mix(in srgb,var(--accent) 9%,var(--bg-card)), transparent 60%),
    var(--bg-tint)}
.thumb-fallback svg{width:34%;height:34%;opacity:.34;color:var(--accent-deep)}
.thumb-fallback::after{content:"H&M";position:absolute;font-family:var(--display);
  font-style:italic;font-size:1.05rem;color:color-mix(in srgb,var(--accent) 50%,var(--ink-faint))}
.plate-mat,.lead-media,.card-media,.rail-thumb,.article-hero{position:relative}

/* ---------- section title ---------- */
.section-title{display:flex;align-items:center;gap:16px;font-weight:600;
  font-size:clamp(1.4rem,2.8vw,1.85rem);letter-spacing:.004em;color:var(--ink);
  margin:0 0 clamp(22px,3vw,32px)}
.section-title::before{content:"";flex:none;width:24px;height:1px;background:var(--terra)}
.section-title::after{content:"";flex:1 1 auto;height:1px;align-self:center;background:var(--line)}

/* ---------- cards ---------- */
.card-grid{display:grid;gap:clamp(30px,3.2vw,46px) clamp(24px,2.6vw,36px);
  grid-template-columns:repeat(auto-fill,minmax(min(100%,288px),1fr))}
.card{display:flex;flex-direction:column;background:none}
.card-media{display:block;aspect-ratio:16/9;overflow:hidden;background:var(--bg-tint);
  border:1px solid var(--line);border-radius:var(--radius)}
.card-media img,.card-media .thumb-fallback{width:100%;height:100%}
.card-media img{object-fit:cover;transition:transform .6s ease}
.card:hover .card-media img{transform:scale(1.04)}
.card-body{display:flex;flex-direction:column;gap:8px;padding:16px 2px 0;flex:1}
.card-title{font-family:var(--display);font-weight:600;font-size:1.24rem;line-height:1.26;
  color:var(--ink);letter-spacing:.003em}
.card:hover .card-title{color:var(--accent)}
.card-dek{color:var(--ink-soft);font-size:.97rem;line-height:1.55;
  display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-meta{margin-top:6px;color:var(--ink-faint);font-size:.68rem;
  letter-spacing:.14em;text-transform:uppercase;font-weight:700;font-family:var(--sans)}
.card--noimg .card-media{display:none}
.card--noimg .card-body{padding-top:0;border-top:2px solid var(--accent-deep);padding-top:14px}

/* =========================================================================
   ARTICLE + HUB (shared templates)
   ========================================================================= */
.article-head{max-width:var(--maxw-read);margin-inline:auto;padding-top:clamp(30px,5vw,56px);
  text-align:center}
.breadcrumb{display:flex;align-items:center;justify-content:center;gap:9px;
  font-size:.78rem;letter-spacing:.04em;color:var(--ink-faint);margin-bottom:20px}
.breadcrumb a{color:var(--ink-faint)}
.breadcrumb a:hover{color:var(--accent)}
.article-head .kicker{margin-bottom:8px}
.article-title{font-weight:600;font-size:clamp(1.95rem,4.8vw,2.8rem);line-height:1.12;
  letter-spacing:.003em;margin:.18em auto .35em;max-width:20ch}
.article-dek{font-size:clamp(1.08rem,2.4vw,1.28rem);line-height:1.55;color:var(--ink-soft);
  margin:0 auto;max-width:60ch;font-family:var(--display);font-style:italic;font-weight:500}
.article-meta{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:10px;
  margin-top:24px;padding-top:20px;border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);padding-bottom:20px;
  font-size:.82rem;letter-spacing:.04em;color:var(--ink-faint)}
.article-meta .byline{font-weight:700;color:var(--accent-deep);text-transform:uppercase;
  letter-spacing:.1em;font-size:.72rem}
.article-meta .dot{color:var(--line-strong)}
.article-hero{max-width:var(--maxw-read);margin:clamp(24px,3.5vw,36px) auto 0}
.article-hero img{width:100%;aspect-ratio:16/9;object-fit:cover;
  border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-tint)}
.article-body{max-width:var(--maxw-read);margin-inline:auto;padding-top:clamp(26px,3.5vw,40px)}

/* hub head mirrors the article head, centred index page */
.hub-head{max-width:var(--maxw-read);margin-inline:auto;padding-top:clamp(30px,5vw,56px);
  text-align:center}
.hub-head .breadcrumb{justify-content:center}
.hub-head .article-title{margin-bottom:.3em}
.hub-head .article-dek{margin-bottom:0}

/* ---------- prose ---------- */
.prose{font-size:1.12rem;line-height:1.74;color:var(--ink)}
.prose>p:first-of-type{color:var(--ink-soft)}
.prose p{margin:0 0 1.2em}
/* drop cap — engraved Lora initial in terracotta */
.article-body .prose>p:first-of-type::first-letter,
.explainer .prose>p:first-of-type::first-letter{
  float:left;font-family:var(--display);font-weight:600;font-size:3.5em;line-height:.74;
  padding:.04em .12em 0 0;color:var(--terra-deep)}
.prose h2{font-family:var(--display);font-weight:600;font-size:clamp(1.4rem,3.2vw,1.85rem);
  line-height:1.2;margin:1.9em 0 .5em;padding-top:.55em}
.prose h2::before{content:"";display:block;width:42px;height:1px;background:var(--terra);margin-bottom:.7em}
.prose h3{font-family:var(--display);font-weight:600;font-size:1.3rem;margin:1.7em 0 .45em}
.prose a{color:var(--accent-dark);text-decoration:underline;text-decoration-thickness:1px;
  text-underline-offset:2px;text-decoration-color:var(--line-strong)}
.prose a:hover{text-decoration-color:var(--accent);text-decoration-thickness:2px}
.prose ul,.prose ol{padding-left:1.3em;margin:0 0 1.25em}
.prose li{margin:.4em 0}
.prose li::marker{color:var(--terra)}
.prose strong{font-weight:700;color:var(--ink)}
.prose blockquote{margin:1.8em 0;padding:.3em 0 .3em 1.5em;border-left:2px solid var(--terra);
  font-family:var(--display);font-style:italic;font-weight:500;font-size:1.3rem;line-height:1.5;
  color:var(--ink-soft)}
.prose hr{border:0;border-top:1px solid var(--line);margin:2.4em 0}
.prose img{border:1px solid var(--line);border-radius:var(--radius);margin:1.5em 0}
.prose table{width:100%;border-collapse:collapse;margin:1.7em 0;font-size:.98rem;
  display:block;overflow-x:auto;border:1px solid var(--line)}
.prose th,.prose td{border:1px solid var(--line);padding:11px 14px;text-align:left;vertical-align:top}
.prose th{background:var(--bg-tint);font-family:var(--sans);font-weight:700;font-size:.78rem;
  text-transform:uppercase;letter-spacing:.06em;color:var(--accent-deep)}
.prose tbody tr:nth-child(even){background:color-mix(in srgb,var(--bg-tint) 40%,var(--bg-card))}
.prose code{background:var(--bg-tint);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:.1em .4em;font-size:.92em}

figure.diagram{margin:1.8em 0;text-align:center}
figure.diagram img{max-width:100%;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--bg-card);padding:14px;margin-inline:auto}
figure.diagram figcaption{font-size:.88rem;color:var(--ink-faint);margin-top:.7em;font-style:italic}

/* affiliate product CTA */
.product-cta{display:flex;align-items:center;gap:22px;border:1px solid var(--line);
  border-radius:var(--radius);background:var(--bg-card);padding:18px 20px;margin:1.7em 0;
  box-shadow:var(--shadow-sm)}
.product-cta img{flex:none;width:128px;height:128px;object-fit:contain;background:#fff;
  border:1px solid var(--line-soft);border-radius:var(--radius-sm);margin:0}
.product-cta .cta-side{flex:1;min-width:0}
.product-cta .cta-note{display:block;color:var(--ink-faint);font-size:.86rem;margin-top:.5em;font-style:italic}
.amazon-btn{display:inline-flex;align-items:center;gap:8px;background:var(--terra);color:#fff;
  font-weight:700;font-size:.95rem;padding:12px 24px;border-radius:var(--radius-sm);
  text-decoration:none;transition:background .15s}
.amazon-btn:hover{background:var(--terra-deep);text-decoration:none}
@media(max-width:520px){.product-cta{flex-direction:column;text-align:center}}

.explainer{padding-top:clamp(42px,6vw,66px)}
.explainer .prose{max-width:var(--maxw-read);margin-inline:auto;
  border-top:1px solid var(--line);padding-top:clamp(26px,4vw,40px)}
.related{padding-bottom:8px}

/* ---------- calculators / tools ---------- */
.calc{border:1px solid var(--line);border-radius:var(--radius);padding:24px;
  background:var(--bg-tint);margin:1.7em 0;box-shadow:var(--shadow-sm)}
.calc h3{margin:.1em 0 .8em;font-family:var(--display)}
.calc .row{display:flex;flex-wrap:wrap;gap:14px 22px;align-items:flex-end;margin-bottom:14px}
.calc .field{display:flex;flex-direction:column;gap:5px;font-size:.88rem;color:var(--ink-soft)}
.calc input[type=number]{font-size:1rem;padding:10px 12px;border:1px solid var(--line);
  border-radius:var(--radius-sm);width:140px;background:#fff}
.calc input:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 16%,transparent)}
.calc button{background:var(--accent);color:#fff;border:0;border-radius:var(--radius-sm);
  padding:12px 22px;font-size:1rem;font-weight:600;cursor:pointer;font-family:var(--sans)}
.calc button:hover{background:var(--accent-dark)}
.calc .result{margin-top:16px;padding:18px;border-radius:var(--radius);background:#fff;
  border:1px solid var(--line);display:none}
.calc .result.show{display:block}
.calc .big{font-size:1.5rem;font-weight:600;color:var(--ink);font-family:var(--display)}
.calc .muted{color:var(--ink-faint);font-size:.92rem}
.conv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.tool-list{list-style:none;padding:0;margin:1.4em 0;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.tool-list a{display:block;border:1px solid var(--line);border-radius:var(--radius);padding:20px;
  background:var(--bg-card);box-shadow:var(--shadow-sm);transition:transform .16s,box-shadow .16s}
.tool-list a:hover{transform:translateY(-3px);box-shadow:var(--shadow)}

/* =========================================================================
   NEWSLETTER (enamel-green band)
   ========================================================================= */
.newsletter{margin-top:clamp(50px,7vw,86px);background:var(--navy);color:var(--cream);
  position:relative;overflow:hidden;
  border-top:1px solid rgba(246,241,230,.1)}
.newsletter::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(closest-side at 88% 10%, color-mix(in srgb,var(--terra) 24%,transparent), transparent),
    repeating-linear-gradient(135deg, rgba(246,241,230,.018) 0 2px, transparent 2px 22px)}
.newsletter-inner{position:relative;display:grid;gap:24px;align-items:center;
  padding:clamp(38px,5vw,60px) 0}
.newsletter h2{color:var(--cream);font-family:var(--display);font-weight:600;
  font-size:clamp(1.5rem,3.2vw,2.1rem);margin:.3em 0 .35em;line-height:1.14}
.newsletter p{color:var(--cream-soft);margin:0;max-width:50ch;line-height:1.55}
.newsletter-form{display:flex;gap:10px;flex-wrap:wrap}
.newsletter-form input{flex:1 1 240px;min-width:0;padding:14px 16px;border-radius:var(--radius-sm);
  border:1px solid rgba(246,241,230,.26);background:rgba(246,241,230,.07);
  color:var(--cream);font:1rem var(--sans)}
.newsletter-form input::placeholder{color:var(--cream-faint)}
.newsletter-form input:focus{outline:none;border-color:color-mix(in srgb,var(--terra) 64%,var(--cream));
  background:rgba(246,241,230,.12)}
.newsletter-form button{background:var(--terra);color:#fff;border:0;border-radius:var(--radius-sm);
  padding:14px 28px;font:700 .95rem var(--sans);cursor:pointer;transition:background .15s;
  letter-spacing:.04em}
.newsletter-form button:hover{background:var(--terra-deep)}

/* =========================================================================
   FOOTER (warm magazine, centred shop-sign + columns)
   ========================================================================= */
.site-footer{background:var(--navy-deep);color:var(--cream-soft)}
.footer-sign{display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:clamp(40px,5vw,58px) var(--gut) 0}
.footer-logo{display:inline-flex;align-items:center;gap:10px;font-family:var(--display);
  font-weight:600;font-size:clamp(1.5rem,4vw,2rem);color:var(--cream);letter-spacing:.01em}
.footer-logo .brand-mark{color:var(--cream-soft)}
.footer-logo .brand-mark svg{height:30px;width:auto}
.footer-motto{color:var(--cream-faint);font-family:var(--display);font-style:italic;
  margin:.7em 0 0;max-width:46ch;line-height:1.5}
.footer-rule{display:block;width:min(280px,60%);height:1px;margin:22px auto 0;
  background:linear-gradient(90deg,transparent,rgba(246,241,230,.28) 20%,rgba(246,241,230,.28) 80%,transparent)}

.footer-grid{display:grid;gap:30px 28px;padding:clamp(30px,4vw,44px) var(--gut) clamp(28px,3vw,38px)}
.footer-col h3{font-family:var(--display);font-weight:600;font-size:1.02rem;color:var(--cream);
  margin:0 0 .9em}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin:.5em 0}
.footer-col a{color:var(--cream-soft);font-size:.93rem;border-bottom:1px solid transparent;
  padding-bottom:1px}
.footer-col a:hover{color:var(--cream);border-bottom-color:color-mix(in srgb,var(--terra) 64%,var(--cream))}
.footer-blurb{color:var(--cream-faint);font-size:.93rem;line-height:1.6;margin:0 0 1.1em;max-width:40ch}
.footer-contact{font-size:.9rem;color:var(--cream-faint)}
.footer-contact a{color:var(--cream-soft);font-weight:700}
.footer-contact a:hover{color:var(--cream)}

.footer-bar{border-top:1px solid rgba(246,241,230,.1)}
.footer-bar-inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:8px 24px;
  padding:18px 0;font-size:.78rem;color:var(--cream-faint)}
.footer-disclaimer{max-width:62ch}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */

/* small tablets: roomier masthead + tagline returns under the wordmark */
@media(min-width:560px){
  .brand-tagline{display:block;font-family:var(--sans);font-style:italic;
    font-size:.92rem;color:var(--ink-soft);letter-spacing:0;max-width:42ch;margin-top:2px}
  .shopbar-inner{flex-wrap:nowrap}
}

@media(min-width:680px){
  .footer-grid{grid-template-columns:1.7fr 1fr 1fr;max-width:var(--maxw);margin-inline:auto;width:100%}
  .contents-link{gap:20px}
}

/* desktop: reveal the shelf nav + desktop search, hide the burger, drop the drawer */
@media(min-width:880px){
  .masthead-inner{padding:24px 0 18px}
  .brand-text{font-size:clamp(2rem,3.4vw,2.7rem)}
  .brand-mark svg{height:44px}
  .burger{display:none}
  .search--desktop{display:flex;width:200px}
  .shelf-nav{display:block}
  .nav-drawer,.nav-scrim{display:none}
  .footer-grid{grid-template-columns:1.8fr 1fr 1fr 1fr}
}

@media(min-width:1000px){
  .lead{grid-template-columns:minmax(0,1.65fr) minmax(0,1fr);
    gap:clamp(40px,4vw,56px);align-items:start}
  .lead-feature-body{padding-top:20px}
}

@media(prefers-reduced-motion:reduce){
  *{transition:none!important;scroll-behavior:auto!important;animation:none!important}
}