/* ==========================================================================
   Brandt & Sons Butchery · Crazy Websites capability demo
   Palette: ink #131110 · cream #F3EBDD · blood red #9E1B1B · brass #C8A24B
   ========================================================================== */

:root{
  --ink:#131110;
  --ink-2:#0d0b0a;
  --cream:#F3EBDD;
  --cream-dim:#d9cfbc;
  --red:#9E1B1B;
  --brass:#C8A24B;
  --font-display:"Anton", Impact, sans-serif;
  --font-accent:"Fraunces", Georgia, serif;
  --font-body:"Inter", -apple-system, sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto}
html,body{overflow-x:clip}
body{
  background:var(--ink);
  color:var(--cream);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
picture{display:contents}
a{color:inherit;text-decoration:none}
em{font-family:var(--font-accent);font-style:italic;font-weight:900}

/* film grain */
body::after{
  content:"";position:fixed;inset:-10%;z-index:90;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix type='saturate' values='0'/></filter><rect width='160' height='160' filter='url(%23n)' opacity='0.5'/></svg>");
  opacity:.05;mix-blend-mode:overlay;
}

.wrap{width:min(1200px,92vw);margin-inline:auto;position:relative;z-index:1}

/* ---------- type scale ---------- */
.kicker{
  font-family:var(--font-body);font-weight:700;font-size:.75rem;
  letter-spacing:.34em;text-transform:uppercase;margin-bottom:1.1rem;
}
.kicker-red{color:var(--red)}
.kicker-brass{color:var(--brass)}
.h2{
  font-family:var(--font-display);font-weight:400;
  font-size:clamp(2.6rem,5.4vw,4.6rem);line-height:.98;
  letter-spacing:.01em;text-transform:uppercase;color:var(--cream);
  margin-bottom:1.6rem;
}
.h2 em{color:var(--brass);text-transform:none;letter-spacing:0;font-size:.92em}
.h2.ink{color:var(--ink)}
.h2.ink em{color:var(--red)}
.body,.body-lg{max-width:56ch;color:var(--cream);opacity:.86}
.body-lg{font-size:1.13rem;margin-bottom:1rem}
.body{font-size:.98rem}
.section-cream .body,.section-cream .body-lg{color:var(--ink);opacity:.82}

/* ==========================================================================
   HEADER
   ========================================================================== */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:80;
  display:flex;align-items:center;gap:2.2rem;
  padding:1rem clamp(1.2rem,4vw,3rem);
  transition:background .4s,box-shadow .4s,padding .4s;
}
.site-header.scrolled{
  background:rgba(13,11,10,.88);backdrop-filter:blur(12px);
  box-shadow:0 1px 0 rgba(200,162,75,.25);
  padding-block:.65rem;
}
.logotype{display:flex;align-items:center;gap:.6rem;margin-right:auto}
.logo-mark{width:30px;height:30px;color:var(--brass);flex:none}
.logo-text{
  font-family:var(--font-display);font-size:1.15rem;letter-spacing:.06em;
  color:var(--cream);display:flex;align-items:baseline;gap:.35rem;white-space:nowrap;
}
.logo-text .amp{color:var(--brass);font-size:1.05em}
.logo-sub{
  font-family:var(--font-body);font-weight:600;font-size:.55rem;
  letter-spacing:.3em;color:var(--cream);opacity:.55;margin-left:.5rem;
  align-self:center;
}
.site-nav{display:flex;gap:1.6rem}
.site-nav a{
  font-weight:600;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--cream);opacity:.85;position:relative;padding:.2rem 0;
}
.site-nav a::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:100%;
  background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .3s;
}
.site-nav a:hover::after{transform:scaleX(1)}
.header-phone{
  font-family:var(--font-accent);font-style:italic;font-weight:900;
  color:var(--brass);font-size:1rem;white-space:nowrap;
}

