/* ============================================================
   NICK & TIN — "Heritage Club Broadsheet"
   Purveyors of Fine Squash Equipment · Est. 2019
   Playfair Display (masthead) · EB Garamond (body) · Courier Prime (ledger)
   ============================================================ */

@font-face{
  font-family:"Playfair Display";
  src:url("../fonts/playfair.woff2") format("woff2");
  font-weight:400 800; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"EB Garamond";
  src:url("../fonts/garamond.woff2") format("woff2");
  font-weight:400 700; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Courier Prime";
  src:url("../fonts/courierprime-400.woff2") format("woff2");
  font-weight:400; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Courier Prime";
  src:url("../fonts/courierprime-700.woff2") format("woff2");
  font-weight:700; font-style:normal; font-display:swap;
}

/* ── tokens ─────────────────────────────────────────────── */
:root{
  --paper:#F3EAD9;
  --paper-2:#EFE3CD;      /* slightly deeper card cream */
  --walnut:#2A1F16;
  --walnut-2:#1E160F;
  --green:#1F3D2F;
  --green-2:#173026;
  --brass:#B0894E;
  --brass-hi:#C9A567;
  --ink:#1A140D;
  --ink-soft:#5C4A2E;
  --ledger:#C8B99A;
  --rule:#B7A67F;

  --disp:"Playfair Display",Georgia,"Times New Roman",serif;
  --body:"EB Garamond",Georgia,"Times New Roman",serif;
  --mono:"Courier Prime",ui-monospace,Courier,monospace;

  --wrap:1160px;
  --gutter:clamp(1.15rem,4.5vw,4rem);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
[id]{scroll-margin-top:64px}

body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:clamp(1.05rem,1.01rem + .22vw,1.16rem);
  line-height:1.72;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
/* faint aged-paper vignette */
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(120% 90% at 50% -10%,rgba(176,137,78,.06),transparent 60%),
    radial-gradient(140% 120% at 50% 120%,rgba(42,31,22,.05),transparent 55%);
}

img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}

/* ── typography ────────────────────────────────────────── */
.display,h1,h2,h3{
  font-family:var(--disp);
  font-weight:700;
  line-height:1.08;
  letter-spacing:-.005em;
  color:var(--walnut);
}
h1{font-size:clamp(2.6rem,6.4vw,5rem)}
h2{font-size:clamp(1.9rem,4vw,3rem)}
h3{font-size:clamp(1.25rem,2.1vw,1.6rem);line-height:1.14}
p{max-width:66ch}

.label{
  font-family:var(--mono);
  font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  font-weight:700;color:var(--brass);
}
.smallcaps{font-variant:small-caps;letter-spacing:.08em}
.mono{font-family:var(--mono);letter-spacing:.02em}
.muted{color:var(--ink-soft)}
.lead{font-size:clamp(1.12rem,1.05rem + .5vw,1.4rem);line-height:1.55;color:var(--ink-soft);font-style:italic}

/* drop cap for intro paragraphs */
.intro::first-letter{
  float:left;font-family:var(--disp);font-weight:700;
  font-size:4.6rem;line-height:.72;
  margin:.08em .12em 0 0;color:var(--green);
}

/* ornamental separator */
.ornament{
  text-align:center;color:var(--brass);
  font-size:1.05rem;letter-spacing:.5em;margin:1.6rem 0;
}

/* ── rules ─────────────────────────────────────────────── */
.rule-thick{border-top:2px solid var(--walnut)}
.rule-brass{border-top:1px solid var(--brass)}
.rule-ledger{border-top:1px solid var(--ledger)}
.rule-double{border-top:3px double var(--walnut)}

/* ── layout scaffolding ────────────────────────────────── */
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(3rem,7vw,6rem)}
.section-tight{padding-block:clamp(2rem,4vw,3.2rem)}
.stack>*+*{margin-top:1.1rem}

.band-green{background:var(--green);color:var(--paper)}
.band-green h2,.band-green h3{color:var(--paper)}
.band-cream2{background:var(--paper-2)}

/* section masthead (interior of a page) */
.sec-rule{
  display:flex;align-items:baseline;justify-content:space-between;
  gap:1.5rem;flex-wrap:wrap;
  border-top:2px solid var(--walnut);border-bottom:1px solid var(--brass);
  padding:.7rem 0;margin-bottom:clamp(1.8rem,3.5vw,2.8rem);
}
.band-green .sec-rule{border-top-color:var(--brass);border-bottom-color:rgba(200,185,154,.4)}
.sec-rule .sec-head{font-family:var(--disp);font-weight:700;font-size:clamp(1.6rem,3vw,2.3rem);color:var(--walnut)}
.band-green .sec-rule .sec-head{color:var(--paper)}
.sec-rule .sec-sub{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.band-green .sec-rule .sec-sub{color:var(--brass-hi)}

/* ── buttons ───────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--mono);font-size:.76rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  padding:.85rem 1.6rem;border:1.5px solid transparent;border-radius:1px;
  transition:transform .15s ease,background .15s ease,color .15s ease,border-color .15s ease;
  cursor:pointer;
}
.btn:hover{transform:translateY(-1px)}
.btn-brass{background:var(--brass);color:var(--walnut-2)}
.btn-brass:hover{background:var(--brass-hi)}
.btn-outline{border-color:var(--walnut);color:var(--walnut);background:transparent}
.btn-outline:hover{background:var(--walnut);color:var(--paper)}
.btn-outline.on-dark{border-color:var(--brass);color:var(--paper)}
.btn-outline.on-dark:hover{background:var(--brass);color:var(--walnut-2)}

/* ── crest / monogram ──────────────────────────────────── */
.crest{display:inline-block;line-height:0}

/* ═══════════════════════════════════════════════════════
   HOME MASTHEAD (centered broadsheet nameplate)
   ═══════════════════════════════════════════════════════ */
.masthead{
  background:var(--walnut);color:var(--paper);
  border-bottom:2px solid var(--brass);
  text-align:center;
}
.masthead .mast-inner{max-width:var(--wrap);margin-inline:auto;padding:clamp(1.4rem,3vw,2.2rem) var(--gutter) 0}
.masthead .crest{margin-bottom:.5rem}
.masthead .nameplate{
  font-family:var(--disp);font-weight:800;
  font-size:clamp(2.4rem,7vw,4.6rem);line-height:.95;color:var(--paper);
  letter-spacing:.01em;
}
.masthead .nameplate em{font-style:italic;font-weight:400;color:var(--brass-hi)}
.masthead .nameplate-sub{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--brass-hi);margin-top:.7rem;
}
.masthead .mast-rule{
  max-width:var(--wrap);margin:1rem auto 0;
  border-top:1px solid rgba(200,185,154,.35);
}
.site-nav{
  display:flex;justify-content:center;align-items:center;flex-wrap:wrap;
  max-width:var(--wrap);margin-inline:auto;padding:.85rem var(--gutter);
}
.site-nav a{
  font-family:var(--body);font-weight:600;font-size:.94rem;
  letter-spacing:.13em;text-transform:uppercase;color:var(--paper);
  padding:.15rem clamp(.7rem,2vw,1.4rem);position:relative;
}
.site-nav a+a{border-left:1px solid rgba(176,137,78,.5)}
.site-nav a:hover,.site-nav a.active{color:var(--brass-hi)}

