/* ============================================================
   FIELDCRAFT-SEALED.CSS — The Shop Sealed (the-shop-sealed-v1)
   Enqueued by functions.php (handle: tss-sealed). ALL site CSS
   lives here; Divi Code modules carry markup + JS only.
   Palette LOCKED: oxblood #8f2418 · ink #1c1a17 · paper #faf6ed ·
   bone #f4ede0 · gold #c9a159.
   §00 fonts · §01–§13 editorial system (from site.css) ·
   §14 global header · §15 Divi resets · §16 storefront app ·
   §17 fishing-gear lander · §18 about · §19 contact · §20 legal ·
   §21 palette & type locks vs Divi globals
   ============================================================ */

/* The Sporting Shop — clean apparel & outdoor-goods landing site.
   Editorial system shared across home + category pages.
   Palette LOCKED: oxblood #8f2418 · ink #1c1a17 · paper #faf6ed · bone #f4ede0 · gold #c9a159 */

/* ---- self-hosted fonts (no external font CDN) ---- */
@font-face{ font-family:"Playfair Display"; src:url("assets/fonts/playfair-display-var-latin.woff2") format("woff2"); font-weight:400 900; font-style:normal; font-display:swap; }
@font-face{ font-family:"Playfair Display"; src:url("assets/fonts/playfair-display-italic-var-latin.woff2") format("woff2"); font-weight:400 900; font-style:italic; font-display:swap; }
@font-face{ font-family:"Cormorant Garamond"; src:url("assets/fonts/cormorant-garamond-var-latin.woff2") format("woff2"); font-weight:300 700; font-style:normal; font-display:swap; }
@font-face{ font-family:"Cormorant Garamond"; src:url("assets/fonts/cormorant-garamond-italic-var-latin.woff2") format("woff2"); font-weight:300 700; font-style:italic; font-display:swap; }
@font-face{ font-family:"Montserrat"; src:url("assets/fonts/montserrat-var-latin.woff2") format("woff2"); font-weight:300 800; font-style:normal; font-display:swap; }
@font-face{ font-family:"JetBrains Mono"; src:url("assets/fonts/jetbrains-mono-var-latin.woff2") format("woff2"); font-weight:400 700; font-style:normal; font-display:swap; }

:root{
  --ox:#8f2418; --ink:#1c1a17; --paper:#faf6ed; --bone:#f4ede0; --gold:#c9a159;
  --quiet:#6b6357; --line:#e3d8c2;
  --display:"Playfair Display",Georgia,serif;
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Montserrat",-apple-system,system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
  --wrap:1200px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--sans); font-size:16px; line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; }
a{ color:var(--ox); text-decoration:none; }
a:hover,a:focus{ color:var(--ink); }
.wrap{ max-width:var(--wrap); margin:0 auto; padding:0 28px; }

/* ---- shared eyebrow / headings ---- */
.eyebrow{ font:600 11px/1 var(--mono); letter-spacing:.22em; text-transform:uppercase; color:var(--ox); margin:0 0 14px; }
.eyebrow.on-dark{ color:var(--gold); }
h1,h2,h3{ font-family:var(--display); font-weight:600; line-height:1.05; margin:0; }

/* ---- top bar ---- */
.topbar{ background:var(--ink); color:var(--paper); font:600 10.5px/1 var(--mono); letter-spacing:.14em; text-transform:uppercase; }
.topbar .wrap{ display:flex; justify-content:center; gap:26px; padding:9px 28px; flex-wrap:wrap; }
.topbar span{ opacity:.82; }
.topbar .sep{ color:var(--gold); opacity:1; }

/* ---- header / nav ---- */
.site-head{ position:sticky; top:0; z-index:30; background:var(--paper); border-bottom:1px solid var(--line); }
.site-head .wrap{ display:flex; align-items:center; gap:30px; padding:18px 28px; }
.brand{ display:flex; align-items:center; gap:13px; }
.brand img{ width:42px; height:42px; }
.brand b{ font-family:var(--display); font-size:21px; font-weight:600; letter-spacing:.01em; color:var(--ink); display:block; line-height:1; }
.brand small{ font:600 8.5px/1 var(--mono); letter-spacing:.2em; text-transform:uppercase; color:var(--quiet); display:block; margin-top:5px; }
.nav{ display:flex; gap:26px; margin-left:auto; align-items:center; }
.nav a{ font:600 12px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase; color:var(--ink); padding:6px 0; border-bottom:2px solid transparent; }
.nav a:hover,.nav a:focus,.nav a.is-active{ color:var(--ox); border-bottom-color:var(--gold); }
.nav .cta{ background:var(--ox); color:var(--paper); border:0; padding:11px 18px; border-radius:2px; letter-spacing:.08em; }
.nav .cta:hover,.nav .cta:focus{ background:var(--ink); color:var(--paper); border-bottom-color:transparent; }