/* hamburger (mobile only) */
.nav-toggle{
  display:none;flex-direction:column;justify-content:center;gap:6px;
  width:42px;height:42px;padding:10px;flex:none;
  background:none;border:0;cursor:pointer;
}
.nav-toggle span{display:block;height:2px;width:100%;background:var(--cream);transition:transform .3s,opacity .3s}
body.menu-open .nav-toggle span:nth-child(1){transform:translateY(8px) rotate(45deg)}
body.menu-open .nav-toggle span:nth-child(2){opacity:0}
body.menu-open .nav-toggle span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* mobile menu overlay */
.mobile-menu{
  position:fixed;inset:0;z-index:79;
  background:rgba(13,11,10,.97);
  display:flex;flex-direction:column;justify-content:center;
  padding:0 10vw;
  opacity:0;pointer-events:none;transition:opacity .35s ease;
}
body.menu-open .mobile-menu{opacity:1;pointer-events:auto}
body.menu-open{overflow:hidden}
.mobile-menu nav{display:grid}
.mobile-menu nav a{
  font-family:var(--font-display);font-size:2.3rem;letter-spacing:.03em;
  text-transform:uppercase;color:var(--cream);
  padding:.55rem 0;border-bottom:1px solid rgba(200,162,75,.22);
  transform:translateX(0);transition:color .25s;
}
.mobile-menu nav a:hover{color:var(--brass)}
.mobile-menu nav a b{
  font-family:var(--font-body);font-weight:700;font-size:.72rem;
  letter-spacing:.28em;color:var(--brass);margin-right:1rem;vertical-align:.6em;
}
.mm-phone{
  margin-top:2.2rem;font-family:var(--font-accent);font-style:italic;font-weight:900;
  color:var(--brass);font-size:1.25rem;
}

/* ==========================================================================
   HERO · THE MASTER CUT
   ========================================================================== */
.hero{position:relative;height:100vh;height:100svh;overflow:hidden;background:var(--ink-2);z-index:1}

.hero-under{position:absolute;inset:0;z-index:1;background:var(--ink-2);display:grid;place-items:center;overflow:hidden}
/* the inside of the cut: marbling stays visible so a mid-slice rest state
   reads as flesh, not a flat void; softer gradients kill the banding */
.under-marble{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.34;filter:saturate(.9) contrast(1.04)}
.hero-under::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(60% 46% at 50% 46%,rgba(158,27,27,.22) 0%,transparent 70%),
    radial-gradient(130% 100% at 50% 50%,transparent 45%,rgba(13,11,10,.72) 100%);
}
.under-inner{position:relative;z-index:2;text-align:center;padding:0 6vw}
/* opaque veil: keeps the widening cut gap dark so nothing ghosts through */
.under-veil{position:absolute;inset:0;z-index:3;background:var(--ink-2)}
.under-line{
  font-family:var(--font-display);font-weight:400;text-transform:uppercase;
  font-size:clamp(2rem,5.6vw,4.4rem);line-height:1.04;color:var(--cream);
}
.under-line em{color:var(--brass);text-transform:none}
.under-sub{margin-top:1.2rem;font-family:var(--font-accent);font-style:italic;font-weight:900;color:var(--red);font-size:clamp(1rem,2vw,1.35rem)}