/* ═══════════════════════════════════════════════════════
   INTERIOR PAGE MASTHEAD BAND (theme persists everywhere)
   ═══════════════════════════════════════════════════════ */
.page-mast{
  background:var(--walnut);color:var(--paper);
  border-bottom:2px solid var(--brass);
}
.page-mast .pm-top{
  max-width:var(--wrap);margin-inline:auto;
  padding:clamp(1rem,2.2vw,1.6rem) var(--gutter) .8rem;
  display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap;
}
.page-mast .pm-word{font-family:var(--disp);font-weight:800;font-size:clamp(1.4rem,3.4vw,2rem);color:var(--paper);letter-spacing:.02em}
.page-mast .pm-word em{font-style:italic;font-weight:400;color:var(--brass-hi)}
.page-mast .pm-nav{
  display:flex;justify-content:center;flex-wrap:wrap;
  max-width:var(--wrap);margin-inline:auto;padding:0 var(--gutter) .3rem;
  border-top:1px solid rgba(200,185,154,.28);
}
.page-mast .pm-nav a{
  font-family:var(--body);font-weight:600;font-size:.84rem;letter-spacing:.13em;text-transform:uppercase;
  color:var(--paper);padding:.55rem clamp(.55rem,1.6vw,1.15rem);
}
.page-mast .pm-nav a+a{border-left:1px solid rgba(176,137,78,.4)}
.page-mast .pm-nav a:hover,.page-mast .pm-nav a.active{color:var(--brass-hi)}

/* the page title band (green) with brass rule + courier tick */
.page-head{background:var(--green);color:var(--paper);border-bottom:2px solid var(--walnut)}
.page-head .ph-inner{
  max-width:var(--wrap);margin-inline:auto;
  padding:clamp(2.2rem,5vw,3.6rem) var(--gutter) clamp(1.4rem,3vw,2rem);
}
.page-head .label{color:var(--brass-hi)}
.page-head h1{color:var(--paper);margin:.5rem 0 .7rem;font-size:clamp(2.2rem,5.2vw,3.6rem)}
.page-head .lead{color:rgba(243,234,217,.82)}
.page-head .brass-rule{border-top:1px solid var(--brass);margin-top:1.3rem;padding-top:.9rem}
.page-head .tick{
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(243,234,217,.62);
}
.page-head .tick b{color:var(--brass-hi);font-weight:700}
.page-head .tick a{color:var(--brass-hi)}

/* ═══════════════════════════════════════════════════════
   BROADSHEET HERO (home)
   ═══════════════════════════════════════════════════════ */
.hero{background:var(--paper)}
.hero .bs-banner{text-align:center;padding:clamp(1.8rem,4vw,3rem) var(--gutter) 0;max-width:var(--wrap);margin-inline:auto}
.hero .bs-banner .kicker{font-family:var(--mono);font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--brass);display:block;margin-bottom:.6rem}
.hero .bs-title{font-family:var(--disp);font-weight:800;font-size:clamp(2.8rem,9vw,6.5rem);line-height:.92;color:var(--walnut);letter-spacing:.005em}
.hero .bs-date{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);
  margin-top:1rem;padding-top:.9rem;
  border-top:2px solid var(--walnut);
  display:flex;justify-content:center;gap:clamp(.6rem,2vw,1.6rem);flex-wrap:wrap;
  position:relative;
}
.hero .bs-date::after{content:"";position:absolute;left:0;right:0;top:3px;border-top:1px solid var(--brass)}

.hero-body{
  max-width:var(--wrap);margin:clamp(1.8rem,4vw,2.8rem) auto 0;
  padding:0 var(--gutter) clamp(2.5rem,5vw,4rem);
  display:grid;grid-template-columns:1.55fr 1px 1fr;gap:clamp(1.5rem,4vw,3rem);
}
.hero-main .kicker{font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass);font-weight:700}
.hero-main h1{margin:.5rem 0 1rem;font-size:clamp(2.1rem,4.6vw,3.5rem);line-height:1.04}
.hero-fig{overflow:hidden;background:var(--green);border:1px solid var(--rule);margin:1.4rem 0}
.hero-fig img{width:100%;aspect-ratio:16/9;object-fit:cover}
.v-rule{background:var(--walnut);width:1px}
.hero-aside .aside-head{
  font-family:var(--disp);font-weight:700;font-size:1.15rem;color:var(--walnut);
  border-bottom:2px solid var(--walnut);padding-bottom:.5rem;margin-bottom:.4rem;
  text-align:center;font-variant:small-caps;letter-spacing:.06em;
}

/* classified ad entry (aside + catalogue) */
.cat-entry{display:flex;flex-direction:column;gap:.15rem;padding:.95rem 0;border-bottom:1px solid var(--ledger)}
.cat-entry .cat-label{font-family:var(--mono);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);font-weight:700}
.cat-entry .cat-name{font-family:var(--disp);font-weight:700;font-size:1.1rem;color:var(--walnut);line-height:1.15}
.cat-entry a.cat-name:hover{color:var(--green)}
.cat-entry .cat-desc{font-style:italic;color:var(--ink-soft);font-size:.98rem;line-height:1.4}
.cat-entry .cat-price{font-family:var(--mono);font-weight:700;color:var(--brass);font-size:1rem;margin-top:.15rem}
.cat-entry .cat-read{font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--green);font-weight:700;margin-top:.2rem}
.cat-entry .cat-read:hover{color:var(--brass)}

@media(max-width:820px){
  .hero-body{grid-template-columns:1fr}
  .v-rule{display:none}
  .hero-aside{border-top:2px solid var(--walnut);padding-top:1.4rem}
}

/* ═══════════════════════════════════════════════════════
   CLASSIFIED-CATALOGUE COLUMNS (products)
   ═══════════════════════════════════════════════════════ */
