/* ============================================================
   BUSSO JERKY · shared stylesheet
   Used by every page. Header + footer are baked statically into
   each HTML file; this file styles them identically everywhere.
   ============================================================ */

:root{
  --red:#B5121B; --red-br:#d8262f; --red-dk:#7d1217;
  --char:#15110f; --char2:#221b17; --char3:#2c231d;
  --cream:#f4ecd8; --cream2:#e9dcc0; --gold:#e0a53b; --gold-dk:#c98e2a;
  --muted:#b9ac98; --line:rgba(224,165,59,.18);
  --maxw:1180px; --hd:68px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
/* kill the mobile blue tap flash, but keep a visible outline for keyboard users */
a,button,[role="button"],[tabindex],input,select,textarea{-webkit-tap-highlight-color:transparent;outline-color:var(--gold)}
:focus:not(:focus-visible){outline:none}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} }

/* hidden scrollbars site-wide, scrolling still works; stable gutter
   avoids horizontal flicker when content height changes */
html{ -ms-overflow-style:none; scrollbar-width:none; }
html::-webkit-scrollbar{ width:0; height:0; display:none; }
body{ overflow-y:scroll; scrollbar-gutter:stable; }
body::-webkit-scrollbar{ width:0; height:0; display:none; }

body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--char); color:var(--cream);
  overflow-x:hidden; line-height:1.5;
  /* sticky footer: column layout, main fills viewport */
  min-height:100dvh; display:flex; flex-direction:column;
  -webkit-font-smoothing:antialiased;
}

h1,h2,h3,.disp{font-family:'Anton',sans-serif;font-weight:400;letter-spacing:.5px;text-transform:uppercase;line-height:.95}
.os{font-family:'Oswald',sans-serif}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px;width:100%}
.r{color:var(--red)}
.gold{color:var(--gold)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--red);color:#fff;
  font-family:'Oswald',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;
  padding:15px 34px;border-radius:3px;font-size:15px;border:2px solid var(--red);
  transition:background .2s var(--ease),color .2s var(--ease),transform .2s var(--ease);cursor:pointer;text-align:center}
.btn:hover{background:var(--red-br);border-color:var(--red-br)}
.btn:active{transform:translateY(1px)}
.btn.ghost{background:transparent;border-color:var(--cream);color:var(--cream)}
.btn.ghost:hover{background:var(--cream);color:var(--char)}
.btn.gold{background:var(--gold);border-color:var(--gold);color:var(--char)}
.btn.gold:hover{background:var(--gold-dk);border-color:var(--gold-dk)}
.btn.sm{padding:11px 22px;font-size:13px;letter-spacing:1px}

/* =====================================================
   HEADER (static markup, identical on every page)
   ===================================================== */
.site-header{position:sticky;top:0;z-index:60;background:rgba(21,17,15,.92);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid rgba(224,165,59,.25)}
.nav{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;height:var(--hd)}
.nav-left{display:flex;align-items:center;gap:10px;justify-self:start}
.nav-center{justify-self:center}
.logo{display:flex;align-items:center;justify-self:center}
.logo picture{display:block;line-height:0}
/* real badge-crest logo (300x288). Fixed reserved box -> no layout shift while loading. */
.logo .logo-img{display:block;height:56px;width:auto;object-fit:contain}
.site-footer .logo .logo-img{height:72px}
@media (max-width:540px){ .site-header .logo .logo-img{height:48px} }
.nav-links{display:flex;gap:24px;font-family:'Oswald';font-weight:600;text-transform:uppercase;font-size:14px;letter-spacing:1px}
.nav-links a{position:relative;padding:4px 0;transition:color .18s var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--gold)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--gold)}
.nav-right{display:flex;align-items:center;gap:14px}
.bag-btn{display:flex;align-items:center;gap:8px;font-family:'Oswald';font-weight:600;font-size:14px;
  text-transform:uppercase;letter-spacing:1px;border:1px solid var(--gold);padding:8px 14px;border-radius:3px;
  background:transparent;color:var(--cream);cursor:pointer;transition:.18s var(--ease)}