.hero-half{position:absolute;inset:0;z-index:2;will-change:transform}
/* default seam (JS re-measures through the headline/tagline gap) */
.half-a{clip-path:polygon(0 0,100% 0,100% 60.6%,0 63.4%);z-index:3}
.half-b{clip-path:polygon(0 63.25%,100% 60.45%,100% 100%,0 100%)}
.hero-slab{position:absolute;inset:0}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:contrast(1.07) saturate(1.06);transform:scale(1.05);will-change:transform}
.hero-shade{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 90% at 50% 42%,transparent 30%,rgba(13,11,10,.62) 100%),
    linear-gradient(180deg,rgba(13,11,10,.55) 0%,rgba(13,11,10,.08) 34%,rgba(13,11,10,.12) 62%,rgba(13,11,10,.66) 100%);
}
.hero-inner{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;padding:0 4vw;
}
.hero-kicker{
  font-weight:700;font-size:clamp(.62rem,1vw,.8rem);letter-spacing:.42em;
  color:var(--cream);opacity:.92;margin-bottom:1.4rem;
  text-shadow:0 2px 14px rgba(0,0,0,.6);
}
.hero-title{
  font-family:var(--font-display);font-weight:400;
  font-size:clamp(3.4rem,12.5vw,11.5rem);line-height:.92;letter-spacing:.015em;
  color:var(--cream);text-shadow:0 6px 40px rgba(0,0,0,.55);
}
.hero-title .amp{
  font-family:var(--font-accent);font-style:italic;font-weight:900;
  color:var(--brass);font-size:.72em;vertical-align:.06em;padding:0 .04em;
}
.hero-sub{
  margin-top:1.5rem;font-family:var(--font-accent);font-style:italic;font-weight:900;
  font-size:clamp(1rem,2.1vw,1.5rem);color:var(--cream);opacity:.95;
  text-shadow:0 2px 18px rgba(0,0,0,.65);
}