.classified{
  column-count:3;column-gap:0;
}
@media(max-width:900px){.classified{column-count:2}}
@media(max-width:600px){.classified{column-count:1}}
.prod-card{
  break-inside:avoid;
  padding:1.4rem clamp(1rem,2vw,1.6rem);
  border-bottom:1px solid var(--ledger);
  border-right:1px solid var(--ledger);
  display:flex;flex-direction:column;gap:.4rem;
}
/* strip rightmost rule per row-ish: remove for last column items */
.classified .prod-card:nth-child(3n){border-right:none}
@media(max-width:900px){.classified .prod-card:nth-child(3n){border-right:1px solid var(--ledger)}.classified .prod-card:nth-child(2n){border-right:none}}
@media(max-width:600px){.classified .prod-card{border-right:none}}
.prod-card .prod-fig{overflow:hidden;background:var(--green);border:1px solid var(--rule);margin-bottom:.4rem}
.prod-card .prod-fig img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .5s ease}
.prod-card:hover .prod-fig img{transform:scale(1.04)}
.prod-cat{font-family:var(--mono);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);font-weight:700}
.prod-name{font-family:var(--disp);font-weight:700;font-size:1.28rem;color:var(--walnut);line-height:1.12}
a.prod-name:hover{color:var(--green)}
.prod-desc{font-style:italic;color:var(--ink-soft);font-size:1rem;line-height:1.45;margin:.1rem 0}
.prod-price{font-family:var(--mono);font-weight:700;color:var(--brass);font-size:1.15rem}
.prod-link{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--green);font-weight:700;
  border-bottom:1px solid var(--brass);align-self:flex-start;padding-bottom:2px;margin-top:.3rem;
}
.prod-link:hover{color:var(--brass)}

/* ═══════════════════════════════════════════════════════
   LEDGER TABLE (catalogue index / about principles)
   ═══════════════════════════════════════════════════════ */
.ledger-row{
  display:grid;grid-template-columns:2.4rem 1fr 8rem 5rem;gap:1rem;align-items:baseline;
  padding:.85rem 0;border-top:1px solid var(--ledger);
  font-family:var(--body);
}
.band-green .ledger-row{border-top-color:rgba(200,185,154,.28)}
.ledger-row .n{font-family:var(--mono);font-size:.72rem;color:var(--brass);font-weight:700}
.ledger-row .nm{font-family:var(--disp);font-weight:700;font-size:1.1rem;color:var(--walnut)}
.band-green .ledger-row .nm{color:var(--paper)}
.ledger-row .dot{border-bottom:1px dotted var(--rule);transform:translateY(-.2rem)}
.ledger-row .val{font-family:var(--mono);font-weight:700;text-align:right;color:var(--brass)}
@media(max-width:560px){.ledger-row{grid-template-columns:2rem 1fr 4rem}.ledger-row .dot{display:none}}

/* ═══════════════════════════════════════════════════════
   THE DISPENSARY (nutra) — green band cards
   ═══════════════════════════════════════════════════════ */
.disp-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1rem,3vw,2rem)}
@media(max-width:680px){.disp-grid{grid-template-columns:1fr}}
.disp-card{
  border:1px solid rgba(200,185,154,.4);background:var(--green-2);
  padding:clamp(1.5rem,3vw,2.2rem);display:flex;flex-direction:column;gap:.55rem;
}
.disp-card .disp-label{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-hi);font-weight:700}
.disp-card .disp-name{font-family:var(--disp);font-weight:700;font-size:1.5rem;color:var(--paper)}
.disp-card .disp-desc{font-style:italic;color:rgba(243,234,217,.8);font-size:1rem}
.disp-card .disp-price{font-family:var(--mono);font-weight:700;color:var(--brass-hi);font-size:1.2rem;margin-top:.2rem}
.disp-card .btn{align-self:flex-start;margin-top:.4rem}

/* ═══════════════════════════════════════════════════════
   MEMBERS' LIBRARY (ebooks)
   ═══════════════════════════════════════════════════════ */
.library-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1rem,3vw,2rem)}
@media(max-width:680px){.library-grid{grid-template-columns:1fr}}
.lib-card{
  background:var(--paper-2);border:1px solid var(--ledger);
  border-left:4px solid var(--brass);
  padding:clamp(1.4rem,3vw,2rem);display:flex;flex-direction:column;gap:.5rem;
}
.lib-card .lib-vol{font-family:var(--mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass);font-weight:700}
.lib-card .lib-title{font-family:var(--disp);font-weight:700;font-size:1.35rem;color:var(--walnut);line-height:1.18}
.lib-card .lib-desc{font-style:italic;color:var(--ink-soft);font-size:1rem}
.lib-card .lib-price{font-family:var(--mono);font-weight:700;color:var(--brass);font-size:1.1rem;margin-top:.2rem}

/* ═══════════════════════════════════════════════════════
   FIELD NOTES (blog teasers) — column layout w/ rules
   ═══════════════════════════════════════════════════════ */
.fn-grid{display:grid;grid-template-columns:1fr 1px 1fr 1px 1fr;gap:clamp(1rem,2.5vw,2rem)}
@media(max-width:820px){.fn-grid{grid-template-columns:1fr}.fn-rule{display:none}}
.fn-rule{background:var(--walnut)}
.fn-col{display:flex;flex-direction:column;gap:.55rem}
.fn-num{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);font-weight:700}
.fn-fig{overflow:hidden;background:var(--green);border:1px solid var(--rule)}
.fn-fig img{width:100%;aspect-ratio:3/2;object-fit:cover;transition:transform .5s ease}
.fn-col:hover .fn-fig img{transform:scale(1.04)}
.fn-title{font-family:var(--disp);font-weight:700;font-size:1.35rem;color:var(--walnut);line-height:1.16}
a.fn-title:hover{color:var(--green)}
.fn-excerpt{font-style:italic;color:var(--ink-soft);font-size:1rem}
.fn-read{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--green);font-weight:700;border-bottom:1px solid var(--brass);align-self:flex-start;padding-bottom:2px}
.fn-read:hover{color:var(--brass)}

/* ═══════════════════════════════════════════════════════
   EDITORIAL SPLIT (about / teaser)
   ═══════════════════════════════════════════════════════ */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.5rem,5vw,4rem);align-items:center}
@media(max-width:820px){.split{grid-template-columns:1fr}}
.split .fig{overflow:hidden;background:var(--green);border:1px solid var(--rule)}
.split .fig img{width:100%;object-fit:cover}

/* ═══════════════════════════════════════════════════════
   PDP
   ═══════════════════════════════════════════════════════ */