/* ---- hero ---- */
.hero{ position:relative; background:var(--ink); color:var(--paper); overflow:hidden; }
.hero .wrap{ position:relative; z-index:2; padding:96px 28px 104px; max-width:var(--wrap); }
.hero__art{ position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(120% 90% at 78% 30%, rgba(143,36,24,.34), transparent 60%),
    linear-gradient(120deg,#1c1a17 0%, #241f1a 55%, #2f2820 100%);
}
.hero__ram{ position:absolute; right:-60px; bottom:-70px; width:440px; opacity:.12; z-index:1; pointer-events:none; }
.hero h1{ font-size:clamp(40px,6.4vw,78px); max-width:14ch; }
.hero h1 em{ font-style:italic; color:var(--gold); }
.hero p{ font-family:var(--serif); font-size:clamp(19px,2.3vw,25px); line-height:1.45; max-width:46ch; margin:22px 0 32px; color:rgba(250,246,237,.9); }
.hero__btns{ display:flex; gap:14px; flex-wrap:wrap; }
.btn{ display:inline-flex; align-items:center; gap:9px; font:600 12px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase; padding:15px 24px; border-radius:2px; border:1px solid transparent; transition:.15s; }
.btn--gold{ background:var(--gold); color:var(--ink); }
.btn--gold:hover,.btn--gold:focus{ background:#bb9043; color:var(--ink); }
.btn--ghost{ background:transparent; color:var(--paper); border-color:rgba(250,246,237,.4); }
.btn--ghost:hover,.btn--ghost:focus{ border-color:var(--gold); color:var(--gold); }
.btn--ox{ background:var(--ox); color:var(--paper); }
.btn--ox:hover,.btn--ox:focus{ background:var(--ink); color:var(--paper); }

/* ---- section frame ---- */
.section{ padding:78px 0; }
.section--bone{ background:var(--bone); }
.section__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:38px; flex-wrap:wrap; }
.section__head h2{ font-size:clamp(28px,3.6vw,42px); }
.section__head p{ margin:8px 0 0; color:var(--quiet); font-family:var(--serif); font-size:19px; max-width:48ch; }
.seeall{ font:600 11px/1 var(--mono); letter-spacing:.12em; text-transform:uppercase; color:var(--ox); white-space:nowrap; border-bottom:2px solid var(--gold); padding-bottom:6px; }
.seeall:hover,.seeall:focus{ color:var(--ink); }

/* ---- category grid ---- */
.cat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.cat-grid--2{ grid-template-columns:repeat(2,1fr); }
.cat-grid--3{ grid-template-columns:repeat(3,1fr); }
.cat-card{ position:relative; display:block; border:1px solid var(--line); border-radius:3px; overflow:hidden; background:#fff; transition:.18s; }
.cat-card:hover{ transform:translateY(-3px); box-shadow:0 14px 30px -18px rgba(28,26,23,.55); border-color:var(--gold); }
.cat-card__ph{ aspect-ratio:4/5; background:var(--bone); position:relative; overflow:hidden; }
.cat-card__ph::after{ content:attr(data-ph); position:absolute; inset:0; display:flex; align-items:center; justify-content:center; text-align:center; padding:20px; font:600 9.5px/1.5 var(--mono); letter-spacing:.12em; text-transform:uppercase; color:#b3a994; }
.cat-card__body{ padding:18px 18px 20px; display:flex; align-items:center; justify-content:space-between; gap:10px; }
.cat-card__body b{ font-family:var(--display); font-size:19px; font-weight:600; color:var(--ink); }
.cat-card__body .arr{ color:var(--ox); font-size:18px; transition:.18s; }
.cat-card:hover .arr{ transform:translateX(4px); }

/* product card */
.prod-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.prod{ background:#fff; border:1px solid var(--line); border-radius:3px; overflow:hidden; display:flex; flex-direction:column; transition:.18s; }
.prod:hover{ transform:translateY(-3px); box-shadow:0 14px 30px -18px rgba(28,26,23,.5); border-color:var(--gold); }
.prod__ph{ aspect-ratio:1/1; background:var(--bone); position:relative; }
.prod__ph::after{ content:attr(data-ph); position:absolute; inset:0; display:flex; align-items:center; justify-content:center; text-align:center; padding:16px; font:600 9px/1.5 var(--mono); letter-spacing:.1em; text-transform:uppercase; color:#b3a994; }
.prod__tag{ position:absolute; top:10px; left:10px; background:var(--ox); color:var(--paper); font:600 8.5px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase; padding:5px 8px; border-radius:2px; }
.prod__body{ padding:15px 16px 18px; display:flex; flex-direction:column; gap:5px; flex:1; }
.prod__brand{ font:600 8.5px/1 var(--mono); letter-spacing:.14em; text-transform:uppercase; color:var(--quiet); }
.prod__name{ font-family:var(--display); font-size:16px; font-weight:600; color:var(--ink); line-height:1.2; }
.prod__price{ font-family:var(--serif); font-size:19px; color:var(--ox); margin-top:auto; padding-top:8px; }

/* ---- real-photo fill: drop on any .*__ph / .band__art to replace the striped placeholder ---- */
.has-img{ background-size:cover; background-position:center; }
.cat-card__ph.has-img::after, .prod__ph.has-img::after, .band__art.has-img::after{ display:none !important; } /* hide data-ph placeholders only — hero scrims are ::after too (1.3.9 fix) */
.cat-card__ph.has-img::before, .band__art.has-img::before{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 40%,rgba(28,26,23,.34)); }

/* ---- split / editorial band ---- */
.band{ display:grid; grid-template-columns:1.1fr 1fr; align-items:stretch; }
.band__art{ background-color:var(--bone); position:relative; min-height:380px; overflow:hidden; }
.band__art::after{ content:attr(data-ph); position:absolute; inset:0; display:flex; align-items:center; justify-content:center; text-align:center; padding:30px; font:600 10px/1.6 var(--mono); letter-spacing:.12em; text-transform:uppercase; color:#b3a994; }
.band__body{ padding:64px 56px; display:flex; flex-direction:column; justify-content:center; }
.band--ink{ background:var(--ink); color:var(--paper); }
.band--ink .band__body h2{ color:var(--paper); }
.band--ink .band__body p{ color:rgba(250,246,237,.85); }
.band__body h2{ font-size:clamp(28px,3.4vw,40px); max-width:16ch; }
.band__body p{ font-family:var(--serif); font-size:20px; line-height:1.5; color:var(--quiet); margin:18px 0 26px; max-width:42ch; }

/* ---- preserve cross-promo strip ---- */
.preserve{ background:linear-gradient(120deg,#1c1a17,#2a241d); color:var(--paper); }
.preserve .wrap{ padding:54px 28px; display:flex; align-items:center; gap:40px; flex-wrap:wrap; }
.preserve__txt{ flex:1 1 360px; }
.preserve__txt h3{ font-size:clamp(24px,3vw,34px); color:var(--paper); }
.preserve__txt p{ font-family:var(--serif); font-size:19px; color:rgba(250,246,237,.82); margin:12px 0 0; max-width:52ch; }
.preserve__links{ display:flex; gap:12px; flex-wrap:wrap; }
.preserve__links a{ font:600 11px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase; color:var(--paper); border:1px solid rgba(250,246,237,.32); padding:13px 17px; border-radius:2px; transition:.15s; }
.preserve__links a:hover,.preserve__links a:focus{ border-color:var(--gold); color:var(--gold); }

/* ---- subcategory deep-link chips (category pages) ---- */
.chips{ display:flex; flex-wrap:wrap; gap:10px; }
.chips a{ font:600 11px/1 var(--mono); letter-spacing:.08em; text-transform:uppercase; color:var(--ink); background:#fff; border:1px solid var(--line); padding:12px 16px; border-radius:2px; transition:.15s; }
.chips a:hover,.chips a:focus{ border-color:var(--gold); color:var(--ox); transform:translateY(-2px); }
.chips a .a{ color:var(--ox); margin-left:7px; }
/* shorter hero for interior pages */
.hero--sub .wrap{ padding:70px 28px 76px; }
.hero--sub h1{ font-size:clamp(34px,5vw,62px); }

/* ---- signup ---- */
.signup{ background:var(--ox); color:var(--paper); }
.signup .wrap{ padding:66px 28px; text-align:center; }
.signup h2{ font-size:clamp(28px,3.6vw,42px); color:var(--paper); max-width:18ch; margin:0 auto; }
.signup p{ font-family:var(--serif); font-size:20px; color:rgba(250,246,237,.9); margin:16px auto 28px; max-width:46ch; }
.signup form{ display:flex; gap:10px; justify-content:center; max-width:480px; margin:0 auto; flex-wrap:wrap; }
.signup input{ flex:1 1 240px; border:0; border-radius:2px; padding:15px 18px; font:15px/1 var(--sans); color:var(--ink); }
.signup button{ background:var(--gold); color:var(--ink); border:0; border-radius:2px; padding:15px 26px; font:600 12px/1 var(--mono); letter-spacing:.1em; text-transform:uppercase; cursor:pointer; }
.signup button:hover,.signup button:focus{ background:#e7c987; }

/* ---- footer ---- */
.site-foot{ background:var(--ink); color:rgba(250,246,237,.72); }
.site-foot .wrap{ padding:58px 28px 30px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:34px; }
.site-foot .brand b{ color:var(--paper); }
.site-foot .brand small{ color:rgba(250,246,237,.55); }
.site-foot p.blurb{ font-family:var(--serif); font-size:17px; line-height:1.5; margin:16px 0 0; max-width:34ch; color:rgba(250,246,237,.7); }
.foot-col h4{ font:600 10px/1 var(--mono); letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin:0 0 16px; }
.foot-col a{ display:block; color:rgba(250,246,237,.72); font-size:14px; padding:5px 0; }
.foot-col a:hover,.foot-col a:focus{ color:var(--paper); }
.foot-bottom{ border-top:1px solid rgba(250,246,237,.14); margin-top:42px; padding-top:22px; display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap; font:600 10.5px/1.5 var(--mono); letter-spacing:.06em; color:rgba(250,246,237,.5); }
.foot-bottom a{ color:rgba(250,246,237,.5); }
.foot-bottom a:hover{ color:var(--gold); }

/* ---- responsive ---- */
@media (max-width:980px){
  .cat-grid,.prod-grid{ grid-template-columns:repeat(2,1fr); }
  .band{ grid-template-columns:1fr; }
  .band__art{ min-height:260px; }
  .band__body{ padding:44px 32px; }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:28px; }
}
@media (max-width:640px){
  .hero .wrap{ padding:64px 24px 72px; }
  .cat-grid,.prod-grid{ grid-template-columns:1fr 1fr; gap:12px; }
  .section{ padding:56px 0; }
  .foot-grid{ grid-template-columns:1fr; }
}


/* =========================================================
   §14  GLOBAL HEADER ADDITIONS — cart button, burger, mobile nav
   (unified light header used site-wide, incl. /shop/)
   ========================================================= */
.site-head .head-tools{ display:flex; align-items:center; gap:10px; }
.nav{ margin-left:auto; }
.cart-btn{ display:flex; align-items:center; gap:9px; background:var(--gold); color:var(--ink); border:none; cursor:pointer; font:600 11px/1 var(--mono); letter-spacing:.12em; text-transform:uppercase; padding:13px 18px; border-radius:2px; text-decoration:none; }
.cart-btn:hover,.cart-btn:focus{ background:#bb9043; color:var(--ink); }
.cart-btn .count{ background:var(--ink); color:var(--paper); border-radius:20px; min-width:20px; height:20px; display:inline-flex; align-items:center; justify-content:center; font-size:11px; padding:0 6px; }
.ss-burger{ display:none; background:none; border:1px solid rgba(28,26,23,.35); border-radius:2px; color:var(--ink); width:42px; height:42px; cursor:pointer; font-size:18px; line-height:1; }
@media (max-width:1080px){
  .nav{ display:none; position:absolute; top:100%; left:0; right:0; background:var(--paper); border-bottom:1px solid var(--line); flex-direction:column; align-items:stretch; gap:0; padding:8px 0; z-index:40; }
  .nav.open{ display:flex; }
  .nav a{ width:auto; padding:14px 28px; border-bottom:none; }
  .nav a:hover,.nav a:focus{ background:rgba(28,26,23,.04); }
  .nav .cta{ margin:10px 28px 8px; text-align:center; }
  .ss-burger{ display:block; margin-left:auto; }
  .nav + .head-tools .ss-burger, .head-tools .ss-burger{ margin-left:0; }
  .site-head .wrap{ position:relative; }
  .site-head .head-tools{ margin-left:auto; }
}

/* =========================================================
   §15  DIVI WRAPPER RESETS — keep code-module pages full-bleed + paper
   ========================================================= */
body, #page-container{ background:var(--paper); }
#main-content .container{ width:100%; max-width:none; padding:0; }


/* =========================================================
   §16  STOREFRONT APP (/shop/) — grid, cards, drawer, modals
   ========================================================= */
/* ---- sealed storefront ---- */
  .sf-hero{ position:relative; min-height:clamp(460px,64vh,680px); display:flex; align-items:flex-end; color:#faf6ed; overflow:hidden; background:#16130f; }
  .sf-hero .wrap{ position:relative; z-index:2; padding:56px 28px 40px; }
  .sf-hero h1{ font-family:var(--display,'Playfair Display',Georgia,serif); font-weight:600; font-size:clamp(34px,5vw,62px); line-height:1.08; margin:8px 0 0; max-width:18ch; }
  .sf-hero h1 em{ font-style:italic; color:var(--gold,#c9a159); }
  .sf-hero p{ font-family:var(--serif,Georgia,serif); font-size:clamp(19px,2.3vw,25px); line-height:1.45; color:rgba(250,246,237,.9); max-width:46ch; margin:22px 0 0; }

  .sf-tabs{ display:flex; flex-wrap:wrap; gap:10px; margin:26px 0 0; }
  .sf-tabs button{ background:transparent; color:rgba(250,246,237,.75); border:1px solid rgba(250,246,237,.25); border-radius:2px; padding:10px 18px; cursor:pointer; font:600 11px/1 var(--mono,monospace); letter-spacing:.12em; text-transform:uppercase; }
  .sf-tabs button.active{ background:#faf6ed; color:#1c1a17; border-color:#faf6ed; }
  .sf-search{ margin:18px 0 0; display:flex; gap:0; max-width:440px; }
  .sf-search input{ flex:1; padding:12px 14px; border:1px solid rgba(250,246,237,.3); background:rgba(250,246,237,.06); color:#faf6ed; border-radius:2px; font-family:var(--serif,Georgia,serif); font-size:16px; }
  .sf-search input::placeholder{ color:rgba(250,246,237,.45); }
  .sf-search input:focus{ outline:none; border-color:var(--gold,#c9a159); }
  .sf-count{ font:600 10px/1 var(--mono,monospace); letter-spacing:.14em; text-transform:uppercase; color:rgba(28,26,23,.5); padding:34px 0 0; }
  .sf-controls{ display:flex; flex-wrap:wrap; gap:12px; align-items:center; justify-content:space-between; padding:26px 0 0; }
  .sf-controls .sels{ display:flex; gap:12px; flex-wrap:wrap; }
  .sf-controls select{ padding:11px 13px; border:1px solid rgba(28,26,23,.25); border-radius:2px; background:#fff; color:var(--ink,#1c1a17); font:600 11px/1 var(--mono,monospace); letter-spacing:.08em; text-transform:uppercase; cursor:pointer; }
  .sf-controls select:focus{ outline:none; border-color:var(--gold-dark,#8a6731); }
  .sf-more{ display:block; margin:10px auto 40px; background:transparent; border:1px solid rgba(28,26,23,.3); color:var(--ink,#1c1a17); padding:14px 34px; border-radius:2px; cursor:pointer; font:600 11px/1 var(--mono,monospace); letter-spacing:.12em; text-transform:uppercase; }
  .sf-more:hover{ background:var(--ink,#1c1a17); color:#faf6ed; }
  .pcard__brand{ font:600 9px/1.4 var(--mono,monospace); letter-spacing:.14em; text-transform:uppercase; color:rgba(28,26,23,.45); margin-top:3px; }

  .sf-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; padding:24px 0 20px; }
  .pcard{ display:flex; flex-direction:column; background:#fff; border:1px solid rgba(28,26,23,.1); border-radius:3px; overflow:hidden; transition:transform .22s ease, box-shadow .22s ease; }
  .pcard:hover{ transform:translateY(-3px); box-shadow:0 16px 36px rgba(28,26,23,.13); }
  .pcard__imgwrap{ overflow:hidden; background:#fff; border-bottom:1px solid rgba(28,26,23,.07); padding:18px; cursor:pointer; }
  .pcard__img{ aspect-ratio:4/3; background-color:#fff; background-size:contain; background-position:center; background-repeat:no-repeat; transition:transform .35s ease; }
  .pcard:hover .pcard__img{ transform:scale(1.05); }
  .pcard__b{ padding:16px 18px 18px; display:flex; flex-direction:column; flex:1; }
  .pcard__top{ display:flex; justify-content:space-between; align-items:baseline; gap:10px; }
  .pcard__cat{ font:600 9px/1.4 var(--mono,monospace); letter-spacing:.16em; text-transform:uppercase; color:var(--gold-dark,#8a6731); }
  .pcard__brand{ font:600 9px/1.4 var(--mono,monospace); letter-spacing:.14em; text-transform:uppercase; color:rgba(28,26,23,.45); text-align:right; }
  .pcard__n{ font-family:var(--serif,Georgia,serif); font-size:18px; color:var(--ink,#1c1a17); margin:8px 0 2px; line-height:1.3; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; min-height:2.6em; }
  .pcard__price{ font-family:var(--serif,Georgia,serif); font-size:20px; color:var(--ink,#1c1a17); margin:auto 0 14px; padding-top:10px; }
  .pcard button{ background:transparent; color:var(--ink,#1c1a17); border:1px solid rgba(28,26,23,.35); cursor:pointer; padding:12px; border-radius:2px; font:600 11px/1 var(--mono,monospace); letter-spacing:.12em; text-transform:uppercase; transition:background .18s, color .18s, border-color .18s; }
  .pcard button:hover,.pcard button:focus{ background:var(--ox,#8f2418); border-color:var(--ox,#8f2418); color:#faf6ed; }

  /* cart drawer */
  .scrim{ position:fixed; inset:0; background:rgba(15,13,10,.55); opacity:0; pointer-events:none; transition:opacity .25s; z-index:9999980; }
  .scrim.open{ opacity:1; pointer-events:auto; }
  .drawer{ position:fixed; top:0; right:0; height:100%; width:min(420px,92vw); background:var(--paper,#faf6ed); z-index:9999981; transform:translateX(100%); transition:transform .3s; display:flex; flex-direction:column; box-shadow:-12px 0 40px rgba(0,0,0,.28); }
  .drawer.open{ transform:none; }
  .drawer__hd{ display:flex; align-items:center; justify-content:space-between; padding:20px 22px; border-bottom:1px solid rgba(28,26,23,.12); }
  .drawer__hd h3{ font-family:var(--serif,Georgia,serif); font-size:22px; color:var(--ink,#1c1a17); }
  .drawer__hd button{ background:none; border:none; font-size:24px; cursor:pointer; color:var(--ink,#1c1a17); line-height:1; }
  .drawer__body{ flex:1; overflow:auto; padding:8px 22px; }
  .drawer__ft{ border-top:1px solid rgba(28,26,23,.12); padding:20px 22px; }
  .citem{ display:flex; gap:14px; padding:16px 0; border-bottom:1px solid rgba(28,26,23,.08); }
  .citem__img{ width:64px; height:64px; border-radius:2px; background-size:cover; background-position:center; flex:none; }
  .citem__n{ font-family:var(--serif,Georgia,serif); font-size:15px; color:var(--ink,#1c1a17); line-height:1.2; }
  .citem__p{ font-family:var(--serif,Georgia,serif); color:var(--ox,#8f2418); font-size:15px; }
  .qty{ display:inline-flex; align-items:center; gap:10px; margin-top:6px; }
  .qty button{ width:24px; height:24px; border:1px solid rgba(28,26,23,.3); background:#fff; cursor:pointer; border-radius:2px; font-size:14px; color:var(--ink); }
  .qty span{ font:600 13px var(--mono,monospace); }
  .clink{ background:none; border:none; color:rgba(28,26,23,.5); cursor:pointer; font:600 9px var(--mono,monospace); letter-spacing:.1em; text-transform:uppercase; margin-left:auto; align-self:flex-start; }
  .row{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:6px; }
  .row .lab{ font:600 10px var(--mono,monospace); letter-spacing:.12em; text-transform:uppercase; color:rgba(28,26,23,.6); }
  .row .tot{ font-family:var(--serif,Georgia,serif); font-size:24px; color:var(--ink,#1c1a17); }
  .btn-full{ display:block; width:100%; text-align:center; background:var(--ox,#8f2418); color:#faf6ed; border:none; cursor:pointer; padding:15px; border-radius:2px; font:600 12px/1 var(--mono,monospace); letter-spacing:.12em; text-transform:uppercase; margin-top:12px; }
  .btn-full:disabled{ opacity:.4; cursor:default; }
  .empty{ text-align:center; color:rgba(28,26,23,.5); font-family:var(--serif,Georgia,serif); font-size:17px; padding:50px 10px; }

  /* product detail modal */
  .pd{ position:fixed; inset:0; z-index:9999990; background:rgba(15,13,10,.6); display:none; align-items:flex-start; justify-content:center; overflow:auto; padding:40px 16px; }
  .pd.open{ display:flex; }
  .pd__card{ background:var(--paper,#faf6ed); border-radius:4px; width:min(880px,100%); display:grid; grid-template-columns:1fr 1fr; overflow:hidden; position:relative; }
  .pd__img{ background:#fff; padding:34px; display:flex; align-items:center; justify-content:center; min-height:380px; }
  .pd__img div{ width:100%; aspect-ratio:1/1; background-size:contain; background-position:center; background-repeat:no-repeat; }
  .pd__b{ padding:38px 36px; display:flex; flex-direction:column; }
  .pd__top{ display:flex; gap:12px; align-items:baseline; }
  .pd__b h2{ font-family:var(--serif,Georgia,serif); font-size:clamp(22px,2.6vw,30px); font-weight:600; color:var(--ink,#1c1a17); line-height:1.2; margin:10px 0 6px; }
  .pd__price{ font-family:var(--serif,Georgia,serif); font-size:26px; color:var(--ink,#1c1a17); margin:12px 0 4px; }
  .pd__stock{ font:600 10px/1 var(--mono,monospace); letter-spacing:.14em; text-transform:uppercase; color:#1f8a5b; margin:0 0 22px; }
  .pd__note{ font-family:var(--serif,Georgia,serif); font-size:14px; color:rgba(28,26,23,.55); margin-top:auto; padding-top:18px; }
  .pd__x{ position:absolute; top:12px; right:14px; background:none; border:none; font-size:26px; cursor:pointer; color:var(--ink,#1c1a17); line-height:1; }
  @media (max-width:700px){ .pd__card{ grid-template-columns:1fr; } .pd__img{ min-height:260px; padding:22px; } .pd__b{ padding:24px 22px; } }

  /* checkout modal */
  .co{ position:fixed; inset:0; z-index:9999990; background:rgba(15,13,10,.6); display:none; align-items:flex-start; justify-content:center; overflow:auto; padding:40px 16px; }
  .co.open{ display:flex; }
  .co__card{ position:relative; background:var(--paper,#faf6ed); border-radius:4px; width:min(560px,100%); padding:34px 34px 30px; max-height:calc(100vh - 48px); max-height:calc(100dvh - 48px); overflow:auto; }
  .co__card h2{ font-family:var(--serif,Georgia,serif); font-size:28px; color:var(--ink,#1c1a17); margin-bottom:4px; }
  .co__card .sub{ color:rgba(28,26,23,.6); font-family:var(--serif,Georgia,serif); margin-bottom:22px; }
  .fgrid{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:8px; }
  .field{ display:flex; flex-direction:column; gap:5px; margin-bottom:14px; }
  .field.full{ grid-column:1/-1; }
  .field label{ font:600 9px var(--mono,monospace); letter-spacing:.12em; text-transform:uppercase; color:rgba(28,26,23,.6); }
  .field input{ padding:12px 13px; border:1px solid rgba(28,26,23,.25); border-radius:2px; font-size:15px; background:#fff; font-family:var(--serif,Georgia,serif); }
  .co__pay{ border:1px dashed rgba(28,26,23,.3); border-radius:3px; padding:16px; background:rgba(28,26,23,.03); margin:6px 0 16px; }
  .co__pay .tag{ font:600 9px var(--mono,monospace); letter-spacing:.12em; text-transform:uppercase; color:var(--gold-dark,#8a6731); margin-bottom:10px; }
  .co__x{ position:absolute; top:14px; right:14px; width:44px; height:44px; border:0; background:none; cursor:pointer; font:300 30px/1 var(--serif,serif); color:rgba(28,26,23,.55); }
.co__x:hover, .co__x:focus{ color:var(--ox,#8f2418); }
.co__https{ font:600 11px/1.6 var(--mono,monospace); letter-spacing:.08em; text-transform:uppercase; color:var(--ox,#8f2418); margin:0 0 10px; }
  .co__note{ font-family:var(--serif,Georgia,serif); font-size:13px; color:rgba(28,26,23,.55); margin-top:8px; }
  .co__ok{ text-align:center; padding:20px 0; }
  .co__ok .chk{ font-size:44px; color:#1f8a5b; }
  .co__ok h2{ margin:10px 0 6px; }
  @media (max-width:820px){ .sf-grid{ grid-template-columns:repeat(2,1fr); gap:14px; } .fgrid{ grid-template-columns:1fr; } .sf-tabs{ flex-wrap:nowrap; overflow-x:auto; padding-bottom:6px; -webkit-overflow-scrolling:touch; } .sf-tabs button{ white-space:nowrap; } .sf-search{ max-width:none; } .pcard__b{ padding:12px 12px 14px; } .pcard__n{ font-size:15px; } .pcard__price{ font-size:17px; } }
  @media (max-width:520px){ .sf-grid{ grid-template-columns:1fr; } }

/* =========================================================
   §17  FISHING-GEAR AD LANDER
   ========================================================= */
/* ---- fishing landing page (campaign) ---- */
  .lp-head{ position:sticky; top:0; z-index:40; background:rgba(22,19,15,.96); border-bottom:1px solid rgba(250,246,237,.1); }
  .lp-head .wrap{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding:14px 0; }
  .lp-head .brand{ display:flex; align-items:center; gap:12px; text-decoration:none; }
  .lp-head .brand img{ width:42px; height:42px; }
  .lp-head .brand b{ font-family:var(--serif,Georgia,serif); color:#faf6ed; font-weight:600; font-size:19px; letter-spacing:.01em; display:block; line-height:1.05; }
  .lp-head .brand b i{ font-style:italic; }
  .lp-head .brand small{ display:block; font:600 9px/1.4 var(--mono,monospace); letter-spacing:.18em; text-transform:uppercase; color:rgba(250,246,237,.6); }
  .lp-head__cta{ display:flex; align-items:center; gap:10px; }
  .lp-head__cta .tel{ color:#faf6ed; text-decoration:none; font:600 13px/1 var(--mono,monospace); letter-spacing:.06em; opacity:.85; }
  .lp-head__cta .tel:hover{ opacity:1; color:#c9a159; }

  .lp-hero{ position:relative; min-height:clamp(520px,74vh,760px); display:flex; align-items:flex-end; overflow:hidden; background:#16130f; }
  .lp-hero__bg{ position:absolute; inset:0; background-image:url('assets/img/fly-fishing.jpg'); background-size:cover; background-position:center 30%; }
  .lp-hero__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg,rgba(15,13,10,.9) 0%,rgba(15,13,10,.66) 42%,rgba(15,13,10,.15) 100%); }
  .lp-hero .wrap{ position:relative; padding:56px 0 60px; }
  .lp-hero h1{ color:#faf6ed; font-family:var(--serif,Georgia,serif); font-weight:600; font-size:clamp(38px,5.6vw,72px); line-height:1.02; max-width:15ch; margin:12px 0 0; }
  .lp-hero h1 em{ font-style:italic; color:#c9a159; }
  .lp-hero p.sub{ color:rgba(250,246,237,.9); font-family:var(--serif,Georgia,serif); font-size:clamp(17px,1.9vw,22px); line-height:1.5; max-width:46ch; margin:18px 0 26px; }
  .lp-hero .hero__btns{ display:flex; flex-wrap:wrap; gap:14px; }

  .lp-trust{ background:var(--ink,#1c1a17); }
  .lp-trust .wrap{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:rgba(250,246,237,.12); border-radius:2px; overflow:hidden; }
  .lp-trust .cell{ background:var(--ink,#1c1a17); padding:26px 22px; }
  .lp-trust .cell b{ display:block; color:#c9a159; font:600 10px/1.4 var(--mono,monospace); letter-spacing:.16em; text-transform:uppercase; margin-bottom:8px; }
  .lp-trust .cell span{ color:rgba(250,246,237,.9); font-family:var(--serif,Georgia,serif); font-size:17px; line-height:1.4; }

  .lp-visit{ background:var(--ink,#1c1a17); }
  .lp-visit .wrap{ display:grid; grid-template-columns:1fr 1fr; gap:0; align-items:stretch; border:1px solid rgba(250,246,237,.14); border-radius:3px; overflow:hidden; }
  .lp-visit__art{ background-image:url('assets/img/shop-interior.jpg'); background-size:cover; background-position:center 74%; min-height:340px; }
  .lp-visit__body{ padding:48px 46px; color:#faf6ed; }
  .lp-visit__body h2{ font-family:var(--serif,Georgia,serif); font-size:clamp(26px,3vw,38px); font-weight:600; margin:8px 0 20px; }
  .lp-visit dl{ margin:0 0 26px; display:grid; grid-template-columns:auto 1fr; gap:8px 22px; }
  .lp-visit dt{ font:600 10px/1.6 var(--mono,monospace); letter-spacing:.14em; text-transform:uppercase; color:#c9a159; }
  .lp-visit dd{ margin:0; font-family:var(--serif,Georgia,serif); font-size:17px; line-height:1.5; color:rgba(250,246,237,.9); }
  .lp-visit dd a{ color:rgba(250,246,237,.9); }
  .lp-visit dd a:hover{ color:#c9a159; }

  @media (max-width:860px){
    .lp-trust .wrap{ grid-template-columns:1fr 1fr; }
    .lp-visit .wrap{ grid-template-columns:1fr; }
    .lp-visit__art{ min-height:220px; }
    .lp-head__cta .tel{ display:none; }
  }


/* =========================================================
   §24  PHOTO HERO — the /fishing/ lander hero (.lp-hero),
   generalized to every category page + the /shop/ tabs.
   Full-height photo, text bottom-left, left ink scrim. ONE
   treatment site-wide (1.3.9, per owner).
   ========================================================= */
.hero--photo{ min-height:clamp(460px,64vh,680px); display:flex; align-items:flex-end; background:#16130f; }
.hero--photo .hero__art.has-img{ position:absolute; inset:0; background-size:cover; background-position:center; }
.hero--photo .hero__art.has-img::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(90deg,rgba(15,13,10,.9) 0%,rgba(15,13,10,.66) 42%,rgba(15,13,10,.15) 100%); }
.hero--photo .hero__ram{ display:none; }
.hero--photo .wrap{ position:relative; z-index:2; padding-top:56px; padding-bottom:60px; }
.sf-hero__art{ position:absolute; inset:0; background-size:cover; background-position:center; }
.sf-hero__art::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(90deg,rgba(15,13,10,.9) 0%,rgba(15,13,10,.66) 42%,rgba(15,13,10,.15) 100%); }
.sf-hero .wrap{ position:relative; z-index:2; }

/* =========================================================
   §18  ABOUT
   ========================================================= */
.pagehead{position:relative;color:#faf6ed;overflow:hidden;
  background:
    radial-gradient(120% 90% at 78% 30%, rgba(143,36,24,.34), transparent 60%),
    linear-gradient(120deg,#1c1a17 0%, #241f1a 55%, #2f2820 100%);}
  .pagehead .wrap{position:relative;z-index:2;padding:clamp(56px,8vw,104px) 40px clamp(48px,6vw,84px);}
  .pagehead__ram{position:absolute;right:-90px;bottom:-70px;height:clamp(280px,40vw,440px);opacity:.12;pointer-events:none;z-index:1;}
  .pagehead h1{color:#faf6ed;max-width:16ch;}
  .pagehead__lede{font-family:'Cormorant Garamond',Georgia,serif;font-style:italic;font-size:clamp(18px,2.4vw,24px);line-height:1.5;color:rgba(250,246,237,.82);max-width:56ch;margin:18px 0 0;}
  .pagehead__rule{width:54px;height:2px;background:#c9a159;border:0;margin:22px 0 0;}

  .story{padding:clamp(46px,7vw,86px) 0;}
  .story__grid{display:grid;grid-template-columns:1fr;gap:clamp(20px,3vw,30px);max-width:760px;}
  .story p{font-family:'Cormorant Garamond',Georgia,serif;font-size:clamp(17px,2vw,21px);line-height:1.6;color:rgba(28,26,23,.8);margin:0;}
  .story p strong{font-weight:600;color:#1c1a17;}

  .values{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,22px);margin-top:clamp(30px,4vw,44px);}
  @media(max-width:780px){.values{grid-template-columns:1fr;}}
  .value{background:#f4ede0;border:1px solid rgba(28,26,23,.12);border-radius:3px;padding:clamp(22px,2.6vw,30px);}
  .value__n{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:12px;font-weight:600;letter-spacing:.18em;color:#c9a159;}
  .value h3{margin:.4em 0 .35em;font-size:clamp(20px,2.2vw,24px);}
  .value p{font-family:'Cormorant Garamond',Georgia,serif;font-size:17px;line-height:1.5;color:rgba(28,26,23,.72);margin:0;}

/* =========================================================
   §19  CONTACT
   ========================================================= */
.pagehead{position:relative;color:#faf6ed;overflow:hidden;
  background:
    radial-gradient(120% 90% at 78% 30%, rgba(143,36,24,.34), transparent 60%),
    linear-gradient(120deg,#1c1a17 0%, #241f1a 55%, #2f2820 100%);}
  .pagehead .wrap{position:relative;z-index:2;padding:clamp(56px,8vw,104px) 40px clamp(48px,6vw,84px);}
  .pagehead__ram{position:absolute;right:-90px;bottom:-70px;height:clamp(280px,40vw,440px);opacity:.12;pointer-events:none;z-index:1;}
  .pagehead h1{color:#faf6ed;max-width:16ch;}
  .pagehead__lede{font-family:'Cormorant Garamond',Georgia,serif;font-style:italic;font-size:clamp(18px,2.4vw,24px);line-height:1.5;color:rgba(250,246,237,.82);max-width:56ch;margin:18px 0 0;}
  .pagehead__rule{width:54px;height:2px;background:#c9a159;border:0;margin:22px 0 0;}

  .contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(14px,2vw,22px);}
  @media(max-width:720px){.contact-grid{grid-template-columns:1fr;}}
  .ccard{background:#f4ede0;border:1px solid rgba(28,26,23,.12);border-radius:3px;padding:clamp(24px,3vw,34px);}
  .ccard__k{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:#c9a159;margin:0 0 12px;}
  .ccard h3{margin:0 0 .4em;font-size:clamp(21px,2.3vw,26px);}
  .ccard p{font-family:'Cormorant Garamond',Georgia,serif;font-size:18px;line-height:1.55;color:rgba(28,26,23,.78);margin:0;}
  .ccard a{color:#8f2418;text-decoration:none;border-bottom:1px solid rgba(143,36,24,.3);}
  .ccard a:hover{color:#1c1a17;border-color:#1c1a17;}
  .ccard__meta{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:11px;letter-spacing:.08em;color:rgba(28,26,23,.55);margin-top:14px;display:block;}

/* =========================================================
   §20  LEGAL (privacy/terms) — shared styles (identical blocks)
   ========================================================= */
.pagehead{position:relative;color:#faf6ed;overflow:hidden;
  background:
    radial-gradient(120% 90% at 78% 30%, rgba(143,36,24,.34), transparent 60%),
    linear-gradient(120deg,#1c1a17 0%, #241f1a 55%, #2f2820 100%);}
  .pagehead .wrap{position:relative;z-index:2;padding:clamp(52px,7vw,92px) 40px clamp(40px,5vw,68px);}
  .pagehead__ram{position:absolute;right:-90px;bottom:-70px;height:clamp(260px,38vw,420px);opacity:.12;pointer-events:none;z-index:1;}
  .pagehead h1{color:#faf6ed;max-width:18ch;}
  .pagehead__meta{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(250,246,237,.6);margin:16px 0 0;}

  .legal{padding:clamp(40px,6vw,76px) 0;}
  .legal__inner{max-width:760px;}
  .legal__lede{font-family:'Cormorant Garamond',Georgia,serif;font-size:clamp(18px,2.1vw,22px);line-height:1.55;color:rgba(28,26,23,.78);margin:0 0 clamp(28px,4vw,40px);}
  .legal h2{font-family:'Playfair Display',Georgia,serif;font-weight:600;font-size:clamp(21px,2.5vw,27px);line-height:1.1;margin:clamp(34px,4vw,46px) 0 .5em;padding-top:clamp(22px,3vw,30px);border-top:1px solid rgba(28,26,23,.14);}
  .legal h2:first-of-type{border-top:0;padding-top:0;margin-top:0;}
  .legal p,.legal li{font-family:'Cormorant Garamond',Georgia,serif;font-size:clamp(16.5px,1.9vw,19px);line-height:1.6;color:rgba(28,26,23,.8);}
  .legal p{margin:0 0 1em;}
  .legal ul{margin:0 0 1em;padding-left:1.1em;}
  .legal li{margin:0 0 .5em;}
  .legal a{color:#8f2418;text-decoration:none;border-bottom:1px solid rgba(143,36,24,.3);}
  .legal a:hover{color:#1c1a17;border-color:#1c1a17;}

/* =========================================================
   §21  PALETTE & TYPE LOCKS — beat Divi global/customizer CSS
   Divi's parent style.css + the et-divi-customizer-global inline
   CSS (printed AFTER this sheet in wp_head) leak defaults into
   Code-module content: body #666 / 14px / 'Open Sans', headings
   #333 + padding-bottom:10px, p padding-bottom:1em, links
   #2ea3f2 blue, ul disc + 23px padding. These locks win on
   SPECIFICITY (html body … = 0,0,2+), not source order, so they
   beat the later-printed customizer CSS — while staying BELOW
   every classed component rule in this sheet (0,1,0+), so hero /
   nav / footer / on-dark colors are untouched.
   Palette: oxblood · ink · paper · bone · gold ONLY.
   ========================================================= */
html body{
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
}
html body h1, html body h2, html body h3,
html body h4, html body h5, html body h6{
  color:inherit;            /* dark bands keep paper via inheritance */
  font-family:var(--display);
  font-weight:600;
  line-height:1.05;
  margin:0;
  padding:0;                /* kills Divi h* padding-bottom:10px */
  font-size:revert;         /* UA default unless a classed rule sets one */
}
html body p{ padding-bottom:0; }   /* kills Divi p{padding-bottom:1em} */
html body ul, html body ol{
  margin:revert; padding:revert; list-style:revert;   /* UA defaults, not Divi's */
}
html body a{ color:var(--ox); text-decoration:none; }
html body a:hover, html body a:focus{ color:var(--ink); }   /* never default blue */

/* =========================================================
   §22  1.3.2 ADDITIONS — topbar tel link · product-shot card
   fill · Dispatch subscribe status line
   ========================================================= */
/* topbar phone link — paper like its siblings, gold hover, never blue */
.topbar a{ color:var(--paper); text-decoration:none; }
.topbar a:hover, .topbar a:focus{ color:var(--gold); }
.topbar .nowrap{ white-space:nowrap; }

/* product photography in category cards: contained on white, no gradient wash */
.cat-card__ph.has-img--product{ background-color:#fff; background-size:72%; background-repeat:no-repeat; background-position:center; }
.cat-card__ph.has-img--product::before{ display:none; }

/* Dispatch signup status line (assets/dispatch-subscribe.js) */
.signup .tss-sub-msg{ font-family:var(--serif); font-size:17px; color:rgba(250,246,237,.95); margin:14px auto 0; max-width:46ch; }

/* =========================================================
   §23  PHOTO HEROES & EMPTY SEARCH STATE (1.3.4)
   Photo layers behind hero/sf-hero text, scrimmed ink-side so
   paper/gold copy always clears contrast. Palette-locked.
   ========================================================= */
.sf-empty{ grid-column:1/-1; padding:56px 20px; text-align:center; background:var(--bone); border:1px solid rgba(28,26,23,.08); }
.sf-empty b{ display:block; font-family:var(--display); font-size:24px; font-weight:600; margin-bottom:8px; }
.sf-empty span{ font-family:var(--serif); font-size:17px; color:rgba(28,26,23,.7); }
.sf-empty a{ color:var(--ox); font-weight:600; }
.sf-empty a:hover, .sf-empty a:focus{ color:var(--ink); }
  .legal strong{font-weight:600;color:#1c1a17;}

/* =========================================================
   §24  STICKY HEADER — fixed mode (ss-sticky-overlays.js)
   Divi TB wrappers are exactly header-height, so sticky has
   no room; the JS swaps to fixed past the trigger point.
   ========================================================= */
header.site-head.is-stuck{ position:fixed; left:0; right:0; top:0; z-index:999900;
  box-shadow:0 10px 26px -18px rgba(28,26,23,.5); }

/* =========================================================
   §24  CONTACT MAP & DIRECTIONS (1.3.21)
   Keyless Google embed in an editorial frame; gold directions
   CTA. iframe filtered toward the palette (warm sepia).
   ========================================================= */
.mapsec{ background:var(--bone); padding:72px 0; }
.mapsec .wrap{ max-width:1200px; margin:0 auto; padding:0 28px; }
.mapsec__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap; margin-bottom:26px; }
.mapsec__head h2{ font-family:var(--display); font-size:clamp(26px,3vw,38px); font-weight:600; color:var(--ink); margin:6px 0 0; }
.mapsec__frame{ position:relative; border:1px solid rgba(28,26,23,.14); box-shadow:0 24px 50px -30px rgba(28,26,23,.5); background:var(--ink); }
.mapsec__frame::before{ content:""; position:absolute; inset:0; border:1px solid rgba(201,161,89,.5); margin:10px; pointer-events:none; z-index:2; }
.mapsec__frame iframe{ display:block; width:100%; height:440px; border:0; filter:grayscale(1) sepia(.32) saturate(1.05) brightness(1.03) contrast(1.04); }
@media (max-width:640px){ .mapsec__frame iframe{ height:340px; } .mapsec{ padding:52px 0; } }

/* =========================================================
   §25  CART FREE-SHIPPING METER (1.3.22)
   ========================================================= */
.freeship{ margin:0 0 14px; }
.freeship__txt{ font-family:var(--serif,Georgia,serif); font-size:14px; color:rgba(28,26,23,.75); margin:0 0 8px; }
.freeship__txt b{ color:var(--ox,#8f2418); font-weight:600; }
.freeship.is-met .freeship__txt, .freeship.is-met .freeship__txt b{ color:var(--ox,#8f2418); }
.freeship__bar{ height:3px; background:rgba(28,26,23,.12); overflow:hidden; }
.freeship__bar span{ display:block; height:100%; width:0; background:var(--gold,#c9a159); transition:width .35s ease; }
.freeship.is-met .freeship__bar span{ background:var(--ox,#8f2418); }