.seam-svg{position:absolute;inset:0;width:100%;height:100%;z-index:4;pointer-events:none}
.seam-line{
  stroke:var(--cream);stroke-width:2.5;fill:none;opacity:0;
  filter:drop-shadow(0 0 6px rgba(243,235,221,.9)) drop-shadow(0 0 18px rgba(158,27,27,.8));
}
.hero-knife{position:absolute;z-index:5;left:0;top:0;width:clamp(190px,21vw,300px);pointer-events:none;opacity:0;transform:translate(-60%,-55%);filter:drop-shadow(0 10px 18px rgba(0,0,0,.6))}
.knife-svg{position:relative;display:block;width:100%;height:auto}
.kn-blade{fill:url(#bladeSteel);stroke:rgba(19,17,16,.4);stroke-width:1}
.kn-bolster{fill:#C8A24B;stroke:#8a6f2f;stroke-width:.8}
.kn-handle{fill:#221b16;stroke:rgba(200,162,75,.9);stroke-width:1.2}
.kn-etch{
  font-family:var(--font-display);font-size:10px;letter-spacing:2.2px;
  fill:#131110;opacity:.34;
}
/* motion-blur glint trail behind the blade */
.knife-trail{
  position:absolute;top:52%;right:72%;width:min(30vw,420px);height:3px;
  transform:translateY(-50%);border-radius:2px;filter:blur(1.3px);
  background:linear-gradient(90deg,rgba(243,235,221,0) 0%,rgba(243,235,221,.08) 40%,rgba(200,162,75,.35) 78%,rgba(243,235,221,.7) 100%);
}

.scroll-hint{
  position:absolute;left:50%;bottom:3vh;transform:translateX(-50%);z-index:6;
  display:flex;flex-direction:column;align-items:center;gap:.7rem;
  font-weight:600;font-size:.68rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--cream);opacity:.85;text-align:center;white-space:nowrap;
}
.sh-rule{width:1px;height:44px;background:linear-gradient(var(--brass),transparent);animation:shDrop 1.8s ease-in-out infinite}
@keyframes shDrop{0%{transform:scaleY(.2);transform-origin:top}50%{transform:scaleY(1)}100%{transform:scaleY(.2);transform-origin:bottom}}

/* ==========================================================================
   TICKER
   ========================================================================== */
.ticker{
  position:relative;z-index:9;overflow:hidden;background:var(--red);
  padding:.85rem 0;border-top:1px solid rgba(243,235,221,.18);border-bottom:1px solid rgba(243,235,221,.18);
  transform:rotate(-1.6deg) scale(1.04);
  box-shadow:0 12px 32px rgba(0,0,0,.4);
}
.ticker-track{display:flex;gap:2.4rem;width:max-content;align-items:center;will-change:transform}
.ticker-track span{
  font-family:var(--font-display);font-size:1.05rem;letter-spacing:.14em;
  color:var(--cream);white-space:nowrap;
}
.ticker-track i{font-style:normal;color:var(--brass);font-size:1.2rem}

/* ==========================================================================
   SECTIONS COMMON + CLEAVER-CUT BOUNDARIES
   Every section top edge is an interlocking diagonal (alternating direction).
   Sections overlap the previous one by the seam drop and stack upwards in
   z-index, so each settled boundary reads as a butchered cut.
   ========================================================================== */
:root{--seam-drop:clamp(30px,4vw,60px)}
.section{position:relative;z-index:2;padding:clamp(4.5rem,9vw,8.5rem) 0}
.edge-lr{clip-path:polygon(0 0,100% var(--seam-drop),100% 100%,0 100%)}
.edge-rl{clip-path:polygon(0 var(--seam-drop),100% 0,100% 100%,0 100%)}
.edge-lr,.edge-rl{
  margin-top:calc(var(--seam-drop) * -1);
  padding-top:calc(clamp(4.5rem,9vw,8.5rem) + var(--seam-drop));
}
.craft{z-index:3}
.cuts{z-index:4}
.braai{z-index:5}
.prices{z-index:6}
.visit{z-index:7}
.section-ink{background:var(--ink)}
.section-ink::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:url("assets/img/marbling-960.webp") center/cover;
  opacity:.06;filter:saturate(.7) contrast(1.05);
}
.section-cream{background:var(--cream);color:var(--ink)}

/* the scrubbed cover: previous section's colour, sheared apart by scroll */
.cut-cover{position:absolute;top:-2px;left:-2px;right:-2px;height:102vh;z-index:40;pointer-events:none;overflow:hidden}
.cc-half{position:absolute;inset:0;will-change:transform}
/* lit rim along each slab's cut edge so resting mid-cut reads as two parted
   slabs even where the cover colour matches the section behind it */
.cc-edge{
  position:absolute;left:-6%;width:112%;height:2px;pointer-events:none;
  background:linear-gradient(90deg,rgba(200,162,75,0),rgba(200,162,75,.55) 10%,rgba(200,162,75,.55) 90%,rgba(200,162,75,0));
  transform-origin:left center;
}
.cc-line{
  position:absolute;left:-6%;top:34%;width:112%;height:2px;background:var(--cream);
  transform:scaleX(0);transform-origin:left center;
  box-shadow:0 0 6px rgba(243,235,221,.75),0 0 12px rgba(158,27,27,.5);
}
html:not(.js) .cut-cover{display:none}

/* ==========================================================================
   CRAFT
   ========================================================================== */
.craft-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.craft .stats{
  list-style:none;display:grid;grid-template-columns:repeat(4,1fr);
  gap:1.2rem;margin-top:2.6rem;padding-top:2rem;border-top:1px solid rgba(200,162,75,.35);
}
.craft .stats strong{
  display:block;font-family:var(--font-display);font-weight:400;
  font-size:clamp(2rem,3.4vw,3rem);color:var(--brass);line-height:1;
}
.craft .stats span{font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;opacity:.7;font-weight:600;display:block;margin-top:.4rem}
.craft-portrait{position:relative}
.craft-portrait img{
  aspect-ratio:4/5;object-fit:cover;width:100%;
  border:1px solid rgba(200,162,75,.5);outline:8px solid rgba(19,17,16,.9);outline-offset:-9px;
  filter:contrast(1.05) saturate(.92);
  box-shadow:0 30px 60px rgba(0,0,0,.5);
}
.craft-portrait figcaption,.craft-counter figcaption{
  margin-top:.9rem;font-size:.8rem;letter-spacing:.05em;opacity:.65;
}
.craft-portrait figcaption em,.craft-counter figcaption em{color:var(--brass)}
.craft-counter{margin-top:clamp(3rem,6vw,5rem)}
.craft-counter img{
  width:100%;aspect-ratio:21/8;object-fit:cover;
  border:1px solid rgba(200,162,75,.4);
  filter:contrast(1.06) saturate(.95);
  box-shadow:0 30px 60px rgba(0,0,0,.45);
}

/* ==========================================================================
   CUT CHART
   ========================================================================== */
.cuts-intro{margin-bottom:3rem}
.chart-grid{display:grid;grid-template-columns:1.5fr .9fr;gap:clamp(2rem,4vw,4rem);align-items:start}
.chart-stage{min-width:0}
.cow-svg{width:100%;height:auto;overflow:visible}
.cow-svg polygon,.cow-svg .cut path,.cow-svg .cow-meta path{
  fill:var(--ink);stroke:var(--cream);stroke-width:2.5;stroke-linejoin:round;
}
.cow-meta path{fill:#241f1c}
.cow-tail{fill:none;stroke:#241f1c;stroke-width:10;stroke-linecap:round}
.cut{cursor:pointer;transition:transform .35s cubic-bezier(.2,.9,.3,1.4),filter .35s;outline:none}
.cut polygon{transition:fill .3s}
.cut:hover,.cut.active,.cut:focus-visible{
  transform:translateY(-9px);
  filter:drop-shadow(0 16px 22px rgba(158,27,27,.4));
}
.cut:hover polygon,.cut.active polygon,.cut:focus-visible polygon,
.cut:hover path,.cut.active path,.cut:focus-visible path{fill:var(--red)}
.cut-fillet polygon{fill:#1f1a17;stroke:var(--brass);stroke-dasharray:7 5;stroke-width:2}
.badge circle{fill:var(--brass);stroke:none}
.badge text{
  font-family:var(--font-body);font-weight:700;font-size:15px;fill:var(--ink);
  text-anchor:middle;dominant-baseline:central;
}
.cut.active .badge circle,.cut:hover .badge circle{fill:var(--cream)}
.chart-legend{
  list-style:none;display:flex;flex-wrap:wrap;gap:.5rem .6rem;margin-top:1.6rem;
}
.chart-legend li{
  display:flex;align-items:center;gap:.45rem;cursor:pointer;
  font-weight:600;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink);border:1px solid rgba(19,17,16,.3);border-radius:999px;
  padding:.34rem .8rem .34rem .4rem;transition:all .25s;background:transparent;
}
.chart-legend li b{
  width:20px;height:20px;border-radius:50%;background:var(--ink);color:var(--cream);
  display:grid;place-items:center;font-size:.68rem;transition:all .25s;
}
.chart-legend li:hover,.chart-legend li.active{background:var(--red);border-color:var(--red);color:var(--cream)}
.chart-legend li:hover b,.chart-legend li.active b{background:var(--cream);color:var(--red)}

.cut-card{
  position:sticky;top:110px;
  background:var(--ink);color:var(--cream);padding:2.2rem 2rem 1.8rem;
  border:1px solid rgba(200,162,75,.45);
  box-shadow:14px 14px 0 rgba(158,27,27,.9);
}
.cc-kicker{font-size:.62rem;font-weight:700;letter-spacing:.34em;color:var(--brass);margin-bottom:.8rem}
.cc-name{font-family:var(--font-display);font-weight:400;font-size:clamp(2.2rem,3vw,3rem);line-height:1;text-transform:uppercase}
.cc-price{font-size:1.05rem;margin:.7rem 0 .9rem;opacity:.9}
.cc-price em{color:var(--brass);font-size:1.9rem;line-height:1}
.cc-use{
  display:inline-block;font-weight:700;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;
  background:var(--red);color:var(--cream);padding:.4rem .85rem;border-radius:999px;margin-bottom:1rem;
}
.cc-desc{font-size:.95rem;opacity:.88;min-height:3.2em}
.cc-note{margin-top:1.3rem;padding-top:1rem;border-top:1px dashed rgba(200,162,75,.4);font-family:var(--font-accent);font-style:italic;font-weight:900;font-size:.92rem;color:var(--brass)}

/* ==========================================================================
   BRAAI
   ========================================================================== */
.braai{overflow:hidden;background:var(--ink-2)}
.braai-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(1.15) contrast(1.05)}
.braai-shade{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(13,11,10,.92) 0%,rgba(13,11,10,.55) 30%,rgba(13,11,10,.45) 60%,rgba(13,11,10,.9) 100%),
    radial-gradient(90% 70% at 30% 65%,transparent 20%,rgba(13,11,10,.5) 100%);
}
.embers{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;mix-blend-mode:screen}
.braai-inner{position:relative;z-index:2}
.braai-title{
  font-family:var(--font-display);font-weight:400;text-transform:uppercase;
  font-size:clamp(3.2rem,9vw,8rem);line-height:.94;color:var(--cream);
  text-shadow:0 0 40px rgba(255,120,30,.35),0 8px 40px rgba(0,0,0,.7);
  margin-bottom:1.6rem;will-change:filter;
}
.braai-title.haze{filter:url(#heatFilter)}
/* copy is bound to its own dark panel so a mid-cut rest state (cream slab /
   seam gleam crossing the section) never leaves pale text on a pale ground */
.braai-copy{
  max-width:52ch;text-shadow:0 2px 14px rgba(0,0,0,.7);
  background:rgba(13,11,10,.72);border-left:3px solid var(--brass);
  padding:1.1rem 1.4rem;backdrop-filter:blur(2px);
}

.braai-box{
  margin-top:3rem;max-width:430px;
  background:rgba(19,17,16,.82);backdrop-filter:blur(8px);
  border:1px solid rgba(200,162,75,.55);
  padding:2rem 2rem 1.6rem;
  box-shadow:0 30px 80px rgba(0,0,0,.6);
}
.bb-head h3{font-family:var(--font-display);font-weight:400;font-size:1.7rem;text-transform:uppercase;letter-spacing:.02em}
.bb-price{font-family:var(--font-accent);font-style:italic;font-weight:900;color:var(--cream);opacity:.9;margin:.3rem 0 1.1rem}
.bb-price em{color:var(--brass);font-size:1.6rem}
.braai-box ul{list-style:none;margin-bottom:1.4rem}
.braai-box li{
  padding:.5rem 0 .5rem 1.4rem;position:relative;font-size:.95rem;
  border-bottom:1px dashed rgba(243,235,221,.15);
}
.braai-box li::before{content:"";position:absolute;left:0;top:1.05em;width:7px;height:7px;background:var(--red);transform:rotate(45deg)}
.bb-cta{
  display:block;text-align:center;background:var(--red);color:var(--cream);
  font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-size:.85rem;
  padding:.95rem 1rem;transition:background .3s,transform .15s;
}
.bb-cta:hover{background:#b62222;transform:translateY(1px)}
.bb-note{margin-top:.9rem;font-size:.78rem;opacity:.6;text-align:center}

/* ==========================================================================
   PRICES / MENU
   ========================================================================== */
.prices-note{margin-bottom:2.6rem}
.menu-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-bottom:3.2rem}
.menu-strip figure{position:relative}
.menu-strip img{
  width:100%;aspect-ratio:4/3;object-fit:cover;
  filter:contrast(1.05) saturate(.98);
  border:1px solid rgba(19,17,16,.25);
  box-shadow:0 18px 40px rgba(19,17,16,.22);
}
.menu-strip figcaption{
  position:absolute;left:.8rem;bottom:.8rem;
  background:var(--ink);color:var(--cream);
  font-family:var(--font-accent);font-style:italic;font-weight:900;font-size:.85rem;
  padding:.3rem .8rem;
}
.menu-grid{display:grid;grid-template-columns:1.35fr .85fr;gap:clamp(2rem,4vw,4rem);align-items:start}
.menu-list{list-style:none}
.menu-row{
  display:flex;align-items:baseline;gap:1rem;
  padding:1.05rem 0;border-bottom:1px solid rgba(19,17,16,.16);
  color:var(--ink);
}
.menu-row:first-child{border-top:2px solid var(--ink)}
.mr-name{font-family:var(--font-display);font-weight:400;font-size:1.25rem;letter-spacing:.02em;text-transform:uppercase;white-space:nowrap}
.mr-name em{
  font-family:var(--font-accent);font-style:italic;font-weight:900;font-size:.8rem;
  color:var(--red);text-transform:none;letter-spacing:0;margin-left:.55rem;
}
.mr-dots{flex:1;border-bottom:2px dotted rgba(19,17,16,.35);transform:translateY(-4px)}
.mr-price{font-family:var(--font-display);font-size:1.3rem;color:var(--red);white-space:nowrap}
.mr-price small{font-family:var(--font-body);font-weight:600;font-size:.7rem;color:rgba(19,17,16,.55);margin-left:.15rem}

.cut-week{
  position:sticky;top:110px;background:var(--ink);color:var(--cream);
  border:1px solid rgba(200,162,75,.5);box-shadow:14px 14px 0 var(--brass);
}
.cut-week img{width:100%;aspect-ratio:4/3.4;object-fit:cover;filter:contrast(1.06)}
.cw-body{padding:1.6rem 1.6rem 1.5rem}
.cut-week h3{font-family:var(--font-display);font-weight:400;font-size:2rem;text-transform:uppercase;line-height:1}
.cw-price{font-family:var(--font-accent);font-style:italic;font-weight:900;margin:.4rem 0 .8rem;opacity:.9}
.cw-price em{color:var(--brass);font-size:1.7rem}
.cw-body p:last-child{font-size:.9rem;opacity:.85}

/* ==========================================================================
   VISIT
   ========================================================================== */
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.visit-addr{font-style:normal;margin:1.8rem 0;display:grid;gap:1rem}
.visit-addr strong{font-family:var(--font-display);font-weight:400;font-size:1.35rem;letter-spacing:.03em;text-transform:uppercase}
.visit-addr a{color:var(--brass);border-bottom:1px solid rgba(200,162,75,.4)}
.hours{border-collapse:collapse;width:100%;max-width:380px}
.hours th,.hours td{
  text-align:left;padding:.6rem 0;border-bottom:1px dashed rgba(200,162,75,.3);
  font-size:.92rem;
}
.hours th{font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-size:.74rem;opacity:.8}
.hours td{font-family:var(--font-accent);font-style:italic;font-weight:900;color:var(--brass);text-align:right}
.visit-map svg{width:100%;height:auto;display:block;filter:drop-shadow(0 24px 50px rgba(0,0,0,.5))}
.map-bg{fill:var(--cream)}
.map-roads path{stroke:rgba(19,17,16,.75);stroke-width:8;fill:none;stroke-linecap:round}
.map-labels text{font-family:var(--font-body);font-weight:600;font-size:12.5px;letter-spacing:.08em;fill:rgba(19,17,16,.62);text-transform:uppercase}
.map-you{font-family:var(--font-display);font-size:17px;fill:var(--red);letter-spacing:.06em}
.pin-pulse{fill:none;stroke:var(--red);stroke-width:2;opacity:.7;transform-box:fill-box;transform-origin:center;animation:pinPulse 2.2s ease-out infinite}
@keyframes pinPulse{0%{transform:scale(.4);opacity:.8}80%{transform:scale(2.1);opacity:0}100%{opacity:0}}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{position:relative;z-index:8;background:var(--ink-2);border-top:1px solid rgba(200,162,75,.3);padding:4rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:1.2fr .6fr 1fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(243,235,221,.1)}
.logo-text.big{font-size:2rem}
.footer-tag{color:var(--brass);margin-top:.4rem}
.footer-nav{display:grid;gap:.55rem;align-content:start}
.footer-nav a{font-size:.85rem;opacity:.75;transition:opacity .2s,color .2s}
.footer-nav a:hover{opacity:1;color:var(--brass)}
.footer-contact{font-size:.85rem;opacity:.75;display:grid;gap:.5rem;align-content:start}
.footer-contact a{color:var(--brass)}
.footer-base{display:flex;justify-content:space-between;gap:1.5rem;padding-top:1.6rem;font-size:.75rem;opacity:.55;flex-wrap:wrap}
.demo-badge strong{color:var(--brass)}

/* ==========================================================================
   STICKY CTA
   .sticky-cta = fixed positioning + show/hide only.
   .cta-body   = the pill; GSAP owns its transform/shadow for the thunk.
   ========================================================================== */
.sticky-cta{
  position:fixed;right:1.6rem;bottom:1.6rem;z-index:70;display:block;
  opacity:0;transform:translateY(90px);pointer-events:none;
  transition:opacity .5s ease,transform .55s cubic-bezier(.2,.9,.25,1.2);
}
.sticky-cta.on{opacity:1;transform:translateY(0);pointer-events:auto}
.cta-body{
  display:flex;align-items:center;gap:.7rem;
  background:var(--red);color:var(--cream);
  font-weight:700;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;
  padding:.95rem 1.5rem .95rem 1.1rem;border-radius:999px;white-space:nowrap;
  box-shadow:0 14px 40px rgba(158,27,27,.45),0 3px 0 #6d1212;
}
.cta-cleaver{width:26px;height:26px;flex:none;transform-origin:88% 42%}

/* ==========================================================================
   REDUCED MOTION + NO-JS
   ========================================================================== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  .cut-cover,.hero-knife,.seam-svg,.embers,.under-veil{display:none !important}
  .braai-title.haze{filter:none}
  .sticky-cta{opacity:1;transform:none;pointer-events:auto}
}
html:not(.js) .sticky-cta{opacity:1;transform:none;pointer-events:auto}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width:1020px){
  .craft-grid,.chart-grid,.menu-grid,.visit-grid{grid-template-columns:1fr}
  .cut-card,.cut-week{position:static}
  .cut-card{margin-top:1.5rem}
  .craft-portrait{max-width:480px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  .site-nav{display:none}
  .nav-toggle{display:flex}
  .header-phone{font-size:.9rem;margin-left:auto}
  .site-header{gap:1rem}
  .logo-sub{display:none}
  .craft .stats{grid-template-columns:repeat(2,1fr);gap:1.6rem 1rem}
  .menu-strip{grid-template-columns:1fr 1fr}
  .menu-strip figure:last-child{grid-column:1/-1}
  .mr-name{font-size:1.02rem;white-space:normal}
  .mr-name em{display:block;margin-left:0}
  .mr-price{font-size:1.1rem}
  .footer-grid{grid-template-columns:1fr}
  .footer-base{flex-direction:column;gap:.5rem}
  /* compact single-line pill, bottom-right, safe-area aware */
  .sticky-cta{right:.85rem;bottom:calc(.85rem + env(safe-area-inset-bottom,0px))}
  .cta-body{font-size:.68rem;letter-spacing:.08em;padding:.7rem 1.05rem .7rem .85rem;gap:.5rem}
  .cta-cleaver{width:19px;height:19px}
  .braai-box{max-width:none}
  .hero-sub{max-width:30ch}
  .cut-card{box-shadow:8px 8px 0 rgba(158,27,27,.9)}
  .cut-week{box-shadow:8px 8px 0 var(--brass)}
}