.breadcrumb{
  max-width:var(--wrap);margin:0 auto;padding:1rem var(--gutter);
  font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);
}
.breadcrumb a{color:var(--brass);font-weight:700}
.pdp-layout{
  max-width:var(--wrap);margin:0 auto;padding:clamp(1rem,3vw,2rem) var(--gutter) clamp(2.5rem,5vw,4rem);
  display:grid;grid-template-columns:1fr 1px 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:start;
}
@media(max-width:820px){.pdp-layout{grid-template-columns:1fr}.pdp-col-rule{display:none}}
.pdp-col-rule{background:var(--walnut);width:1px}
.pdp-fig{overflow:hidden;background:var(--green);border:1px solid var(--rule)}
.pdp-fig img{width:100%;aspect-ratio:4/3;object-fit:cover}
.pdp-kicker{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);font-weight:700}
.pdp-title{font-family:var(--disp);font-weight:800;font-size:clamp(2rem,4.4vw,3rem);color:var(--walnut);margin:.4rem 0 .5rem}
.pdp-price{font-family:var(--mono);font-weight:700;font-size:1.7rem;color:var(--brass);margin-bottom:.9rem}
.pdp-desc{font-style:italic;color:var(--ink-soft);margin-bottom:1.3rem}
.specs-table{width:100%;border-collapse:collapse;margin-bottom:1.5rem;font-family:var(--body)}
.specs-table th,.specs-table td{text-align:left;padding:.55rem .2rem;border-top:1px solid var(--ledger);font-size:.98rem}
.specs-table th{font-family:var(--mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;width:42%;vertical-align:top}
.specs-table td{color:var(--walnut);font-weight:600}
.pdp-actions{display:flex;gap:.8rem;flex-wrap:wrap}

.related-band{background:var(--paper-2);border-top:2px solid var(--walnut)}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,3vw,2rem)}
@media(max-width:820px){.related-grid{grid-template-columns:1fr}}
.related-grid .prod-card{border:1px solid var(--ledger);background:var(--paper)}

/* ═══════════════════════════════════════════════════════
   PDP — FULL DEPTH (v2)
   ═══════════════════════════════════════════════════════ */
/* gallery: principal plate + two supporting plates, no script */
.pdp-gallery{display:flex;flex-direction:column;gap:.9rem}
.pdp-gallery .pdp-fig-main img{aspect-ratio:4/3}
.pdp-thumbs{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.pdp-thumbs .pdp-fig img{aspect-ratio:1/1}
.plate-cap{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-soft);text-align:center;padding-top:.15rem;
}
.plate-cap b{color:var(--brass);font-weight:700}

/* lead paragraph (drop-cap) in the info column */
.pdp-lead{
  font-size:clamp(1.06rem,1rem + .4vw,1.22rem);line-height:1.6;color:var(--ink);
  margin-bottom:1.4rem;max-width:56ch;
}
.pdp-badges{
  display:flex;gap:.5rem;flex-wrap:wrap;margin:0 0 1.3rem;
}
.pdp-badge{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;
  font-weight:700;color:var(--ink-soft);border:1px solid var(--ledger);
  padding:.34rem .6rem;border-radius:1px;background:var(--paper-2);
}
.pdp-badge b{color:var(--brass)}

/* structured spec ledger — courier figures, dotted leaders */
.spec-ledger{width:100%;border-collapse:collapse;font-family:var(--body)}
.spec-ledger tr{border-top:1px solid var(--ledger)}
.spec-ledger tr:last-child{border-bottom:1px solid var(--ledger)}
.spec-ledger th{
  text-align:left;font-family:var(--body);font-weight:600;color:var(--walnut);
  padding:.72rem .2rem;font-size:1.02rem;font-variant:small-caps;letter-spacing:.04em;
  white-space:nowrap;width:1%;
}
.spec-ledger .lead-cell{border-bottom:1px dotted var(--rule);width:99%}
.spec-ledger td.val{
  text-align:right;font-family:var(--mono);font-weight:700;color:var(--brass);
  padding:.72rem .2rem;font-size:.95rem;white-space:nowrap;
}
@media(max-width:560px){.spec-ledger .lead-cell{display:none}.spec-ledger th{white-space:normal}}

/* included / materials — twin ledger columns */
.pdp-cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,3.2rem)}
@media(max-width:760px){.pdp-cols{grid-template-columns:1fr}}
.spec-list{list-style:none}
.spec-list li{
  display:flex;gap:.7rem;align-items:baseline;
  padding:.6rem 0;border-top:1px solid var(--ledger);font-size:1rem;
}
.spec-list li:last-child{border-bottom:1px solid var(--ledger)}
.spec-list li::before{content:"\25C6";color:var(--brass);font-size:.62rem;position:relative;top:-.12em}
.spec-list li b{color:var(--walnut);font-weight:700}
.band-green .spec-list li{border-color:rgba(200,185,154,.28);color:rgba(243,234,217,.9)}
.band-green .spec-list li b{color:var(--paper)}

/* why we picked it — clubby editorial (green band w/ drop cap) */
.band-green .intro::first-letter{color:var(--brass-hi)}
.pdp-why p{color:rgba(243,234,217,.9);max-width:70ch}
.pdp-why p+p{margin-top:1.1rem}
.pdp-why .signoff{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--brass-hi);font-weight:700;margin-top:1.4rem;
}

/* trust row */
.trust-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
@media(max-width:760px){.trust-row{grid-template-columns:1fr 1fr}}
.trust-item{
  text-align:center;padding:1.3rem 1rem;
  border:1px solid var(--ledger);background:var(--paper-2);
}
.trust-item .ti-mark{font-size:1.5rem;color:var(--brass);line-height:1}
.trust-item .ti-head{font-family:var(--disp);font-weight:700;font-size:1.06rem;color:var(--walnut);margin-top:.4rem}
.trust-item .ti-sub{
  font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-soft);margin-top:.3rem;
}

/* the members' book — two static reviews */
.reviews-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3rem)}
@media(max-width:760px){.reviews-grid{grid-template-columns:1fr}}
.review{
  background:var(--paper-2);border:1px solid var(--ledger);border-left:4px solid var(--brass);
  padding:clamp(1.5rem,3vw,2.1rem);display:flex;flex-direction:column;gap:.6rem;
}
.review .stars{color:var(--brass);letter-spacing:.18em;font-size:1.05rem;line-height:1}
.review blockquote{
  font-style:italic;color:var(--ink);font-size:1.08rem;line-height:1.55;
  max-width:none;quotes:"\201C" "\201D";
}
.review blockquote::before{content:open-quote;color:var(--brass);font-family:var(--disp);font-size:1.3em;line-height:0;margin-right:.06em}
.review blockquote::after{content:close-quote;color:var(--brass);font-family:var(--disp)}
.review .rv-by{
  font-family:var(--mono);font-size:.66rem;letter-spacing:.13em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:700;margin-top:.2rem;
}
.review .rv-by b{color:var(--walnut)}

