/* ═══════════════════════════════════════════════════════════════════════
   STY site.css — shared chrome.
   ═══════════════════════════════════════════════════════════════════════

   Loaded by every shipping page. Contains rules that are byte-identical
   (or close enough) across the 11-file site:

     1. Design tokens (bone scale, ink/lift, brass, refined serif, etc.)
     2. CSS reset + base typography defaults
     3. Skip link + visually-hidden helper
     4. body::after film-grain overlay
     5. Commerce masthead strip (.ed-masthead*)
     6. Primary nav (.nav, .nav-c, .nav-a, .nav-icon, .nav-bag, .ham)
     7. Mobile menu (.mm)
     8. Footer chrome (.ft, .ft-top, .ft-cols, .ft-col, .ft-social,
        .ft-list-form, .ft-btm, .ft-stamp)

   What's deliberately NOT here:

     - .ann announcement strip — has two variants (static vs marquee).
       Stays inline per page.
     - All page-specific CSS namespaces: .ed-* (editorial), .wp-*
       (waypoint), .mf-* (manifesto), .cp-* (collection pages),
       .pdp-* (product detail pages). Stay inline per page.

   Pages may override any rule below with their own inline <style>
   block (loaded after this file). Cascade resolves correctly.

   Caching: served with `Cache-Control: public, max-age=31536000,
   immutable` per the existing /assets/css/* rule in _headers. Bust by
   changing the filename if the contents change in a way that would
   create stale-cache pain.
   ═══════════════════════════════════════════════════════════════════════ */


/* ───────────── RESET ───────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
h1,h2,h3,h4,h5,h6{font-weight:inherit;font-size:inherit;line-height:inherit}


/* ───────────── DESIGN TOKENS ───────────── */
:root{
  --ink:#050403;--ink-lift:#0a0908;--bone:#c9bfa8;--bone-soft:#b5ad99;--bone-pale:#d8d0bd;--bone-dim:#837b6a;
  --bg:var(--ink);--sf:#0d0c0b;--el:#1a1816;--bd:rgba(201,191,168,.08);
  --t1:var(--bone);--t2:var(--bone-soft);--t3:rgba(201,191,168,.2);
  --accent:var(--bone-dim);--olive:var(--bone-soft);--green:#1a1816;
  /* Manifesto inheritance: brass accent for line commissions + section
     markers (single source of truth — same token used on /manifesto +
     homepage). Refined serif for editorial supporting copy on chapters
     + Waypoint line-level copy + hero subhead. */
  --brass:#b08d57;
  --refined:'Fraunces',Georgia,'Times New Roman',serif;
  --display:"Druk","Anton",sans-serif;--sans:'Inter',sans-serif;--serif:'Cormorant Garamond',serif;--condensed:'Inter',sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
  --gutter:56px;
}


/* ───────────── BASE ───────────── */
html{background:var(--bg);overflow-x:hidden}
body{font-family:var(--sans);background:var(--bg);color:var(--t1);overflow-x:hidden;-webkit-font-smoothing:antialiased}
::selection{background:rgba(147,148,116,.35)}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{cursor:pointer;border:none;background:none;font-family:inherit;color:inherit}

/* Subtle film grain — sits above all content, below interactive elements. */
body::after{content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.015;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:128px}


/* ───────────── ACCESSIBILITY HELPERS ───────────── */
.skip-link{position:absolute;top:-40px;left:8px;background:var(--t1);color:var(--bg);padding:8px 14px;font-family:var(--sans);font-size:.65rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;z-index:10000;transition:top .2s}
.skip-link:focus{top:8px}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}


/* ───────────── COMMERCE MASTHEAD STRIP ───────────── */
/* Top-most strip on the page (used by index + manifesto): shipping +
   returns line. Replaces the prior announce strip and the publication-
   masthead strip — does both jobs in one quiet line. The fixed nav
   sits below it. Pages without an .ed-masthead element are unaffected. */
.ed-masthead{background:var(--green);padding:9px 24px;display:flex;align-items:center;justify-content:center;gap:24px;position:relative;z-index:201;line-height:1}
.ed-masthead-r{font-family:var(--condensed);font-size:.6rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--t2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media(max-width:768px){
  .ed-masthead{padding:9px 16px;gap:14px}
  .ed-masthead-r{font-size:.5rem;letter-spacing:.16em}
}


/* ───────────── COLOPHON ───────────── */
.ed-colophon{font-family:var(--condensed);font-size:.65rem;font-weight:400;font-style:italic;letter-spacing:.04em;color:var(--t3);text-align:center;padding:12px 24px 0;line-height:1.5;opacity:.75}


/* ───────────── PRIMARY NAV ───────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:0 40px;height:56px;transition:background .4s,backdrop-filter .4s,top .3s}
.nav.scrolled{background:rgba(41,39,40,.94);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
/* Masthead bumps the nav down so it sits below the strip. On scroll, the
   nav slides to top:0 (masthead scrolls away with content). */
.nav.has-masthead{top:32px}
.nav.has-masthead.scrolled{top:0}
.nav-logo{font-family:var(--display);font-size:1.15rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--t1)}
.nav-logo img{height:22px;width:auto;display:block;max-width:140px}
.nav-c{display:flex;gap:28px;position:absolute;left:50%;transform:translateX(-50%)}
.nav-a{font-family:var(--sans);font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--t2);transition:color .3s}
.nav-a:hover{color:var(--t1)}
.nav-r{display:flex;gap:18px;align-items:center}
.nav-icon{color:var(--t2);transition:color .3s;position:relative}
.nav-icon:hover{color:var(--t1)}
.nav-icon svg{display:block}
/* Bag indicator — text + count, replaces the dot. Reads as storefront, not magazine. */
.nav-bag{display:inline-flex;align-items:center;gap:8px}
.nav-bag-label{font-family:var(--condensed);font-size:.6rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:inherit;line-height:1}
.nav-bag-count{font-variant-numeric:tabular-nums}
@media(max-width:540px){
  .nav-bag-label{display:none}
}
.ham{color:var(--t1);display:none}
@media(max-width:900px){
  .nav{padding:0 24px}
  .nav-c{display:none}
  .ham{display:block}
}