.bag-btn:hover{background:var(--gold);color:var(--char)}
.bag-count{display:inline-grid;place-items:center;min-width:20px;height:20px;padding:0 5px;border-radius:20px;
  background:var(--red);color:#fff;font-size:12px;font-weight:700;line-height:1}
.bag-btn:hover .bag-count{background:var(--char)}
.hamburger{display:none;flex-direction:column;gap:5px;width:42px;height:42px;border:1px solid var(--line);
  border-radius:4px;background:transparent;cursor:pointer;align-items:center;justify-content:center}
.hamburger span{display:block;width:20px;height:2px;background:var(--cream);transition:.25s var(--ease)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile menu panel */
.mobile-menu{position:fixed;inset:var(--hd) 0 auto 0;background:rgba(17,13,11,.98);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
  z-index:80;transform:translateY(-12px);opacity:0;pointer-events:none;transition:.25s var(--ease)}
.mobile-menu.open{transform:translateY(0);opacity:1;pointer-events:auto}
.mobile-menu a{display:block;padding:16px 22px;font-family:'Oswald';font-weight:600;text-transform:uppercase;
  letter-spacing:1px;border-bottom:1px solid rgba(224,165,59,.1)}
.mobile-menu a:hover{color:var(--gold);background:rgba(224,165,59,.06)}

@media(max-width:880px){
  .nav-links{display:none}
  .hamburger{display:flex}
}

/* =====================================================
   PAGE / MAIN + FADE TRANSITIONS
   The #page wrapper fades; header/footer/background stay put.
   ===================================================== */
main{flex:1 0 auto;display:block}
.page-fade{opacity:1;transition:opacity .32s var(--ease),transform .32s var(--ease)}
.page-fade.is-leaving{opacity:0;transform:translateY(8px)}
.page-fade.is-entering{opacity:0;transform:translateY(8px)}
@media (prefers-reduced-motion: reduce){
  .page-fade,.page-fade.is-leaving,.page-fade.is-entering{transition:none;transform:none;opacity:1}
}

/* =====================================================
   HERO
   ===================================================== */
.hero{position:relative;min-height:86vh;display:flex;align-items:center;text-align:center;overflow:hidden;
  background:
    linear-gradient(180deg,rgba(21,17,15,.55),rgba(21,17,15,.92)),
    repeating-linear-gradient(135deg,#3a201a 0 22px,#341c16 22px 44px)}
.hero .glow{position:absolute;inset:0;background:radial-gradient(60% 55% at 50% 30%,rgba(184,29,36,.5),transparent 70%);pointer-events:none}
.hero-inner{position:relative;z-index:2;margin:0 auto;max-width:900px;padding:70px 22px}
.kick{font-family:'Oswald';font-weight:700;letter-spacing:4px;text-transform:uppercase;color:var(--gold);font-size:14px;margin-bottom:18px}
.hero h1{font-size:clamp(46px,9vw,104px);text-shadow:0 4px 30px rgba(0,0,0,.5)}
.hero h1 .r{color:var(--red-br);-webkit-text-stroke:1px var(--gold)}
.hero p{font-size:clamp(16px,2.4vw,20px);color:var(--cream2);max-width:560px;margin:22px auto 32px;line-height:1.55}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.scrollcue{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:3;color:var(--muted);
  font-family:'Oswald';font-size:12px;letter-spacing:2px;text-transform:uppercase;animation:bob 1.8s infinite}
@keyframes bob{50%{transform:translate(-50%,8px)}}
@media (prefers-reduced-motion: reduce){.scrollcue{animation:none}}

/* small page hero for inner pages */
.page-hero{position:relative;text-align:center;padding:72px 22px 56px;overflow:hidden;
  background:linear-gradient(180deg,rgba(21,17,15,.6),rgba(21,17,15,.95)),
    repeating-linear-gradient(135deg,#341c16 0 22px,#2c1813 22px 44px)}
.page-hero h1{font-size:clamp(38px,7vw,72px)}
.page-hero p{color:var(--cream2);max-width:560px;margin:16px auto 0;line-height:1.55}

/* =====================================================
   TRUST STRIP
   ===================================================== */
.trust{background:var(--red);color:#fff}
.trust .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:12px 40px;padding:15px 22px;
  font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:1.5px;font-size:14px}
.trust span{display:flex;align-items:center;gap:9px}
.trust b{color:var(--gold)}

/* =====================================================
   SECTIONS
   ===================================================== */
section.block{padding:72px 0}
section.block.tight{padding:54px 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:26px;flex-wrap:wrap}
.sec-head h2{font-size:clamp(30px,5vw,52px)}
.sec-head .sub{color:var(--muted);font-family:'Oswald';letter-spacing:1px;text-transform:uppercase;font-size:13px}
.sec-head a.more{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:1px;font-size:13px;color:var(--gold);white-space:nowrap}
.sec-head a.more:hover{text-decoration:underline}

.funnelband{text-align:center;max-width:660px;margin:0 auto 30px}
.funnelband .kick{margin-bottom:10px}
.funnelband h2{font-size:clamp(30px,5vw,52px)}
.funnelband p{color:var(--muted);line-height:1.55;margin-top:10px}

/* =====================================================
   PRODUCT RAILS (home funnel) + CARDS
   ===================================================== */
.rail{display:flex;gap:18px;overflow-x:auto;padding:6px 4px 16px;scroll-snap-type:x mandatory;
  -ms-overflow-style:none;scrollbar-width:none}
.rail::-webkit-scrollbar{height:0;display:none}
.rail .card{scroll-snap-align:start;flex:0 0 280px}

.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}

.card{background:var(--char2);border-radius:8px;overflow:hidden;border:1px solid var(--line);
  transition:transform .22s var(--ease),border-color .22s var(--ease),box-shadow .22s var(--ease);
  display:flex;flex-direction:column;cursor:pointer;position:relative}
/* simple, tasteful baseline hover: a gentle lift + shadow (nothing cursor-reactive) */
.card:hover{transform:translateY(-6px);border-color:var(--gold);box-shadow:0 14px 30px rgba(0,0,0,.35)}
.card .pic{height:200px;position:relative;display:grid;place-items:center;font-family:'Anton';
  font-size:58px;color:rgba(255,255,255,.12);background-size:cover;background-position:center}
.card .pic .plabel{padding:0 10px;text-align:center}
.pic.biltong{background:linear-gradient(150deg,#6e2b1d,#3a1712)}
.pic.wors{background:linear-gradient(150deg,#8a3a1c,#43200f)}
.pic.jerky{background:linear-gradient(150deg,#7a2418,#3c160e)}
.pic.sticks{background:linear-gradient(150deg,#6b2f17,#36180c)}
.pic.steak{background:linear-gradient(150deg,#9a2b2b,#451414)}
.pic.hamper{background:linear-gradient(150deg,#7d4a16,#3a2208)}
.pic .tag{position:absolute;top:12px;left:12px;background:var(--gold);color:var(--char);font-family:'Oswald';
  font-weight:700;font-size:11px;letter-spacing:1px;text-transform:uppercase;padding:4px 9px;border-radius:3px}
.pic .tag.pickup{background:var(--cream);color:var(--char)}
.pic .heat{position:absolute;top:12px;right:12px;font-size:12px;letter-spacing:1px;background:rgba(0,0,0,.4);
  padding:4px 8px;border-radius:3px;font-family:'Oswald';font-weight:600;text-transform:uppercase;color:var(--cream2);
  display:inline-flex;align-items:center;gap:3px}
.pic .heat .heat-ico{flex:0 0 auto}
.card .body{padding:16px 17px 18px;display:flex;flex-direction:column;flex:1}
.card h3{font-size:21px;margin-bottom:5px}
.card .desc{color:var(--muted);font-size:13.5px;line-height:1.45;min-height:40px;flex:1}
.card .row{display:flex;align-items:center;justify-content:space-between;margin-top:14px;gap:10px}
.price{font-family:'Oswald';font-weight:700;font-size:18px;color:var(--gold)}
.price .from{font-size:12px;color:var(--muted);font-weight:500;letter-spacing:.5px}
.add{font-family:'Oswald';font-weight:700;font-size:12px;letter-spacing:1px;text-transform:uppercase;
  background:var(--red);color:#fff;padding:9px 15px;border-radius:3px;border:none;cursor:pointer;transition:background .18s var(--ease)}
.add:hover{background:var(--red-br)}

/* scroll reveal: staggered rise + de-blur + fade */
.reveal{opacity:0;transform:translateY(26px);filter:blur(6px);
  transition:opacity .6s var(--ease),transform .6s var(--ease),filter .6s var(--ease)}
.reveal.in{opacity:1;transform:none;filter:blur(0)}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;filter:none;transition:none}
}

/* =====================================================
   FEATURE TEASERS (subscribe / hampers / story)
   ===================================================== */
.teaser{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--line)}
.teaser-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media(max-width:780px){.teaser-grid{grid-template-columns:1fr}}
.teaser .inner{position:relative;z-index:2;padding:40px 36px}
.teaser h3{font-size:clamp(26px,4vw,38px);margin-bottom:12px}
.teaser p{color:var(--cream2);line-height:1.6;margin-bottom:20px;max-width:42ch}
.teaser.sub{background:linear-gradient(150deg,#2c231d,#1a1411)}
.teaser.sub::after{content:"";position:absolute;inset:0;background:radial-gradient(70% 80% at 90% 10%,rgba(224,165,59,.16),transparent 60%);pointer-events:none}
.teaser.gift{background:linear-gradient(150deg,#3a2208,#1a1411)}
.teaser.gift::after{content:"";position:absolute;inset:0;background:radial-gradient(70% 80% at 90% 10%,rgba(184,29,36,.22),transparent 60%);pointer-events:none}
.teaser .save-badge{display:inline-block;font-family:'Oswald';font-weight:700;font-size:12px;letter-spacing:1px;
  text-transform:uppercase;background:var(--gold);color:var(--char);padding:5px 12px;border-radius:20px;margin-bottom:14px}

/* loyalty / gift card mini grid */
.perks{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:780px){.perks{grid-template-columns:1fr}}
.perk{background:var(--char2);border:1px solid var(--line);border-radius:10px;padding:26px 24px}
.perk .ic{font-size:26px;margin-bottom:12px;color:var(--gold)}
.perk .ic svg{width:30px;height:30px;display:block;color:var(--gold)}
.perk-head{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.perk-ic{flex:0 0 auto;width:36px;height:36px;display:grid;place-items:center;color:var(--gold);
  border:1px solid var(--line);border-radius:9px;background:rgba(224,165,59,.08)}
.perk-ic svg{width:20px;height:20px}
.perk-head h3{margin:0;font-size:21px}
.perk h3{font-size:21px;margin-bottom:8px}
.perk p{color:var(--muted);line-height:1.55;font-size:14.5px}

/* =====================================================
   STORY
   ===================================================== */
.story{background:
  linear-gradient(180deg,rgba(21,17,15,.86),rgba(21,17,15,.96)),
  repeating-linear-gradient(45deg,#2a1813 0 30px,#241410 30px 60px)}
.story .grid{display:grid;grid-template-columns:1.1fr 1fr;gap:46px;align-items:center}
.story h2{font-size:clamp(30px,5vw,54px);margin-bottom:18px}
.story p{color:var(--cream2);line-height:1.7;margin-bottom:14px;font-size:16px}
.story .panel{aspect-ratio:4/3.4;border-radius:10px;border:2px solid var(--gold);
  background:radial-gradient(circle at 50% 40%,var(--red-br),var(--red-dk));display:grid;place-items:center;text-align:center;padding:30px}
.story .panel picture{display:block;line-height:0;margin:0 auto 16px}
.story .panel .panel-logo{display:block;height:150px;width:auto;object-fit:contain}
.story .panel small{font-family:'Oswald';letter-spacing:3px;text-transform:uppercase;color:var(--cream2);font-size:13px}
@media(max-width:780px){.story .grid{grid-template-columns:1fr;gap:30px}}

/* prose blocks (story / shipping / contact) */
.prose{max-width:760px;margin:0 auto}
.prose h2{font-size:clamp(26px,4vw,40px);margin:34px 0 14px}
.prose h2:first-child{margin-top:0}
.prose p{color:var(--cream2);line-height:1.75;margin-bottom:16px;font-size:16px}
.prose .lead{font-size:19px;color:var(--cream)}

/* =====================================================
   SHIPPING SPLIT
   ===================================================== */
.ship .cols{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.ship .c{background:var(--char2);border-radius:8px;padding:30px;border-left:4px solid var(--gold)}
.ship .c.fresh{border-left-color:var(--red)}
.ship .c h3{font-size:24px;margin-bottom:10px}
.ship .c p{color:var(--muted);line-height:1.6}
.ship .c .pill{display:inline-block;font-family:'Oswald';font-weight:700;font-size:12px;letter-spacing:1px;
  text-transform:uppercase;padding:5px 12px;border-radius:20px;margin-bottom:14px}
.pill.g{background:rgba(224,165,59,.18);color:var(--gold)}
.pill.rr{background:rgba(184,29,36,.22);color:#ff8a8f}
@media(max-width:680px){.ship .cols{grid-template-columns:1fr}}

/* =====================================================
   NEWSLETTER
   ===================================================== */
.news{background:var(--red);text-align:center;padding:64px 22px}
.news h2{font-size:clamp(28px,5vw,46px);color:#fff}
.news p{color:#ffe3d6;margin:12px auto 24px;max-width:480px}
.news form{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;align-items:center}
.news input{padding:14px 18px;border-radius:3px;border:none;min-width:280px;font-family:'Inter';font-size:15px;color:var(--char)}
.news .ok{color:#fff;font-family:'Oswald';font-weight:600;letter-spacing:1px;text-transform:uppercase;margin-top:14px}

/* =====================================================
   CATALOGUE FILTERS
   ===================================================== */
.catbar{display:flex;flex-direction:column;gap:18px;margin-bottom:30px}
.filter-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.filter-row .flabel{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:1px;
  font-size:12px;color:var(--muted);margin-right:4px}
.chip{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-size:13px;
  padding:8px 15px;border-radius:30px;border:1px solid var(--line);background:transparent;color:var(--cream);
  cursor:pointer;transition:.16s var(--ease)}
.chip:hover{border-color:var(--gold)}
.chip.active{background:var(--gold);border-color:var(--gold);color:var(--char)}
.cat-meta{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  border-top:1px solid var(--line);padding-top:16px}
.cat-meta .count{color:var(--muted);font-family:'Oswald';letter-spacing:1px;text-transform:uppercase;font-size:13px}
.clear-all{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:1px;font-size:12px;
  color:var(--gold);background:transparent;border:none;cursor:pointer}
.clear-all:hover{text-decoration:underline}
.empty{text-align:center;color:var(--muted);padding:60px 0;font-family:'Oswald';letter-spacing:1px;text-transform:uppercase}

/* =====================================================
   PRODUCT MODAL
   bottom-sheet on mobile, centered box on desktop
   ===================================================== */
.modal-root{position:fixed;inset:0;z-index:120;display:none}
.modal-root.show{display:block}
.modal-backdrop{position:absolute;inset:0;background:rgba(8,6,5,.6);opacity:0;transition:opacity .3s var(--ease)}
.modal-root.show .modal-backdrop{opacity:1}
.modal-root.closing .modal-backdrop{opacity:0}

.modal{position:absolute;left:0;right:0;bottom:0;max-height:92vh;overflow-y:auto;
  background:rgba(34,27,23,.86);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-top:1px solid var(--line);border-radius:18px 18px 0 0;
  transform:translateY(100%);transition:transform .34s var(--ease);
  -ms-overflow-style:none;scrollbar-width:none}
.modal::-webkit-scrollbar{display:none}
.modal-root.show .modal{transform:translateY(0)}
.modal-root.closing .modal{transform:translateY(100%)}

.modal .handle{width:42px;height:5px;border-radius:5px;background:rgba(244,236,216,.35);margin:10px auto 0;display:block}
.modal .close{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;border:1px solid var(--line);
  background:rgba(0,0,0,.25);color:var(--cream);font-size:18px;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:3}
.modal-inner{padding:22px 24px 28px}

/* two-column layout: images left, content right (stacks on mobile) */
.m-grid{display:grid;grid-template-columns:1fr;gap:22px}
.m-pic{height:240px;border-radius:12px;display:grid;place-items:center;overflow:hidden;
  background-size:cover;background-position:center;position:relative}
.m-pic .m-pic-lbl{font-family:'Anton';font-size:54px;color:rgba(255,255,255,.13);text-align:center;padding:0 10px}
.modal .m-tag{position:absolute;top:12px;left:12px;background:var(--gold);color:var(--char);font-family:'Oswald';
  font-weight:700;font-size:11px;letter-spacing:1px;text-transform:uppercase;padding:4px 9px;border-radius:3px;z-index:2}
.modal .m-tag.pickup{background:var(--cream)}
.m-thumbs{display:flex;gap:10px;margin-top:12px}
.m-thumb{flex:1;max-width:88px;aspect-ratio:1/1;border-radius:8px;border:1px solid var(--line);
  background-size:cover;background-position:center;opacity:.7}

/* meta as plain text with middot separators (not pills) */
.m-meta{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:1.5px;font-size:12px;
  color:var(--cream2);margin-bottom:12px;display:flex;flex-wrap:wrap;align-items:center;gap:6px}
.m-meta .m-sep{color:var(--muted);font-weight:400}
.modal h2{font-size:clamp(26px,4vw,40px);margin-bottom:12px;line-height:1.02}
.m-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
/* squared-off tag elements (slightly-rounded rectangles, not pills) */
.tag-pill{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-size:11px;
  color:var(--muted);background:rgba(224,165,59,.08);border:1px solid rgba(224,165,59,.18);padding:4px 10px;border-radius:3px}
.modal .m-notes{color:var(--cream2);line-height:1.65;margin-bottom:20px}
.m-amount{margin-bottom:20px}

.opt-label{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:1px;font-size:12px;color:var(--muted);margin-bottom:8px}
.weights{display:flex;flex-wrap:wrap;gap:9px}
.weight-opt{font-family:'Oswald';font-weight:600;font-size:14px;padding:9px 16px;border-radius:6px;
  border:1px solid var(--line);background:transparent;color:var(--cream);cursor:pointer;transition:.16s var(--ease);text-align:center;min-width:74px}
.weight-opt small{display:block;font-size:11px;color:var(--muted);font-weight:500;margin-top:2px}
.weight-opt:hover{border-color:var(--gold)}
.weight-opt.active{border-color:var(--gold);background:rgba(224,165,59,.12)}
.weight-opt.active small{color:var(--gold)}

/* purchase group: price + Save (left, centered, min-width) / subscribe over buy button (right, stretches) */
.m-buy{display:grid;grid-template-columns:minmax(160px,auto) 1fr;gap:22px;align-items:stretch;
  padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:18px}
.m-buy-left{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-width:160px}
.m-buy-left .m-price{font-family:'Oswald';font-weight:800;font-size:clamp(36px,3.8vw,58px);color:var(--gold);white-space:nowrap;line-height:.95}
.m-buy-left .m-price .strike{font-size:17px;color:var(--muted);text-decoration:line-through;margin-right:8px}
.m-unit{font-size:13px;color:var(--muted);margin-top:4px}
.m-save{margin-top:8px;font-family:'Oswald';font-weight:700;text-transform:uppercase;letter-spacing:.5px;font-size:12px;color:var(--gold)}
.m-buy-right{display:flex;flex-direction:column;gap:12px;justify-content:center}
.m-buy-right .btn{width:100%}
/* quantity stepper (for hampers / fresh - products without a weight selector) */
.qtyctrl{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:8px;overflow:hidden;width:max-content}
.qtyctrl button{width:42px;height:42px;background:transparent;border:none;color:var(--cream);font-size:20px;cursor:pointer;transition:background .16s var(--ease)}
.qtyctrl button:hover{background:rgba(224,165,59,.12)}
.qtyctrl .q{min-width:46px;text-align:center;font-family:'Oswald';font-weight:700;font-size:16px}

.sub-toggle{display:flex;align-items:flex-start;gap:12px;background:rgba(224,165,59,.07);border:1px solid var(--line);
  border-radius:10px;padding:13px 14px;cursor:pointer}
.sub-toggle .box{width:22px;height:22px;flex:0 0 22px;border-radius:5px;border:2px solid var(--gold);
  display:grid;place-items:center;margin-top:1px;transition:.16s var(--ease)}
.sub-toggle .box::after{content:"✓";color:var(--char);font-size:14px;font-weight:700;opacity:0;transition:.16s var(--ease)}
.sub-toggle.on .box{background:var(--gold)}
.sub-toggle.on .box::after{opacity:1}
.sub-toggle .t b{display:block;font-family:'Oswald';text-transform:uppercase;letter-spacing:.5px;font-size:13px;color:var(--cream)}
.sub-toggle .t span{font-size:12px;color:var(--muted);white-space:nowrap}
.modal .ship-note{font-size:12.5px;color:var(--muted);margin-bottom:18px;line-height:1.5}

/* nutrition, scaled to selected weight */
.m-nutri{border:1px solid var(--line);border-radius:10px;padding:14px 16px;background:rgba(0,0,0,.18)}
.m-nutri .opt-label{margin-bottom:10px}
.m-nutri-per{color:var(--gold);margin-left:6px}
.m-nutri-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;text-align:center}
.m-nutri-grid > div{display:flex;flex-direction:column;gap:2px}
.m-nutri-grid b{font-family:'Oswald';font-weight:700;font-size:16px;color:var(--cream)}
.m-nutri-grid span{font-family:'Oswald';text-transform:uppercase;letter-spacing:.5px;font-size:10px;color:var(--muted)}

/* you might also like */
.m-suggest{margin-top:24px;padding-top:20px;border-top:1px solid var(--line)}
/* one even row: cards + tile are equal columns (count set inline) and fill the modal width */
.m-suggest-row{display:grid;gap:12px;align-items:stretch}
/* understated "surprise me" tile - same surface as the cards, quiet type */
.sug-surprise{display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:6px;text-align:center;cursor:pointer;border:1px solid var(--line);border-radius:10px;padding:12px;
  background:var(--char2);color:var(--cream);overflow:hidden;
  transition:border-color .18s var(--ease),transform .18s var(--ease)}
.sug-surprise:hover{border-color:var(--gold);transform:translateY(-3px)}
.sug-surprise .ss-kicker{font-family:'Oswald';font-weight:500;text-transform:uppercase;letter-spacing:1px;font-size:9.5px;color:var(--muted)}
.sug-surprise .ss-big{font-family:'Oswald';font-weight:600;text-transform:uppercase;line-height:1.1;letter-spacing:.5px;font-size:13px;color:var(--cream)}
.sug-surprise .ss-sub{font-family:'Oswald';font-weight:500;text-transform:uppercase;letter-spacing:.5px;font-size:10px;color:var(--gold)}
@media(max-width:560px){
  .m-suggest-row{grid-template-columns:1fr 1fr !important}
  .sug-surprise{padding:18px 12px}
}
/* mirrors the product card: gradient image on top, content below, price pinned bottom */
.sug-card{display:flex;flex-direction:column;background:var(--char2);border:1px solid var(--line);border-radius:10px;
  overflow:hidden;padding:0;cursor:pointer;text-align:left;transition:border-color .18s var(--ease),transform .18s var(--ease)}
.sug-card:hover{border-color:var(--gold);transform:translateY(-3px)}
.sug-pic{display:block;width:100%;aspect-ratio:4/3;background-size:cover;background-position:center}
.sug-body{display:flex;flex-direction:column;gap:8px;flex:1;padding:10px 11px 11px}
.sug-name{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-size:12px;color:var(--cream);line-height:1.2}
.sug-price{margin-top:auto;font-family:'Oswald';font-weight:700;font-size:12.5px;color:var(--gold)}

/* swap-in-place: content drawers DOWN then UP while the backdrop stays dark
   (backdrop only fades on .closing, never during a swap) */
.modal-root.show.swapping .modal{transform:translateY(100%)}
/* 'pre' = displayed but still in the CLOSED state, so the FIRST open animates
   (the slide has a start frame to transition from instead of popping) */
.modal-root.show.pre .modal{transform:translateY(100%)}
.modal-root.show.pre .modal-backdrop{opacity:0}

/* desktop: large centered box, two columns, close X, no handle.
   Keeps the same drawer motion (slide up to open, down to close). */
@media(min-width:768px){
  .modal-root{display:none;place-items:center}
  .modal-root.show{display:grid}
  .modal{position:relative;left:auto;right:auto;bottom:auto;width:70vw;max-width:1100px;
    border:1px solid var(--line);border-radius:16px;max-height:90vh;transform:translateY(110vh)}
  .modal-root.show .modal{transform:translateY(0)}
  .modal-root.closing .modal,
  .modal-root.show.pre .modal,
  .modal-root.show.swapping .modal{transform:translateY(110vh)} /* fully below viewport - nothing peeks at the bottom */
  .modal .handle{display:none}
  .modal .close{display:flex}
  .modal-inner{padding:30px 32px 30px}
  .m-grid{grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);gap:34px;align-items:stretch}
  .m-left{align-self:center}            /* image column vertically centered vs taller right column */
  /* right column fills the row height; meta·name·tags·notes stay at top, the
     buy controls + nutrition pin to the bottom via the auto spacer below */
  .m-right{display:flex;flex-direction:column}
  .m-right .m-amount{margin-top:auto}   /* first element after the description -> pushes it + all below to the bottom */
  .m-pic{height:auto;aspect-ratio:1/1}
  .m-pic .m-pic-lbl{font-size:72px}
}
@media(max-width:520px){
  .m-buy{grid-template-columns:1fr;gap:16px}
  .m-nutri-grid{grid-template-columns:repeat(3,1fr);gap:10px}
}

/* =====================================================
   CART DRAWER
   ===================================================== */
.cart-root{position:fixed;inset:0;z-index:110;display:none}
.cart-root.show{display:block}
.cart-backdrop{position:absolute;inset:0;background:rgba(8,6,5,.55);opacity:0;transition:opacity .3s var(--ease)}
.cart-root.show .cart-backdrop{opacity:1}
.cart-root.closing .cart-backdrop{opacity:0}
.cart-drawer{position:absolute;top:0;right:0;height:100%;width:min(420px,100%);background:var(--char2);
  border-left:1px solid var(--line);display:flex;flex-direction:column;transform:translateX(100%);
  transition:transform .34s var(--ease)}
.cart-root.show .cart-drawer{transform:translateX(0)}
.cart-root.closing .cart-drawer{transform:translateX(100%)}
/* 'pre' = displayed but still closed, so the first open slides instead of popping */
.cart-root.show.pre .cart-drawer{transform:translateX(100%)}
.cart-root.show.pre .cart-backdrop{opacity:0}
.cart-head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--line)}
.cart-head h3{font-size:24px}
.cart-head .x{width:36px;height:36px;border-radius:50%;border:1px solid var(--line);background:transparent;color:var(--cream);font-size:18px;cursor:pointer}
.cart-items{flex:1;overflow-y:auto;padding:10px 22px;-ms-overflow-style:none;scrollbar-width:none}
.cart-items::-webkit-scrollbar{display:none}
.cart-empty{text-align:center;color:var(--muted);padding:60px 10px;font-family:'Oswald';letter-spacing:1px;text-transform:uppercase}
.litem{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid rgba(224,165,59,.1)}
.litem .lp{width:60px;height:60px;flex:0 0 60px;border-radius:8px;background-size:cover;background-position:center}
.litem .li{flex:1;min-width:0}
.litem .li h4{font-family:'Oswald';font-weight:600;font-size:15px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}
.litem .li .meta{font-size:12.5px;color:var(--muted);margin-bottom:8px}
.litem .li .meta .subtag{color:var(--gold)}
.litem .lc{display:flex;align-items:center;justify-content:space-between;gap:10px}
.miniqty{display:flex;align-items:center;border:1px solid var(--line);border-radius:6px}
.miniqty button{width:30px;height:30px;background:transparent;border:none;color:var(--cream);font-size:16px;cursor:pointer}
.miniqty button:hover{background:rgba(224,165,59,.12)}
.miniqty .q{min-width:28px;text-align:center;font-family:'Oswald';font-weight:600;font-size:14px}
.litem .ltot{font-family:'Oswald';font-weight:700;color:var(--gold);font-size:15px}
.litem .rm{background:none;border:none;color:var(--muted);font-size:12px;cursor:pointer;text-transform:uppercase;letter-spacing:.5px;font-family:'Oswald'}
.litem .rm:hover{color:var(--red-br)}
.cart-foot{border-top:1px solid var(--line);padding:20px 22px;background:var(--char3)}
.cart-foot .subtotal{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px;
  font-family:'Oswald';text-transform:uppercase;letter-spacing:1px}
.cart-foot .subtotal b{font-size:22px;color:var(--gold)}
.cart-foot .gst{font-size:12px;color:var(--muted);margin-bottom:16px}
.cart-foot .btn{width:100%}
.cart-foot .ship-note{font-size:12px;color:var(--muted);text-align:center;margin-top:12px;line-height:1.5}

/* =====================================================
   FOOTER (static markup, identical on every page)
   ===================================================== */
.site-footer{background:#0d0a09;padding:46px 0 30px;border-top:1px solid rgba(224,165,59,.2);flex-shrink:0}
.foot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:28px;color:var(--muted);font-size:14px}
.foot .col{min-width:150px}
.foot .about{max-width:260px}
.foot h4{font-family:'Oswald';text-transform:uppercase;letter-spacing:1.5px;color:var(--cream);margin-bottom:12px;font-size:15px}
.foot a{display:block;margin-bottom:7px}
.foot a:hover{color:var(--gold)}
.foot .about .logo{margin-bottom:12px}
.foot .about p{line-height:1.6}
.copy{text-align:center;color:#5d534a;font-size:12.5px;margin-top:34px;font-family:'Oswald';letter-spacing:1px;text-transform:uppercase}

/* concept note banner */
.note{background:var(--gold);color:var(--char);text-align:center;font-family:'Oswald';font-weight:600;
  font-size:13px;letter-spacing:.5px;padding:9px 16px}

/* utility */
.center{text-align:center}
.mt8{margin-top:8px}.mt16{margin-top:16px}.mt24{margin-top:24px}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);z-index:200;
  background:var(--gold);color:var(--char);font-family:'Oswald';font-weight:600;letter-spacing:.5px;
  padding:12px 22px;border-radius:6px;opacity:0;pointer-events:none;transition:.28s var(--ease);box-shadow:0 8px 24px rgba(0,0,0,.4)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media(max-width:540px){
  section.block{padding:54px 0}
  .teaser .inner{padding:32px 26px}
  .hero-cta .btn{flex:1}
}

/* =====================================================
   HEADER v2 · centered logo, search left, About/Account/Cart right
   ===================================================== */
.nav-right{display:flex;align-items:center;gap:16px;justify-self:end}
.icon-btn{display:inline-grid;place-items:center;width:40px;height:40px;border-radius:50%;
  border:1px solid var(--gold);background:transparent;color:var(--cream);cursor:pointer;transition:.18s var(--ease)}
.icon-btn:hover{background:var(--gold);color:var(--char)}
.about-link,.acct-link{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:1px;
  font-size:14px;color:var(--cream);position:relative;padding:4px 0;transition:color .18s var(--ease)}
.about-link:hover,.acct-link:hover,.about-link.active,.acct-link.active{color:var(--gold)}
.acct-link.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--gold)}
.cart-link{display:inline-flex;align-items:center;gap:5px;font-family:'Oswald';font-weight:600;font-size:14px;
  text-transform:uppercase;letter-spacing:1px;border:1px solid var(--gold);padding:8px 14px;border-radius:3px;
  background:transparent;color:var(--cream);cursor:pointer;transition:.18s var(--ease);white-space:nowrap}
.cart-link:hover{background:var(--gold);color:var(--char)}
/* DESKTOP DEFAULT: header icons hidden, text labels shown (desktop header unchanged).
   The mobile breakpoint below swaps to icon buttons. */
.hd-ico{display:none}
.cart-badge{display:none}
.cart-desktop{display:inline-flex;align-items:center;gap:5px}  /* preserves the original desktop "Cart (n)" spacing */

/* category nav row (under the main bar) */
.cat-nav{border-top:1px solid rgba(224,165,59,.14)}
.cat-nav-row{position:relative;display:flex;gap:26px;justify-content:center;align-items:center;height:46px;overflow-x:auto;
  -ms-overflow-style:none;scrollbar-width:none}
.cat-nav-row::-webkit-scrollbar{display:none;height:0}
.cat-nav-row a{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:1px;font-size:13px;
  color:var(--muted);white-space:nowrap;position:relative;padding:6px 0;transition:color .22s var(--ease)}
.cat-nav-row a:hover{color:var(--cream)}
.cat-nav-row a.active{color:var(--red)}
/* sliding indicator that glides between items */
.cat-indicator{position:absolute;bottom:2px;left:0;width:0;height:3px;border-radius:3px;background:var(--red);
  opacity:0;pointer-events:none;transition:left .35s var(--ease),width .35s var(--ease),opacity .25s var(--ease)}
.cat-indicator.show{opacity:1}
@media (prefers-reduced-motion: reduce){ .cat-indicator{transition:opacity .2s linear} }

/* logged-in account name accent */
.acct-link.acct-in{color:var(--gold);font-weight:700}
.acct-link.acct-in:hover{color:var(--gold);opacity:.85}

@media(max-width:880px){
  .nav-right .about-link{display:none}
  /* MOBILE HEADER: clean borderless icons, consistent size + spacing.
     LEFT group = hamburger then search; CENTER = logo; RIGHT group = account then cart. */
  .nav-left{gap:6px}
  .nav-right{gap:6px}
  .hd-ico{display:block}
  .acct-label,.cart-desktop{display:none}
  /* strip box / circle / border / background from every header control */
  .nav-left .icon-btn,.nav-left .hamburger,.nav-right .acct-link,.nav-right .cart-link{
    width:44px;height:44px;min-width:44px;padding:0;border:none;border-radius:0;background:transparent;
    color:var(--cream);display:inline-grid;place-items:center}
  .nav-left .icon-btn svg,.nav-right .hd-ico{width:21px;height:21px}
  /* hamburger glyph: square-ish ~20x18 stack matching the other ~18px icons.
     Restore a centred flex column (the borderless rule above sets display:inline-grid,
     which stretched the stack and broke the X). gap 6 + bar 2 => bar-to-centre = 8px. */
  .nav-left .hamburger{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}
  .nav-left .hamburger span{display:block;width:20px;height:2px;transform-origin:center}
  .nav-left .hamburger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .nav-left .hamburger.open span:nth-child(2){opacity:0}
  .nav-left .hamburger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  /* subtle tap/active feedback only - no fill */
  .nav-left .icon-btn:active,.nav-left .hamburger:active,.nav-right .acct-link:active,.nav-right .cart-link:active{opacity:.5}
  .nav-right .acct-link::after{display:none}              /* drop the desktop underline on the icon */
  .cart-link{position:relative}
  .cart-badge{position:absolute;top:1px;right:1px;min-width:17px;height:17px;padding:0 4px;border-radius:9px;
    background:var(--red);color:#fff;font-family:'Oswald';font-weight:700;font-size:10.5px;line-height:1;
    place-items:center;border:2px solid var(--char)}
  .cart-badge.show{display:grid}
  /* category nav: centred when items fit, horizontally scrollable (no left-clip) when they overflow */
  .cat-nav-row{justify-content:flex-start;gap:20px;padding:0 18px}
  .cat-nav-row a:first-of-type{margin-left:auto}
  .cat-nav-row a:last-of-type{margin-right:auto}
}

/* smooth anchor scroll to category sections, offset for sticky header */
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} }
.cat-section{scroll-margin-top:calc(var(--hd) + 60px)}

/* =====================================================
   SEARCH OVERLAY (header affordance)
   ===================================================== */
.search-overlay{position:fixed;inset:0;z-index:130;display:none}
.search-overlay.show{display:block}
.search-overlay-backdrop{position:absolute;inset:0;background:rgba(8,6,5,.72);opacity:0;transition:opacity .25s var(--ease)}
.search-overlay.show .search-overlay-backdrop{opacity:1}
.search-overlay.closing .search-overlay-backdrop{opacity:0}
.search-overlay-bar{position:absolute;top:0;left:0;right:0;background:rgba(21,17,15,.98);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--gold);
  padding:22px;transform:translateY(-16px);opacity:0;transition:.28s var(--ease)}
.search-overlay.show .search-overlay-bar{transform:translateY(0);opacity:1}
.search-overlay.closing .search-overlay-bar{transform:translateY(-16px);opacity:0}
/* 'pre' = displayed but still closed, so the first open animates instead of popping */
.search-overlay.show.pre .search-overlay-bar{transform:translateY(-16px);opacity:0}
.search-overlay.show.pre .search-overlay-backdrop{opacity:0}
.so-form{max-width:760px;margin:0 auto;display:flex;align-items:center;gap:12px;
  border:1px solid var(--line);border-radius:8px;padding:8px 8px 8px 16px;background:var(--char2)}
.so-ico{display:inline-grid;place-items:center;color:var(--gold)}
.so-input{flex:1;background:transparent;border:none;outline:none;color:var(--cream);font-family:'Inter';font-size:17px;padding:10px 0}
.so-go{font-family:'Oswald';font-weight:700;text-transform:uppercase;letter-spacing:1px;font-size:13px;
  background:var(--red);color:#fff;border:none;border-radius:5px;padding:11px 18px;cursor:pointer}
.so-go:hover{background:var(--red-br)}
.so-close{background:transparent;border:none;color:var(--muted);font-size:18px;cursor:pointer;padding:0 8px}
.so-close:hover{color:var(--cream)}
.so-hint{max-width:760px;margin:12px auto 0;color:var(--muted);font-family:'Oswald';letter-spacing:.5px;font-size:13px}

/* =====================================================
   SEARCH PAGE (filter rail + results + guides)
   ===================================================== */
.search-head{margin-bottom:24px}
.search-bar{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:10px;
  padding:8px 8px 8px 16px;background:var(--char2);max-width:680px}
.search-bar .so-ico{color:var(--gold)}
.search-bar input{flex:1;background:transparent;border:none;outline:none;color:var(--cream);font-family:'Inter';font-size:16px;padding:11px 0}
.search-layout{display:grid;grid-template-columns:248px 1fr;gap:30px;align-items:start}
.filter-rail{position:sticky;top:calc(var(--hd) + 58px);align-self:start;
  background:var(--char2);border:1px solid var(--line);border-radius:12px;padding:22px}
.filter-rail .fr-group{margin-bottom:20px}
.filter-rail .fr-group:last-child{margin-bottom:0}
.filter-rail .fr-label{font-family:'Oswald';font-weight:700;text-transform:uppercase;letter-spacing:1px;
  font-size:12px;color:var(--gold);margin-bottom:10px}
.filter-rail .fr-chips{display:flex;flex-wrap:wrap;gap:8px}
.results-head{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:20px}
.results-head .count{color:var(--muted);font-family:'Oswald';letter-spacing:1px;text-transform:uppercase;font-size:13px}
.sort-wrap{display:flex;align-items:center;gap:8px}
.sort-wrap label{font-family:'Oswald';text-transform:uppercase;letter-spacing:1px;font-size:12px;color:var(--muted)}
.sort-wrap select{font-family:'Oswald';font-weight:600;font-size:13px;background:var(--char2);color:var(--cream);
  border:1px solid var(--line);border-radius:6px;padding:8px 10px;cursor:pointer}
.guides-section{margin-top:46px}
.guides-section .sec-head{margin-bottom:18px}
.guides-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}
.guide-card{background:linear-gradient(150deg,#241d18,#191310);border:1px solid var(--line);
  border-radius:10px;padding:22px;cursor:pointer;display:flex;flex-direction:column;gap:10px;
  transition:transform .22s var(--ease),border-color .22s var(--ease),box-shadow .22s var(--ease)}
.guide-card:hover{transform:translateY(-5px);box-shadow:0 14px 30px rgba(0,0,0,.35);border-color:var(--red-br)}
.guide-card .g-kind{font-family:'Oswald';font-weight:700;text-transform:uppercase;letter-spacing:1.5px;font-size:11px;color:var(--gold)}
.guide-card h3{font-size:20px;line-height:1.05;display:flex;align-items:center;gap:8px}
.guide-card h3 .g-star{flex:0 0 auto;color:var(--red);width:20px;height:20px;display:inline-grid;place-items:center}
.guide-card h3 .g-star svg{width:18px;height:18px}
.guide-card p{color:var(--muted);font-size:13.5px;line-height:1.5;flex:1}
.guide-card .g-foot{display:flex;justify-content:space-between;align-items:center;font-family:'Oswald';
  text-transform:uppercase;letter-spacing:1px;font-size:11px;color:var(--muted)}
.guide-card .g-read{color:var(--gold)}
@media(max-width:780px){
  .search-layout{grid-template-columns:1fr}
  .filter-rail{position:static;display:flex;flex-wrap:wrap;gap:18px 26px}
  .filter-rail .fr-group{margin-bottom:0}
}

/* =====================================================
   ACCOUNT PAGE
   ===================================================== */
.account-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media(max-width:780px){.account-grid{grid-template-columns:1fr}}
.points-card{grid-column:1/-1;background:linear-gradient(150deg,#3a2208,#1a1411);border:1px solid var(--gold);
  border-radius:14px;padding:32px;position:relative;overflow:hidden}
.points-card::after{content:"";position:absolute;inset:0;background:radial-gradient(70% 90% at 90% 0%,rgba(224,165,59,.18),transparent 60%);pointer-events:none}
.points-card .pc-top{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap;position:relative;z-index:2}
.points-card .pc-pts{font-family:'Anton';font-size:clamp(40px,7vw,64px);color:var(--gold);line-height:.9}
.points-card .pc-pts small{display:block;font-family:'Oswald';font-size:13px;letter-spacing:2px;color:var(--cream2);margin-top:8px}
.points-card .pc-tier{text-align:right}
.points-card .pc-tier .badge-tier{font-family:'Oswald';font-weight:700;text-transform:uppercase;letter-spacing:1px;
  font-size:13px;background:rgba(224,165,59,.18);color:var(--gold);padding:6px 14px;border-radius:20px}
.tier-bar{position:relative;z-index:2;margin-top:24px;height:10px;border-radius:10px;background:rgba(0,0,0,.35);overflow:hidden}
.tier-bar > span{display:block;height:100%;background:linear-gradient(90deg,var(--red-br),var(--gold));border-radius:10px;transition:width .5s var(--ease)}
.tier-next{position:relative;z-index:2;margin-top:10px;font-family:'Oswald';letter-spacing:.5px;text-transform:uppercase;font-size:12.5px;color:var(--cream2)}
.acct-panel{background:var(--char2);border:1px solid var(--line);border-radius:12px;padding:26px}
.acct-panel h3{font-size:21px;margin-bottom:14px}
.acct-panel .muted{color:var(--muted);line-height:1.6;font-size:14.5px}
.acct-order{display:flex;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--line);font-size:14px}
.acct-order:last-child{border-bottom:none}
.acct-order .o-meta{color:var(--muted);font-size:12.5px}
.acct-order .o-status{font-family:'Oswald';text-transform:uppercase;letter-spacing:1px;font-size:11px;color:var(--gold)}
.acct-cta{margin-top:16px}

/* =====================================================
   TRUST MARQUEE (auto-scrolling band, replaces trust strip)
   ===================================================== */
.marquee{position:relative;background:var(--red);color:#fff;overflow:hidden}
.marquee::before,.marquee::after{content:"";position:absolute;top:0;bottom:0;width:60px;z-index:2;pointer-events:none}
.marquee::before{left:0;background:linear-gradient(90deg,var(--red),transparent)}
.marquee::after{right:0;background:linear-gradient(270deg,var(--red),transparent)}
.marquee-track{display:flex;width:max-content;animation:mq-scroll 60s linear infinite;will-change:transform}
.marquee:hover .marquee-track,.marquee:focus-within .marquee-track{animation-play-state:paused}
@keyframes mq-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
/* MOBILE/TOUCH: JS drives the scroll (drag + ramped resume), so disable the CSS auto-scroll.
   Desktop keeps the CSS animation above, untouched. */
.marquee.mq-touch{cursor:grab;touch-action:pan-y}
.marquee.mq-touch.dragging{cursor:grabbing}
.marquee.mq-touch .marquee-track{animation:none;will-change:scroll-position}
.marquee.mq-touch .mq-item{user-select:none;-webkit-user-select:none}
.mq-item{display:inline-flex;align-items:center;gap:9px;padding:15px 24px;font-family:'Oswald';font-weight:600;
  text-transform:uppercase;letter-spacing:1.2px;font-size:13.5px;color:#fff;white-space:nowrap;
  border-right:1px solid rgba(255,255,255,.16);transition:color .18s var(--ease)}
.mq-item svg{width:18px;height:18px;flex:0 0 18px;display:block}
.mq-item:hover{color:var(--char)}
.mq-item.mq-prod{color:var(--gold)}
.mq-item.mq-prod:hover{color:#fff}
@media (prefers-reduced-motion: reduce){
  .marquee::before,.marquee::after{display:none}
  .marquee-track{animation:none;flex-wrap:wrap;width:100%;justify-content:center}
  .mq-item[aria-hidden]{display:none}
}

/* =====================================================
   SMOKEHOUSE (guides hub) - heading, detail view
   ===================================================== */
.sec-head .sh-left{display:flex;flex-direction:column;gap:4px}
.sec-head .sh-sub{color:var(--muted);font-family:'Oswald';letter-spacing:1px;text-transform:uppercase;font-size:13px}
.guide-detail{max-width:760px;margin:0 auto}
.guide-detail .g-back{display:inline-block;margin-bottom:18px;font-family:'Oswald';font-weight:600;text-transform:uppercase;
  letter-spacing:1px;font-size:12px;color:var(--gold)}
.guide-detail .g-back:hover{text-decoration:underline}
.guide-detail .g-kind{font-family:'Oswald';font-weight:700;text-transform:uppercase;letter-spacing:1.5px;font-size:12px;color:var(--gold);margin-bottom:10px}
.guide-detail h1{font-size:clamp(32px,6vw,56px);margin-bottom:16px}
.guide-detail .lead{font-size:19px;color:var(--cream);line-height:1.6;margin-bottom:18px}
.guide-detail p{color:var(--cream2);line-height:1.75;margin-bottom:16px;font-size:16px}

/* =====================================================
   HOME CATEGORY SECTIONS - sticky title bar + expandable grid
   Each section is its own sticky containing block, so the bar
   releases at the section's end (no stuck title without content).
   Sticky offset = header height + category-nav row height.
   ===================================================== */
:root{ --catbar-top: calc(var(--hd) + 47px); }
.cat-section{position:relative;padding:0 0 44px;scroll-margin-top:var(--catbar-top)}
.cat-section.alt{background:var(--char2)}
.cat-inner{position:relative}

.cat-bar{display:flex;align-items:baseline;flex-wrap:nowrap;gap:16px;padding:20px 0;cursor:pointer;
  background:var(--char);border-bottom:1px solid var(--line)}
.cat-section.alt .cat-bar{background:var(--char2)}
.cat-bar:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
.cat-star{flex:0 0 auto;align-self:center;color:var(--red);width:26px;height:26px;display:inline-grid;place-items:center}
.cat-star svg{width:24px;height:24px}
.cat-title{flex:0 0 auto;font-family:'Anton';text-transform:uppercase;letter-spacing:.5px;font-size:clamp(24px,3vw,34px);line-height:1;margin:0;white-space:nowrap}
/* scoped to the bar so it fully overrides the search page's .cat-meta (flex-wrap/border/padding leak).
   BASELINE: align-items:baseline uses an item's FIRST baseline. Previously the meta was a 2-line
   block (tag over desc), so its first baseline was the GOLD TAG line - the title hung off the tag
   and the description never met the title's baseline. Fix: take the tag OUT of flow (absolute) and
   float it ABOVE the description, leaving the description as the meta's ONLY in-flow line - so the
   meta's baseline IS the description's, and it lines up with the title's baseline. */
.cat-bar .cat-meta{position:relative;display:block;flex:0 1 auto;min-width:0;margin-left:4px;text-align:left;
  border-top:0;padding-top:0;padding-bottom:0}
.cat-bar .cat-meta .cat-tag{position:absolute;left:0;bottom:100%;margin-bottom:3px;
  font-family:'Oswald';font-weight:700;text-transform:uppercase;letter-spacing:1.2px;font-size:11px;color:var(--gold);line-height:1.1;white-space:nowrap}
.cat-bar .cat-meta .cat-desc{display:block;color:var(--muted);font-size:13px;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:min(460px,38vw)}
.cat-toggle{margin-left:auto;flex:0 0 auto;align-self:center;display:inline-flex;align-items:center;gap:8px;
  font-family:'Oswald';font-weight:700;text-transform:uppercase;letter-spacing:1px;font-size:13px;
  background:transparent;border:1px solid var(--gold);color:var(--cream);padding:9px 16px;border-radius:3px;
  cursor:pointer;transition:background .18s var(--ease),color .18s var(--ease)}
.cat-toggle:hover{background:var(--gold);color:var(--char)}
.ct-chev{width:16px;height:16px;transition:transform .3s var(--ease)}
.cat-section.open .ct-chev{transform:rotate(180deg)}

.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding-top:24px}

/* desktop: sticky bar + collapsible grid */
@media (min-width:768px){
  .cat-bar{position:sticky;top:var(--catbar-top);z-index:20}
  .cat-grid{overflow:hidden;transition:max-height .36s var(--ease);will-change:max-height}
  .cat-section.no-expand .cat-grid{overflow:visible}
  /* COLLAPSED IS THE CSS DEFAULT: items beyond the first 4 are hidden from
     first paint (no JS), so nothing ever peeks on reload at any scroll pos.
     JS only handles expanding (adds .open to reveal the rest). */
  .cat-section:not(.open):not(.no-expand) .cat-grid > .card:nth-child(n+5){display:none}
}
@media (min-width:768px) and (max-width:1023px){
  .cat-grid{grid-template-columns:repeat(2,1fr)}
}
@media (prefers-reduced-motion: reduce){
  .cat-grid{transition:none}
  .ct-chev{transition:none}
}

/* mobile: keep it simple and working - static bar, all cards shown */
@media (max-width:767px){
  .cat-bar{position:static;flex-wrap:wrap;gap:6px 12px}
  .cat-toggle{display:none !important}
  .cat-grid{grid-template-columns:1fr;max-height:none !important;overflow:visible !important}
  /* description stays a single truncated line on mobile too (base rule applies) */
  .cat-bar .cat-meta .cat-desc{max-width:min(360px,52vw)}

  /* SITE-WIDE mobile side gutter - nothing touches the screen edges.
     .wrap handles nested containers; section.block.wrap handles sections that ARE the wrap
     (their `padding:..px 0` shorthand otherwise zeroes the sides and out-specifies .wrap).
     Full-bleed bands (.marquee) have no .wrap class, so they stay edge-to-edge by design. */
  .wrap{padding-left:22px;padding-right:22px}
  section.block.wrap{padding-left:22px;padding-right:22px}
  .hero-inner,.page-hero{padding-left:22px;padding-right:22px}

  /* MOBILE PRODUCT CARDS: full-width horizontal list rows - image LEFT, content RIGHT.
     Scoped to the home category grid + search/results grid; desktop grid (image-top) is untouched. */
  .cat-grid .card,.grid-cards .card{flex-direction:row;align-items:stretch}
  .cat-grid .card .pic,.grid-cards .card .pic{flex:0 0 38%;max-width:150px;height:auto;min-height:124px;
    font-size:34px;border-radius:0}
  .cat-grid .card .body,.grid-cards .card .body{flex:1;padding:13px 15px 14px}
  .cat-grid .card .desc,.grid-cards .card .desc{min-height:0;-webkit-line-clamp:2;display:-webkit-box;
    -webkit-box-orient:vertical;overflow:hidden}
  .cat-grid .card:hover,.grid-cards .card:hover{transform:none}  /* no lift on touch list rows */

  /* image badges: both on the LEFT edge - tag pinned top-left, heat moved to bottom-left */
  .cat-grid .card .pic .heat,.grid-cards .card .pic .heat{top:auto;bottom:10px;left:10px;right:auto}
  .cat-grid .card .pic .tag,.grid-cards .card .pic .tag{top:10px;left:10px}
}