/* ═══════════════════════════════════════════════════════
   ARTICLE (blog post)
   ═══════════════════════════════════════════════════════ */
.post-layout{
  max-width:var(--wrap);margin:0 auto;padding:clamp(1.5rem,4vw,2.5rem) var(--gutter) clamp(2.5rem,5vw,4rem);
  display:grid;grid-template-columns:1.65fr 1px 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:start;
}
@media(max-width:900px){.post-layout{grid-template-columns:1fr}.post-col-rule{display:none}}
.post-col-rule{background:var(--walnut);width:1px}
.post-kicker{font-family:var(--mono);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass);font-weight:700}
.post-title{font-family:var(--disp);font-weight:800;font-size:clamp(2.1rem,4.6vw,3.3rem);color:var(--walnut);margin:.4rem 0 .5rem;line-height:1.05}
.post-byline{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:1.2rem}
.post-img{width:100%;aspect-ratio:3/2;object-fit:cover;background:var(--green);border:1px solid var(--rule);margin-bottom:1.6rem}
.post-body p{margin-bottom:1.3rem;max-width:none}
.post-body p:first-of-type::first-letter{
  float:left;font-family:var(--disp);font-weight:700;
  font-size:4.4rem;line-height:.72;margin:.08em .12em 0 0;color:var(--green);
}
.post-body h2{font-family:var(--disp);font-weight:700;font-size:clamp(1.4rem,2.6vw,1.9rem);color:var(--walnut);margin:2rem 0 .9rem;padding-top:.9rem;border-top:1px solid var(--ledger)}
.post-sidebar .post-sb-head{
  font-family:var(--disp);font-weight:700;font-size:1.1rem;color:var(--walnut);
  border-bottom:2px solid var(--walnut);padding-bottom:.4rem;margin-bottom:.3rem;
  font-variant:small-caps;letter-spacing:.06em;
}

/* ═══════════════════════════════════════════════════════
   CART (ledger)
   ═══════════════════════════════════════════════════════ */
.cart-grid{display:grid;grid-template-columns:1.4fr .6fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}
@media(max-width:820px){.cart-grid{grid-template-columns:1fr}}
.cart-line{
  display:grid;grid-template-columns:1fr auto;gap:1rem;
  padding:1rem 0;border-top:1px solid var(--ledger);
  font-family:var(--body);align-items:baseline;
}
.cart-line .ci-name{font-family:var(--disp);font-weight:700;font-size:1.15rem;color:var(--walnut)}
.cart-line .ci-meta{font-family:var(--mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.cart-line .ci-price{font-family:var(--mono);font-weight:700;color:var(--brass)}
.cart-total{
  display:grid;grid-template-columns:1fr auto;gap:1rem;
  padding:1.1rem 0;border-top:3px double var(--walnut);margin-top:.4rem;
  font-family:var(--mono);font-weight:700;font-size:1.25rem;color:var(--walnut);
}
.cart-total .val{color:var(--brass)}
.checkout-box{background:var(--green);color:var(--paper);border:1px solid var(--brass);padding:clamp(1.5rem,3vw,2.2rem)}
.checkout-box h2{color:var(--paper);font-size:1.6rem;margin-bottom:.6rem}
.checkout-box p{color:rgba(243,234,217,.8);font-style:italic;margin-bottom:1.2rem}
.checkout-box .btn{width:100%;justify-content:center}
.checkout-box .btn+.btn{margin-top:.7rem}

/* ═══════════════════════════════════════════════════════
   FORMS (contact)
   ═══════════════════════════════════════════════════════ */
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.1rem}
.field label{font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}
.field input,.field textarea{
  font-family:var(--body);font-size:1.05rem;padding:.8rem 1rem;
  background:var(--paper-2);border:1px solid var(--ledger);border-radius:1px;color:var(--ink);
}
.field input:focus,.field textarea:focus{outline:2px solid var(--brass);outline-offset:1px;border-color:var(--brass)}

/* ═══════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════ */
.site-footer{background:var(--walnut);color:var(--paper);margin-top:clamp(3rem,6vw,5rem);border-top:2px solid var(--brass)}
.footer-inner{
  max-width:var(--wrap);margin-inline:auto;padding:clamp(2.5rem,5vw,4rem) var(--gutter) 2rem;
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:clamp(1.4rem,3.4vw,2.6rem);
}
@media(max-width:820px){.footer-inner{grid-template-columns:1fr 1fr 1fr}}
@media(max-width:640px){.footer-inner{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-inner{grid-template-columns:1fr}}
.f-brand-name{font-family:var(--disp);font-weight:800;font-size:1.8rem;color:var(--paper)}
.f-brand-name em{font-style:italic;font-weight:400;color:var(--brass-hi)}
.f-brand-sub{font-family:var(--mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-hi);margin-top:.4rem}
.f-about{font-style:italic;color:rgba(243,234,217,.72);font-size:.98rem;margin-top:.8rem;max-width:34ch}
.f-col-head{font-family:var(--disp);font-weight:700;font-size:1.05rem;color:var(--brass-hi);margin-bottom:.7rem;font-variant:small-caps;letter-spacing:.06em}
.f-col ul{list-style:none}
.f-col li{margin-bottom:.45rem}
.f-col a{font-size:.95rem;color:rgba(243,234,217,.82)}
.f-col a:hover{color:var(--brass-hi)}
.footer-bottom{
  max-width:var(--wrap);margin-inline:auto;padding:1.2rem var(--gutter) 2.5rem;
  border-top:1px solid rgba(200,185,154,.24);
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(243,234,217,.55);
}

/* ═══════════════════════════════════════════════════════
   EBOOK PDP — portrait cover plate & chapter ledger
   ═══════════════════════════════════════════════════════ */
.pdp-cover{overflow:hidden;background:var(--green);border:1px solid var(--rule);padding:clamp(1.2rem,3vw,2.2rem);display:flex;justify-content:center}
.pdp-cover img{width:100%;max-width:340px;aspect-ratio:3/4;object-fit:contain;box-shadow:0 12px 30px rgba(42,31,22,.34)}
.chapter-ledger{list-style:none;margin:0;padding:0}
.chapter-ledger li{display:flex;gap:.8rem;align-items:baseline;border-top:1px solid var(--ledger);padding:.72rem 0;font-family:var(--body)}
.chapter-ledger li:last-child{border-bottom:1px solid var(--ledger)}
.chapter-ledger .ch-no{font-family:var(--mono);font-size:.72rem;font-weight:700;letter-spacing:.12em;color:var(--brass);white-space:nowrap}
.chapter-ledger .ch-t{color:var(--ink)}

/* ═══════════════════════════════════════════════════════
   PDP COMMERCE — working gallery, compare price, variants,
   frequently-bought, FAQ (CSS-only, no script)
   ═══════════════════════════════════════════════════════ */

/* — working gallery: radio + label, nth-of-type drives nth slide — */
.gallery{position:relative}
.gallery .gal-radio{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  border:0;clip:rect(0 0 0 0);overflow:hidden;white-space:nowrap;
}
.gal-stage{position:relative}
.gal-stage .gal-slide{display:none}
.gallery .gal-radio:nth-of-type(1):checked ~ .gal-stage .gal-slide:nth-child(1),
.gallery .gal-radio:nth-of-type(2):checked ~ .gal-stage .gal-slide:nth-child(2),
.gallery .gal-radio:nth-of-type(3):checked ~ .gal-stage .gal-slide:nth-child(3){display:block}

.gal-thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem;margin-top:.1rem}
.gal-thumb{
  display:block;cursor:pointer;position:relative;
  border:1px solid var(--rule);background:var(--green);
}
.gal-thumb img{aspect-ratio:1/1;object-fit:cover;width:100%;opacity:.8;transition:opacity .15s ease}
.gal-thumb:hover img{opacity:1}
.gal-thumb::after{content:"";position:absolute;inset:0;pointer-events:none;border:2px solid transparent}
.gallery .gal-radio:nth-of-type(1):checked ~ .gal-thumbs .gal-thumb:nth-child(1)::after,
.gallery .gal-radio:nth-of-type(2):checked ~ .gal-thumbs .gal-thumb:nth-child(2)::after,
.gallery .gal-radio:nth-of-type(3):checked ~ .gal-thumbs .gal-thumb:nth-child(3)::after{border-color:var(--brass)}
.gallery .gal-radio:nth-of-type(1):checked ~ .gal-thumbs .gal-thumb:nth-child(1) img,
.gallery .gal-radio:nth-of-type(2):checked ~ .gal-thumbs .gal-thumb:nth-child(2) img,
.gallery .gal-radio:nth-of-type(3):checked ~ .gal-thumbs .gal-thumb:nth-child(3) img{opacity:1}
.gallery .gal-radio:nth-of-type(1):focus-visible ~ .gal-thumbs .gal-thumb:nth-child(1),
.gallery .gal-radio:nth-of-type(2):focus-visible ~ .gal-thumbs .gal-thumb:nth-child(2),
.gallery .gal-radio:nth-of-type(3):focus-visible ~ .gal-thumbs .gal-thumb:nth-child(3){outline:2px solid var(--brass);outline-offset:3px}

/* — compare-at price + stock badge — */
.pdp-priceline{display:flex;align-items:baseline;gap:.7rem;flex-wrap:wrap;margin-bottom:.45rem}
.pdp-priceline .pdp-price{margin-bottom:0}
.price-was{font-family:var(--mono);font-size:1.02rem;color:var(--ink-soft);text-decoration:line-through;text-decoration-color:var(--brass)}
.price-save{
  font-family:var(--mono);font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--walnut-2);background:var(--brass);padding:.3rem .55rem;border-radius:1px;
}
.stock-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--mono);font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--green);margin-bottom:1.1rem;
}
.stock-badge .stock-dot{width:.55rem;height:.55rem;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px rgba(31,61,47,.16)}
.stock-badge.low{color:var(--brass)}
.stock-badge.low .stock-dot{background:var(--brass);box-shadow:0 0 0 3px rgba(176,137,78,.2)}