/* ───────────── MOBILE MENU ───────────── */
.mm{position:fixed;inset:0;background:var(--bg);z-index:999;display:flex;flex-direction:column;justify-content:center;padding:0 32px;transform:translateY(-100%);transition:transform .6s var(--ease);pointer-events:none}
.mm.open{transform:translateY(0);pointer-events:all}
.mm a{font-family:var(--display);font-size:clamp(2.5rem,10vw,4.5rem);font-weight:400;text-transform:uppercase;color:var(--t1);display:block;padding:6px 0;opacity:0;transform:translateY(24px);transition:opacity .5s,transform .5s var(--ease)}
.mm.open a{opacity:1;transform:none}
.mm.open a:nth-child(1){transition-delay:.08s}
.mm.open a:nth-child(2){transition-delay:.16s}
.mm.open a:nth-child(3){transition-delay:.24s}
.mm.open a:nth-child(4){transition-delay:.32s}
.mm.open a:nth-child(5){transition-delay:.40s}
.mm.open a:nth-child(6){transition-delay:.48s}
.mm .mm-x{position:absolute;top:20px;right:24px;color:var(--t1);padding:8px}


/* ───────────── FOOTER CHROME ───────────── */
.ft{padding:80px 56px 32px;display:flex;flex-direction:column;gap:48px;border-top:0.5px solid var(--bd);background:var(--ink-lift)}
.ft-top{display:grid;grid-template-columns:1fr 2fr;gap:56px;align-items:start}
.ft-brand{display:flex;flex-direction:column;gap:12px}
.ft-logo img{display:block;height:36px;width:auto;max-width:240px}
.ft-origin{font-family:var(--serif);font-style:italic;font-size:.85rem;color:var(--t3);margin-top:8px;max-width:30ch;line-height:1.5}
.ft-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.ft-col{display:flex;flex-direction:column;gap:8px}
.ft-col .ft-ch{font-family:var(--sans);font-size:.5rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--t2);margin-bottom:14px}
.ft-col a{display:block;font-family:var(--sans);font-size:.72rem;color:var(--t2);font-weight:400;transition:color .25s;line-height:2.2}
.ft-col a:hover{color:var(--t1)}
.ft-social{display:flex;gap:10px;margin-bottom:16px}
.ft-social a{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:0.5px solid var(--bd);color:var(--t2);transition:all .3s}
.ft-social a:hover{border-color:var(--t1);color:var(--t1);background:rgba(201,191,168,.04)}
.ft-social svg{width:14px;height:14px}
.ft-promise{font-family:var(--serif);font-style:italic;font-size:.75rem;color:var(--t3);line-height:1.5;max-width:28ch}
/* Footer email field — compact safety-net capture for visitors who scrolled
   past the inline section without joining. Quieter than the inline form. */
.ft-list-form{display:flex;border:0.5px solid rgba(201,191,168,.22);transition:border-color .25s;margin-bottom:14px}
.ft-list-form:focus-within{border-color:var(--t2)}
.ft-list-form input[type=email]{flex:1;font-family:var(--sans);font-size:.78rem;color:var(--t1);background:transparent;border:0;padding:10px 12px;outline:none;min-width:0}
.ft-list-form input[type=email]::placeholder{color:var(--bone-dim)}
.ft-list-submit{font-family:var(--sans);font-size:1rem;color:var(--t1);background:transparent;border:0;border-left:0.5px solid rgba(201,191,168,.22);padding:10px 14px;cursor:pointer;transition:background .25s,color .25s}
.ft-list-submit:hover{background:rgba(201,191,168,.06);color:var(--t1)}
.ft-list-status{font-family:var(--sans);font-size:.7rem;color:var(--bone-dim);margin:0 0 14px;line-height:1.4;min-height:1em}
.ft-list-status.is-success{color:var(--t2)}
.ft-list-status.is-error{color:#c98e6a}
.ft-list-form.is-success{display:none}
.ft-btm{display:flex;justify-content:space-between;align-items:center;padding-top:32px;border-top:0.5px solid var(--bd);gap:24px;flex-wrap:wrap}
.ft-btm-l,.ft-btm-r{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.ft-btm-l{font-family:var(--sans);font-size:.6rem;color:var(--t2);letter-spacing:.05em}
.ft-sep{opacity:.5}
.ft-btm-r a{font-family:var(--sans);font-size:.55rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--t2);transition:color .25s}
.ft-btm-r a:hover{color:var(--t1)}
.ft-stamp{font-family:var(--display);font-weight:700;font-size:.85rem;letter-spacing:.2em;text-transform:uppercase;color:var(--t3);text-align:center;padding-top:16px;opacity:.55}
@media(max-width:960px){.ft-top{grid-template-columns:1fr;gap:40px}.ft-cols{grid-template-columns:repeat(2,1fr);gap:32px}}
@media(max-width:600px){.ft{padding:56px 24px 32px}.ft-cols{grid-template-columns:1fr 1fr;gap:24px}.ft-btm{flex-direction:column;align-items:flex-start}.ft-logo img{height:30px}}
@media(max-width:400px){.ft-cols{grid-template-columns:1fr}}