/* — variant swatches: radio + adjacent label — */
.variant-group{border:0;padding:0;margin:0 0 1.2rem;min-width:0}
.variant-legend{
  font-family:var(--mono);font-size:.66rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-soft);padding:0;margin-bottom:.5rem;
}
.variant-legend b{color:var(--walnut);font-weight:700}
.variant-swatches{display:flex;gap:.5rem;flex-wrap:wrap;position:relative}
.variant-radio{position:absolute;width:1px;height:1px;padding:0;margin:-1px;border:0;clip:rect(0 0 0 0);overflow:hidden}
.variant-swatch{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:.72rem;font-weight:700;letter-spacing:.07em;
  color:var(--walnut);background:var(--paper-2);
  border:1.5px solid var(--ledger);border-radius:1px;
  padding:.5rem .85rem;cursor:pointer;
  transition:border-color .15s ease,background .15s ease,color .15s ease;
}
.variant-swatch:hover{border-color:var(--brass)}
.variant-radio:checked + .variant-swatch{border-color:var(--brass);background:var(--brass);color:var(--walnut-2)}
.variant-radio:focus-visible + .variant-swatch{outline:2px solid var(--brass);outline-offset:2px}

/* — frequently bought together ("Completes the Kit") — */
.fbt-rack{display:flex;align-items:stretch;gap:clamp(.5rem,1.6vw,1rem);flex-wrap:nowrap}
.fbt-item{
  flex:1 1 0;min-width:0;
  display:flex;flex-direction:column;gap:.35rem;
  border:1px solid var(--ledger);background:var(--paper);padding:.9rem;
}
.fbt-fig{overflow:hidden;background:var(--green);border:1px solid var(--rule)}
.fbt-fig img{aspect-ratio:4/3;object-fit:cover;width:100%}
.fbt-this{font-family:var(--mono);font-size:.56rem;letter-spacing:.12em;text-transform:uppercase;color:var(--walnut-2);background:var(--brass-hi);align-self:flex-start;padding:.16rem .4rem;font-weight:700;border-radius:1px}
.fbt-cat{font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brass);font-weight:700}
.fbt-name{font-family:var(--disp);font-weight:700;font-size:1.02rem;color:var(--walnut);line-height:1.14}
a.fbt-name:hover{color:var(--green)}
.fbt-price{font-family:var(--mono);font-weight:700;color:var(--brass);font-size:.95rem;margin-top:auto}
.fbt-plus{align-self:center;font-family:var(--disp);font-weight:700;font-size:1.6rem;color:var(--brass);line-height:1;flex:0 0 auto}
.fbt-sum{
  margin-top:1.4rem;border:1px solid var(--brass);background:var(--paper-2);
  padding:1.05rem 1.3rem;display:flex;align-items:center;justify-content:space-between;
  gap:1rem;flex-wrap:wrap;
}
.fbt-sub-label{font-family:var(--mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;display:block}
.fbt-sub{font-family:var(--mono);font-weight:700;font-size:1.5rem;color:var(--brass)}
.fbt-sub s{color:var(--ink-soft);font-size:.9rem;font-weight:400;margin-left:.5rem}
.fbt-sum .btn{margin:0}
@media(max-width:680px){
  .fbt-rack{flex-direction:column}
  .fbt-item{flex-direction:row;align-items:center;gap:.9rem}
  .fbt-fig{width:88px;flex:0 0 88px}
  .fbt-price{margin-top:0}
  .fbt-plus{transform:rotate(90deg)}
}

/* — FAQ accordion (native <details>) — */
.faq{max-width:840px}
.faq-item{border-top:1px solid var(--ledger)}
.faq-item:last-child{border-bottom:1px solid var(--ledger)}
.faq-item summary{
  list-style:none;cursor:pointer;
  display:flex;align-items:baseline;justify-content:space-between;gap:1rem;
  padding:1.05rem .2rem;
  font-family:var(--disp);font-weight:700;font-size:1.12rem;color:var(--walnut);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"\002B";font-family:var(--mono);font-weight:700;color:var(--brass);font-size:1.2rem;line-height:1;flex:0 0 auto}
.faq-item[open] summary::after{content:"\2212"}
.faq-item summary:hover{color:var(--green)}
.faq-item summary:focus-visible{outline:2px solid var(--brass);outline-offset:2px;border-radius:1px}
.faq-a{padding:0 .2rem 1.15rem;color:var(--ink-soft);font-style:italic;max-width:72ch}

/* — cart steppers, promo, summary, upsell (ledger) — */
.cart-thumb{overflow:hidden;background:var(--green);border:1px solid var(--rule);width:76px;flex:0 0 76px}
.cart-thumb img{aspect-ratio:1/1;object-fit:cover;width:100%}
.cart-line-full{
  display:grid;grid-template-columns:76px 1fr auto;gap:1rem;align-items:center;
  padding:1.1rem 0;border-top:1px solid var(--ledger);font-family:var(--body);
}
.cart-line-full:first-of-type{border-top:2px solid var(--walnut)}
.ci-body{min-width:0}
.qty-step{display:inline-flex;align-items:center;border:1px solid var(--ledger);border-radius:1px;margin-top:.55rem;background:var(--paper-2)}
.qty-step .qbtn{
  display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;
  font-family:var(--mono);font-weight:700;font-size:1rem;color:var(--walnut);
  border:0;background:transparent;cursor:pointer;text-decoration:none;
}
.qty-step .qbtn:hover{background:var(--brass);color:var(--walnut-2)}
.qty-step .qnum{font-family:var(--mono);font-weight:700;font-size:.9rem;color:var(--walnut);min-width:2rem;text-align:center;border-inline:1px solid var(--ledger);line-height:2rem}
.ci-remove{font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);border-bottom:1px solid var(--ledger);margin-left:.9rem}
.ci-remove:hover{color:var(--brass);border-color:var(--brass)}
.promo-row{display:flex;gap:.6rem;margin:1.4rem 0 0;flex-wrap:wrap}
.promo-row input{
  flex:1 1 12rem;font-family:var(--mono);font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;
  padding:.7rem .9rem;background:var(--paper-2);border:1px solid var(--ledger);border-radius:1px;color:var(--ink);
}
.promo-row input:focus{outline:2px solid var(--brass);outline-offset:1px;border-color:var(--brass)}
.promo-note{font-family:var(--mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--green);font-weight:700;margin-top:.5rem}
.summary-line{display:flex;justify-content:space-between;gap:1rem;padding:.62rem 0;border-top:1px solid rgba(200,185,154,.28);font-family:var(--mono);font-size:.82rem;letter-spacing:.06em;color:rgba(243,234,217,.86)}
.summary-line:first-of-type{border-top:0}
.summary-line .s-val{font-weight:700;color:var(--paper)}
.summary-line.discount .s-val{color:var(--brass-hi)}
.summary-total{display:flex;justify-content:space-between;gap:1rem;padding:.9rem 0 0;margin-top:.4rem;border-top:1px solid var(--brass);font-family:var(--mono);font-weight:700;font-size:1.3rem;color:var(--paper)}
.summary-total .s-val{color:var(--brass-hi)}
.upsell{display:flex;align-items:center;gap:1rem;border:1px solid var(--ledger);border-left:4px solid var(--brass);background:var(--paper-2);padding:.9rem 1.1rem;margin-top:.4rem}
.upsell .up-fig{overflow:hidden;background:var(--green);border:1px solid var(--rule);width:64px;flex:0 0 64px}
.upsell .up-fig img{aspect-ratio:1/1;object-fit:cover;width:100%}
.upsell .up-body{flex:1 1 auto;min-width:0}
.up-cat{font-family:var(--mono);font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brass);font-weight:700}
.up-name{font-family:var(--disp);font-weight:700;font-size:1.04rem;color:var(--walnut);line-height:1.12}
.up-desc{font-style:italic;color:var(--ink-soft);font-size:.9rem}
.up-add{font-family:var(--mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--green);font-weight:700;border:1px solid var(--brass);padding:.5rem .7rem;border-radius:1px;white-space:nowrap;flex:0 0 auto}
.up-add:hover{background:var(--brass);color:var(--walnut-2)}
.cart-trust{display:flex;gap:1.4rem;flex-wrap:wrap;margin-top:1.6rem;padding-top:1.2rem;border-top:1px solid var(--ledger)}
.cart-trust .ct-item{display:flex;align-items:center;gap:.5rem;font-family:var(--mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}
.cart-trust .ct-mark{color:var(--brass);font-size:1.05rem;line-height:1}

/* ═══════════════════════════════════════════════════════
   ACCESSIBILITY / MOTION
   ═══════════════════════════════════════════════════════ */
a:focus-visible,.btn:focus-visible,.site-nav a:focus-visible,.pm-nav a:focus-visible,input:focus-visible,textarea:focus-visible{
  outline:2px solid var(--brass);outline-offset:3px;border-radius:1px;
}
@keyframes riseIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.rise{animation:riseIn .8s cubic-bezier(.2,.7,.2,1) both}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}

/* ═══════════════════════════════════════════════════════
   TRUST LAYER (v11) — rating summary · verified reviews ·
   hallmark seals · press strip · payment marks · fit chart
   ═══════════════════════════════════════════════════════ */

/* — aggregate rating summary — */
.rating-summary{
  display:grid;grid-template-columns:auto 1px 1fr;gap:clamp(1.2rem,3.4vw,2.6rem);
  align-items:center;
  border:1px solid var(--ledger);border-left:4px solid var(--brass);
  background:var(--paper-2);padding:clamp(1.2rem,3vw,1.9rem);
  margin-bottom:clamp(1.6rem,3.5vw,2.4rem);
}
@media(max-width:620px){.rating-summary{grid-template-columns:1fr}.rs-div{display:none}}
.rs-div{background:var(--ledger);width:1px;align-self:stretch}
.rs-head{display:flex;flex-direction:column;gap:.4rem;align-items:center;text-align:center;min-width:8.4rem}
.rs-avg{font-family:var(--disp);font-weight:800;font-size:clamp(2.7rem,6.5vw,3.5rem);color:var(--walnut);line-height:.86}
.rs-avg small{font-family:var(--mono);font-size:.9rem;font-weight:700;color:var(--ink-soft)}
.rs-stars{position:relative;display:inline-block;font-size:1.12rem;letter-spacing:.14em;line-height:1;white-space:nowrap}
.rs-stars .rs-empty{color:var(--ledger)}
.rs-stars .rs-fill{position:absolute;top:0;left:0;overflow:hidden;white-space:nowrap;color:var(--brass)}
.rs-count{font-family:var(--mono);font-size:.64rem;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}
.rs-count b{color:var(--walnut)}
.rs-bars{display:flex;flex-direction:column;gap:.42rem}
.rs-bar{display:grid;grid-template-columns:2.6rem 1fr 2.4rem;gap:.6rem;align-items:center}
.rs-bar-label{font-family:var(--mono);font-size:.66rem;font-weight:700;color:var(--brass);letter-spacing:.04em;white-space:nowrap}
.rs-bar-track{height:.5rem;background:var(--paper);border:1px solid var(--ledger);border-radius:1px;overflow:hidden}
.rs-bar-fill{display:block;height:100%;background-image:linear-gradient(90deg,var(--brass),var(--brass-hi))}
.rs-bar-n{font-family:var(--mono);font-size:.64rem;color:var(--ink-soft);text-align:right}

/* — verified-buyer badge on reviews — */
.review .rv-top{display:flex;align-items:center;justify-content:space-between;gap:.6rem;flex-wrap:wrap;margin-bottom:.1rem}
.rv-verified{
  display:inline-flex;align-items:center;gap:.34rem;
  font-family:var(--mono);font-size:.57rem;font-weight:700;letter-spacing:.11em;text-transform:uppercase;
  color:var(--green);border:1px solid var(--brass);background:var(--paper);
  padding:.24rem .5rem;border-radius:1px;
}
.rv-verified svg{width:.74rem;height:.74rem;display:block;flex:0 0 auto}
.review .rv-note{font-family:var(--body);font-style:italic;color:var(--ink-soft);font-size:.86rem;margin-top:-.1rem}

/* — hallmark seals — */
.seal-row{display:flex;flex-wrap:wrap;gap:clamp(1.1rem,3.4vw,2.4rem);justify-content:center;align-items:flex-start}
.seal{display:flex;flex-direction:column;align-items:center;gap:.5rem;width:9.6rem;text-align:center}
.seal-disc{width:74px;height:74px;flex:0 0 74px;display:block}
.seal-cap{font-family:var(--mono);font-size:.62rem;font-weight:700;letter-spacing:.11em;text-transform:uppercase;color:var(--walnut);line-height:1.3}
.seal-sub{font-family:var(--body);font-style:italic;font-size:.82rem;color:var(--ink-soft);line-height:1.32}
.band-green .seal-cap{color:var(--paper)}
.band-green .seal-sub{color:rgba(243,234,217,.75)}
.seal-band{border-top:1px solid var(--ledger);margin-top:1.5rem;padding-top:1.4rem}

/* signature interaction — engraved guilloché seal on a slow lathe turn */
.seal--sig .seal-ring{transform-box:fill-box;transform-origin:center;animation:lathe 64s linear infinite}
.seal--sig .seal-disc{transition:transform .5s cubic-bezier(.2,.7,.2,1)}
.seal--sig:hover .seal-ring{animation-duration:11s}
.seal--sig:hover .seal-disc{transform:translateY(-3px) scale(1.05)}
.seal--sig:focus-within .seal-disc{transform:translateY(-3px) scale(1.05)}
@keyframes lathe{to{transform:rotate(360deg)}}

/* — press "as seen in" strip — */
.press-strip{border-top:2px solid var(--walnut);border-bottom:1px solid var(--brass);padding:clamp(1.2rem,3vw,1.8rem) 0}
.press-lede{font-family:var(--mono);font-size:.64rem;letter-spacing:.24em;text-transform:uppercase;color:var(--brass);text-align:center;margin-bottom:1rem;font-weight:700}
.press-marks{display:flex;flex-wrap:wrap;justify-content:center;align-items:baseline;gap:clamp(1.3rem,5vw,3.6rem)}
.press-mark{display:flex;flex-direction:column;align-items:center;line-height:1}
.press-mark .pm-name{font-family:var(--disp);font-weight:700;font-size:clamp(1.05rem,2.4vw,1.45rem);color:var(--walnut);letter-spacing:.01em;white-space:nowrap}
.press-mark .pm-name em{font-style:italic;font-weight:400;color:var(--ink-soft)}
.press-mark .pm-kick{font-family:var(--mono);font-size:.52rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);margin-top:.3rem}
.press-mark.sc .pm-name{font-variant:small-caps;letter-spacing:.06em}

/* — payment marks — */
.footer-pay{
  max-width:var(--wrap);margin-inline:auto;padding:.2rem var(--gutter) .2rem;
  display:flex;align-items:center;gap:1rem;flex-wrap:wrap;justify-content:center;
}
.footer-pay .fp-label{font-family:var(--mono);font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(243,234,217,.55);font-weight:700}
.pay-row{display:inline-flex;gap:.5rem;flex-wrap:wrap;align-items:center}
.pay-mark{width:38px;height:24px;display:block;border-radius:2px;box-shadow:0 1px 2px rgba(0,0,0,.25)}
.cart-pay{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;margin-top:1.2rem;padding-top:1.2rem;border-top:1px solid var(--ledger)}
.cart-pay .cp-label{font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}

/* — fit chart (size guide) — */
.fit-wrap{overflow-x:auto;margin:.4rem 0 1.2rem}
.fit-table{width:100%;border-collapse:collapse;font-family:var(--body);min-width:34rem}
.fit-table caption{font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);text-align:left;padding-bottom:.7rem;font-weight:700}
.fit-table th,.fit-table td{text-align:left;padding:.7rem .7rem;border-top:1px solid var(--ledger);font-size:.95rem;vertical-align:top}
.fit-table thead th{font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--brass);border-top:2px solid var(--walnut);border-bottom:1px solid var(--brass);font-weight:700}
.fit-table tbody th{font-family:var(--disp);font-weight:700;color:var(--walnut);font-size:1.02rem;white-space:nowrap}
.fit-table tbody td{color:var(--ink)}
.fit-table tbody tr:last-child th,.fit-table tbody tr:last-child td{border-bottom:1px solid var(--ledger)}
@media(max-width:640px){.fit-table th,.fit-table td{padding:.55rem .5rem;font-size:.88rem}}
