/* =========================================================================
   WILD WEST CATTLE RANCH — Cinematic Dark + Ember Design System
   Built by F4TE · builtbyf4te.com
   ========================================================================= */

/* ----------  TOKENS  ---------- */
:root{
  /* core palette */
  --black:#0b0a09;
  --ink:#121010;
  --ink-2:#1a1715;
  --char:#211d1a;
  --char-2:#2b2521;
  --line:#3a322c;
  --line-soft:#2a2421;

  --cream:#f5eedd;
  --bone:#e7ddc7;
  --sand:#c9bda2;
  --muted:#9c917e;
  --muted-2:#73695c;

  /* ember accents (pulled from the sunset hero) */
  --ember:#e8782b;
  --ember-2:#f0993f;
  --flame:#d8531c;
  --gold:#d4a052;
  --gold-2:#e9c277;
  --blood:#7c2d18;

  /* gradients */
  --sky: linear-gradient(180deg,#1a1b2e 0%,#3a2940 14%,#7a3d2e 34%,#c2562a 52%,#e8842f 66%,#f4ab46 78%,#e9923a 88%,#1c130d 100%);
  --ember-grad: linear-gradient(135deg,var(--flame),var(--ember-2));
  --gold-grad: linear-gradient(135deg,var(--gold),var(--gold-2));

  /* type */
  --serif:"Cormorant Garamond",Georgia,serif;
  --display:"Oswald","Bebas Neue",Impact,sans-serif;
  --body:"Inter",system-ui,-apple-system,sans-serif;

  --maxw:1240px;
  --gut:clamp(20px,5vw,64px);
  --radius:4px;
  --shadow:0 24px 60px -20px rgba(0,0,0,.7);
  --ease:cubic-bezier(.16,1,.3,1);
}

/* ----------  RESET  ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  background:var(--black);
  color:var(--bone);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
::selection{background:var(--ember);color:#120b06}

/* scrollbar */
::-webkit-scrollbar{width:11px}
::-webkit-scrollbar-track{background:var(--ink)}
::-webkit-scrollbar-thumb{background:var(--char-2);border-radius:20px;border:3px solid var(--ink)}
::-webkit-scrollbar-thumb:hover{background:var(--blood)}

/* ----------  TYPOGRAPHY  ---------- */
.eyebrow{
  font-family:var(--display);
  text-transform:uppercase;
  letter-spacing:.42em;
  font-size:.72rem;
  font-weight:500;
  color:var(--ember-2);
  display:inline-flex;align-items:center;gap:.8em;
}
.eyebrow::before{content:"";width:34px;height:1px;background:linear-gradient(90deg,transparent,var(--ember))}
.eyebrow.center::after{content:"";width:34px;height:1px;background:linear-gradient(90deg,var(--ember),transparent)}

h1,h2,h3{font-family:var(--display);font-weight:600;line-height:.98;text-transform:uppercase;letter-spacing:.01em;color:var(--cream)}
.h-xl{font-size:clamp(2.8rem,8vw,7rem)}
.h-lg{font-size:clamp(2.2rem,5.5vw,4.6rem)}
.h-md{font-size:clamp(1.6rem,3.5vw,2.8rem)}
.script{font-family:var(--serif);font-style:italic;text-transform:none;font-weight:500;color:var(--gold-2);letter-spacing:0}
.lede{font-family:var(--serif);font-size:clamp(1.2rem,2.2vw,1.7rem);line-height:1.5;color:var(--sand)}

/* ----------  LAYOUT  ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
.section{padding-block:clamp(80px,12vw,160px);position:relative}
.center{text-align:center}
.stack{display:flex;flex-direction:column}

/* ----------  BUTTONS  ---------- */
.btn{
  --bg:var(--ember);--fg:#160c05;
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.7em;
  font-family:var(--display);text-transform:uppercase;letter-spacing:.16em;font-weight:600;font-size:.82rem;
  padding:1.1em 2.2em;border-radius:var(--radius);
  background:var(--bg);color:var(--fg);
  overflow:hidden;isolation:isolate;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),color .4s;
  box-shadow:0 10px 30px -10px rgba(232,120,43,.5);
}
.btn::before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(120deg,var(--gold-2),var(--ember-2));transform:translateY(101%);transition:transform .55s var(--ease)}
.btn:hover{transform:translateY(-3px);box-shadow:0 18px 40px -12px rgba(232,120,43,.65)}
.btn:hover::before{transform:translateY(0)}
.btn:active{transform:translateY(0)}
.btn--ghost{--bg:transparent;--fg:var(--cream);border:1px solid var(--line);box-shadow:none}
.btn--ghost::before{background:var(--cream)}
.btn--ghost:hover{color:#160c05;border-color:var(--cream);box-shadow:0 16px 36px -16px rgba(245,238,221,.3)}
.btn--gold{--bg:var(--gold);box-shadow:0 10px 30px -10px rgba(212,160,82,.5)}
.btn--sm{padding:.8em 1.5em;font-size:.74rem}
.btn--block{width:100%}

.link-arrow{font-family:var(--display);text-transform:uppercase;letter-spacing:.14em;font-size:.8rem;font-weight:600;color:var(--gold-2);display:inline-flex;align-items:center;gap:.6em;transition:gap .4s var(--ease),color .3s}
.link-arrow svg{transition:transform .4s var(--ease)}
.link-arrow:hover{color:var(--ember-2);gap:1em}
.link-arrow:hover svg{transform:translateX(4px)}

/* =========================================================================
   NAVBAR
   ========================================================================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem var(--gut);
  transition:background .5s var(--ease),padding .5s var(--ease),border-color .5s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{background:rgba(11,10,9,.82);backdrop-filter:blur(14px);border-bottom-color:var(--line-soft);padding-block:.7rem}
.nav__brand{display:flex;align-items:center;gap:.7rem;font-family:var(--display);text-transform:uppercase;letter-spacing:.2em;font-weight:600;font-size:.92rem;color:var(--cream)}
.nav__brand img{width:42px;height:42px;transition:transform .6s var(--ease)}
.nav__brand:hover img{transform:rotate(-8deg) scale(1.05)}
.nav__brand span small{display:block;font-size:.52rem;letter-spacing:.34em;color:var(--ember-2);margin-top:2px}
.nav__links{display:flex;align-items:center;gap:2.2rem}
.nav__links a{font-family:var(--display);text-transform:uppercase;letter-spacing:.13em;font-size:.78rem;font-weight:500;color:var(--bone);position:relative;padding:.2em 0}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;background:var(--ember);transition:width .4s var(--ease)}
.nav__links a:hover{color:var(--cream)}
.nav__links a:hover::after{width:100%}
.nav__actions{display:flex;align-items:center;gap:1rem}
.icon-btn{position:relative;width:42px;height:42px;display:grid;place-items:center;border-radius:50%;border:1px solid var(--line-soft);transition:border-color .4s,background .4s,transform .4s}
.icon-btn:hover{border-color:var(--ember);background:rgba(232,120,43,.08);transform:translateY(-2px)}
.icon-btn svg{width:19px;height:19px;stroke:var(--bone)}
.cart-count{position:absolute;top:-5px;right:-5px;min-width:19px;height:19px;padding:0 5px;background:var(--ember);color:#160c05;border-radius:20px;font-family:var(--display);font-size:.66rem;font-weight:700;display:grid;place-items:center;transform:scale(0);transition:transform .4s var(--ease)}
.cart-count.show{transform:scale(1)}
.nav__burger{display:none;flex-direction:column;gap:5px;width:42px;height:42px;align-items:center;justify-content:center;border:1px solid var(--line-soft);border-radius:50%}
.nav__burger span{width:18px;height:2px;background:var(--bone);transition:.4s var(--ease)}

/* =========================================================================
   HERO — scroll-driven running cattle
   ========================================================================= */
.hero{position:relative;height:230vh;min-height:680px;overflow:clip}
.hero__layer{transform-origin:50% 100%}
.hero__sticky{position:sticky;top:0;height:100vh;overflow:hidden}
.hero__sky{position:absolute;inset:0;background:var(--sky);z-index:0}
/* real cattle photo hero — sky gradient above is the fallback if image is missing */
.hero__photo{position:absolute;inset:0;z-index:3;background:url("../assets/hero-poster.png?v=2") center 45%/cover no-repeat;transform-origin:50% 60%;will-change:transform,opacity}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 45%;z-index:3;transform-origin:50% 60%;will-change:transform,opacity}
.hero__photo-grade{position:absolute;inset:0;z-index:4;pointer-events:none;background:
  radial-gradient(125% 85% at 50% 32%,transparent 42%,rgba(11,10,9,.5) 100%),
  linear-gradient(180deg,rgba(11,10,9,.5) 0%,transparent 20%,transparent 52%,rgba(11,10,9,.72) 84%,#0b0a09 100%)}
/* sun */
.hero__sun{position:absolute;left:50%;top:46%;width:min(46vw,520px);aspect-ratio:1;transform:translate(-50%,-50%);border-radius:50%;
  background:radial-gradient(circle,#ffe7b0 0%,#ffc24d 30%,#f59330 55%,rgba(216,83,28,0) 72%);
  filter:blur(2px);z-index:1;opacity:.95;animation:sunPulse 7s ease-in-out infinite}
@keyframes sunPulse{0%,100%{opacity:.85;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.04)}}
.hero__haze{position:absolute;inset:0;z-index:2;background:
  radial-gradient(120% 60% at 50% 78%,rgba(232,120,43,.32),transparent 60%),
  linear-gradient(180deg,rgba(11,10,9,.25) 0%,transparent 28%,transparent 60%,rgba(11,10,9,.85) 100%)}
/* parallax cattle layers */
.hero__layer{position:absolute;left:0;right:0;bottom:0;width:100%;z-index:3;will-change:transform;pointer-events:none}
.hero__layer svg{width:100%;height:auto;display:block}
.hero__layer--far{bottom:8%;opacity:.5;filter:blur(1px)}
.hero__layer--mid{bottom:2%;opacity:.78}
.hero__layer--rider{bottom:5%;z-index:4}
.hero__layer--near{bottom:-2%;z-index:5}
.hero__ground{position:absolute;left:0;right:0;bottom:0;height:30%;z-index:3;background:linear-gradient(180deg,transparent,#16100b 78%,#0b0a09);}
/* dust */
.hero__dust{position:absolute;inset:0;z-index:4;pointer-events:none;opacity:.5;
  background:radial-gradient(2px 2px at 20% 80%,rgba(245,238,221,.5),transparent),
            radial-gradient(2px 2px at 70% 85%,rgba(245,238,221,.35),transparent),
            radial-gradient(1px 1px at 45% 75%,rgba(245,238,221,.4),transparent),
            radial-gradient(2px 2px at 85% 78%,rgba(245,238,221,.3),transparent),
            radial-gradient(1px 1px at 30% 88%,rgba(245,238,221,.35),transparent);
  background-size:cover;animation:dustDrift 9s linear infinite}
@keyframes dustDrift{from{transform:translateX(0)}to{transform:translateX(-40px)}}

.hero__content{position:absolute;left:0;right:0;bottom:clamp(7%,12vh,16%);z-index:8;text-align:center;padding-inline:var(--gut);will-change:transform,opacity}
.hero__content h1{filter:drop-shadow(0 8px 30px rgba(0,0,0,.6))}
.hero__content::before{content:"";position:absolute;left:50%;top:40%;transform:translate(-50%,-50%);width:min(135%,1000px);height:135%;z-index:-1;pointer-events:none;background:radial-gradient(closest-side,rgba(11,10,9,.55),rgba(11,10,9,.3) 48%,transparent 74%);filter:blur(26px)}
.hero__content .script{display:block;font-size:clamp(1.6rem,4vw,3rem);margin-bottom:-.1em;color:#ffe9c2;text-shadow:0 0 16px rgba(11,10,9,.95),0 0 40px rgba(11,10,9,.75),0 2px 5px rgba(0,0,0,.95)}
.hero__sub{margin:1.4rem auto 2rem;max-width:540px;color:var(--bone);font-size:1.02rem;text-shadow:0 2px 16px rgba(0,0,0,.6)}
.hero__cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

.scroll-cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:8;font-family:var(--display);text-transform:uppercase;letter-spacing:.3em;font-size:.62rem;color:var(--bone);display:flex;flex-direction:column;align-items:center;gap:.7rem;opacity:.85}
.scroll-cue .mouse{width:22px;height:34px;border:1.5px solid var(--bone);border-radius:14px;position:relative}
.scroll-cue .mouse::after{content:"";position:absolute;left:50%;top:6px;width:3px;height:7px;background:var(--ember-2);border-radius:2px;transform:translateX(-50%);animation:wheel 1.6s ease-in-out infinite}
@keyframes wheel{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}100%{opacity:0;transform:translate(-50%,12px)}}

/* logo reveal overlay (fades in as cattle reach you) */
.hero__finale{position:absolute;inset:0;z-index:6;pointer-events:none;opacity:0;will-change:opacity;
  background:
    radial-gradient(72% 56% at 50% 47%, rgba(64,32,12,.35) 0%, rgba(20,12,7,.86) 55%, #0b0a09 100%),
    linear-gradient(180deg,#0b0a09 0%,transparent 28%,transparent 72%,#0b0a09 100%)}
.hero__brandreveal{position:absolute;inset:0;z-index:7;display:grid;place-items:center;opacity:0;pointer-events:none;will-change:opacity}
.hero__brandglow{position:absolute;width:min(72vw,580px);aspect-ratio:1;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(212,160,82,.42) 0%,rgba(232,120,43,.16) 40%,transparent 68%);filter:blur(16px)}
.hero__brandreveal img{position:relative;z-index:1;width:min(58vw,330px);
  filter:drop-shadow(0 0 26px rgba(212,160,82,.45)) drop-shadow(0 14px 50px rgba(0,0,0,.85))}

/* =========================================================================
   MARQUEE / TRUST STRIP
   ========================================================================= */
.marquee{border-block:1px solid var(--line-soft);background:var(--ink);overflow:hidden;padding-block:1.1rem}
.marquee__track{display:flex;gap:3.5rem;width:max-content;animation:scrollX 32s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__item{font-family:var(--display);text-transform:uppercase;letter-spacing:.22em;font-size:.84rem;color:var(--sand);display:flex;align-items:center;gap:1rem;white-space:nowrap}
.marquee__item span{color:var(--ember-2)}
@keyframes scrollX{to{transform:translateX(-50%)}}

/* =========================================================================
   STORY / SPLIT
   ========================================================================= */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,6vw,6rem);align-items:center}
.split--rev .split__media{order:2}
.split__media{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow);background:var(--ink-2)}
.split__media .scene{position:absolute;inset:0}
.split__media .split__photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.split__badge{position:absolute;bottom:18px;left:18px;background:rgba(11,10,9,.78);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:var(--radius);padding:.9rem 1.1rem;display:flex;align-items:center;gap:.8rem}
.split__badge img{width:40px;height:40px}
.split__badge b{font-family:var(--display);text-transform:uppercase;letter-spacing:.16em;font-size:.8rem;color:var(--cream);display:block}
.split__badge small{color:var(--muted);font-size:.72rem}
.split__body h2{margin-bottom:1.4rem}
.split__body p+p{margin-top:1.1rem}
.split__body .lede{margin-bottom:1.6rem}
.pillars{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;margin:2rem 0}
.pillar{display:flex;gap:.9rem;align-items:flex-start}
.pillar .ico{flex:none;width:42px;height:42px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--ember-2)}
.pillar .ico svg{width:20px;height:20px}
.pillar b{font-family:var(--display);text-transform:uppercase;letter-spacing:.1em;font-size:.86rem;color:var(--cream);display:block;margin-bottom:.2rem}
.pillar small{color:var(--muted);font-size:.82rem;line-height:1.5}

/* =========================================================================
   SECTION HEADERS
   ========================================================================= */
.sec-head{max-width:680px}
.sec-head.center{margin-inline:auto}
.sec-head h2{margin:1rem 0 1rem}
.sec-head p{color:var(--muted);font-size:1.05rem}
.sec-head__row{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;flex-wrap:wrap}

/* =========================================================================
   PRODUCT GRID + CARDS
   ========================================================================= */
.grid{display:grid;gap:1.6rem}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}

.card{
  position:relative;background:var(--ink-2);border:1px solid var(--line-soft);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .55s var(--ease),border-color .45s,box-shadow .55s var(--ease);
}
.card:hover{transform:translateY(-7px);border-color:var(--line);box-shadow:var(--shadow)}
.card__media{position:relative;aspect-ratio:4/3;overflow:hidden;background:#16110d}
.card__media .scene{position:absolute;inset:0;transition:transform .8s var(--ease)}
.card:hover .card__media .scene{transform:scale(1.07)}
/* ---- real product photos (auto: drop assets/products/<id>.jpg|.png) ---- */
.card__media .card__photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2;transition:transform .8s var(--ease)}
.card:hover .card__media .card__photo{transform:scale(1.07)}
.card__media.has-photo .scene-mark{display:none}
.cart-item__img .ci-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2}
.card__tag{position:absolute;top:12px;left:12px;z-index:3;font-family:var(--display);text-transform:uppercase;letter-spacing:.14em;font-size:.62rem;font-weight:600;padding:.4em .8em;border-radius:40px;background:var(--ember);color:#160c05}
.card__tag.gold{background:var(--gold)}
.card__tag.dark{background:rgba(11,10,9,.8);color:var(--bone);border:1px solid var(--line)}
.card__fav{position:absolute;top:10px;right:10px;z-index:3;width:34px;height:34px;border-radius:50%;background:rgba(11,10,9,.6);display:grid;place-items:center;opacity:0;transform:translateY(-6px);transition:.4s var(--ease)}
.card:hover .card__fav{opacity:1;transform:none}
.card__fav svg{width:16px;height:16px;stroke:var(--cream)}
.card__body{padding:1.3rem 1.3rem 1.5rem;display:flex;flex-direction:column;flex:1}
.card__cat{font-family:var(--display);text-transform:uppercase;letter-spacing:.18em;font-size:.6rem;color:var(--ember-2);margin-bottom:.5rem}
.card__title{font-family:var(--display);text-transform:uppercase;font-size:1.18rem;color:var(--cream);line-height:1.05;margin-bottom:.4rem}
.card__desc{color:var(--muted);font-size:.84rem;line-height:1.5;margin-bottom:1rem;flex:1}
.card__stars{display:flex;align-items:center;gap:.4rem;margin-bottom:.9rem;font-size:.74rem;color:var(--muted)}
.stars{display:inline-flex;gap:1px;color:var(--gold-2)}
.stars svg{width:13px;height:13px;fill:currentColor}
.card__foot{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:auto}
.price{font-family:var(--display);color:var(--cream);font-size:1.4rem;letter-spacing:.01em}
.price s{color:var(--muted-2);font-size:.9rem;margin-right:.4rem;font-family:var(--body)}
.price small{font-size:.7rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}
.add-btn{flex:none;display:inline-flex;align-items:center;gap:.5em;background:var(--char-2);border:1px solid var(--line);color:var(--cream);padding:.7em 1.1em;border-radius:var(--radius);font-family:var(--display);text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;font-weight:600;transition:.4s var(--ease)}
.add-btn:hover{background:var(--ember);color:#160c05;border-color:var(--ember);transform:translateY(-2px)}
.add-btn svg{width:15px;height:15px}

/* food "scene" backgrounds (CSS-rendered cuts, no photos needed) */
.scene{background-size:cover;background-position:center}
.cut-ribeye{background:
  radial-gradient(60% 70% at 40% 40%,#7a2418,#4a1610 70%),
  repeating-linear-gradient(40deg,rgba(245,238,221,.06) 0 3px,transparent 3px 12px),
  linear-gradient(135deg,#5e1c12,#2c0e09)}
.cut-strip{background:radial-gradient(70% 60% at 55% 45%,#7c2a18,#3a130d),linear-gradient(120deg,#641f12,#2a0d08)}
.cut-tender{background:radial-gradient(50% 60% at 50% 50%,#8a3320,#4a1710),linear-gradient(160deg,#722616,#2c0d08)}
.cut-ground{background:repeating-radial-gradient(circle at 30% 40%,#6e2417 0 5px,#581c12 5px 9px),linear-gradient(135deg,#5a1d12,#27100a)}
.cut-brisket{background:linear-gradient(160deg,#73291a 0%,#3c150d 60%),repeating-linear-gradient(85deg,rgba(20,10,6,.4) 0 4px,transparent 4px 16px)}
.cut-box{background:radial-gradient(80% 80% at 50% 30%,#2a2018,#150f0a),linear-gradient(135deg,#241a12,#0f0b08)}
.cut-roast{background:radial-gradient(60% 65% at 45% 45%,#8a3a22,#481810),linear-gradient(135deg,#6c2715,#2a0f08)}
.cut-burger{background:radial-gradient(60% 60% at 50% 55%,#3a2415,#1c120a),linear-gradient(135deg,#2e1d10,#120c07)}
.cut-share{background:linear-gradient(135deg,#241c14,#0f0b07),radial-gradient(70% 50% at 50% 20%,rgba(232,120,43,.22),transparent)}
.cut-sub{background:linear-gradient(135deg,#2a1f16,#120d08),radial-gradient(60% 60% at 70% 30%,rgba(212,160,82,.2),transparent)}
.cut-jerky{background:repeating-linear-gradient(60deg,#4a2012 0 6px,#37160d 6px 12px),linear-gradient(135deg,#451d11,#1f0d07)}
.scene::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(11,10,9,.55));}
.scene-mark{position:absolute;inset:0;display:grid;place-items:center;z-index:1;opacity:.14}
.scene-mark img{width:55%;filter:none}

/* =========================================================================
   CATEGORY TILES
   ========================================================================= */
.cats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.cat-tile{position:relative;aspect-ratio:3/4;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line-soft);display:flex;align-items:flex-end;padding:1.4rem;transition:transform .55s var(--ease),border-color .4s}
.cat-tile .scene{position:absolute;inset:0;z-index:0;transition:transform .8s var(--ease)}
.cat-tile:hover{transform:translateY(-6px);border-color:var(--ember)}
.cat-tile:hover .scene{transform:scale(1.08)}
.cat-tile .cat-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:transform .8s var(--ease)}
.cat-tile:hover .cat-photo{transform:scale(1.08)}
.cat-tile .cat-grade{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(11,10,9,.05) 0%,transparent 36%,rgba(11,10,9,.55) 72%,rgba(11,10,9,.92) 100%)}
.cat-tile__txt{position:relative;z-index:2}
.cat-tile__txt small{font-family:var(--display);letter-spacing:.2em;text-transform:uppercase;font-size:.6rem;color:var(--ember-2)}
.cat-tile__txt b{font-family:var(--display);text-transform:uppercase;font-size:1.3rem;color:var(--cream);display:block;line-height:1}
.cat-tile__txt .link-arrow{margin-top:.6rem;font-size:.68rem}

/* =========================================================================
   FEATURE BANNER (parallax)
   ========================================================================= */
.banner{position:relative;min-height:70vh;display:grid;place-items:center;text-align:center;overflow:hidden;border-block:1px solid var(--line-soft)}
.banner__bg{position:absolute;inset:0;z-index:0;background:var(--sky);will-change:transform}
.banner__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,10,9,.6),rgba(11,10,9,.78))}
.banner__cattle{position:absolute;left:0;right:0;bottom:0;z-index:1;opacity:.6;will-change:transform}
.banner__inner{position:relative;z-index:3;max-width:760px;padding:6rem var(--gut)}
.banner__inner h2{margin:1.2rem 0}
.banner__inner p{color:var(--bone);font-size:1.1rem;margin-bottom:2rem}

/* =========================================================================
   STEPS / HOW IT WORKS
   ========================================================================= */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;counter-reset:step}
.step{position:relative;padding:2rem 1.4rem;border:1px solid var(--line-soft);border-radius:var(--radius);background:var(--ink-2);transition:.5s var(--ease)}
.step:hover{border-color:var(--line);transform:translateY(-5px)}
.step::before{counter-increment:step;content:"0" counter(step);font-family:var(--display);font-size:2.6rem;color:var(--blood);line-height:1;display:block;margin-bottom:1rem;opacity:.9}
.step b{font-family:var(--display);text-transform:uppercase;letter-spacing:.08em;font-size:1.05rem;color:var(--cream);display:block;margin-bottom:.5rem}
.step p{color:var(--muted);font-size:.86rem}

/* =========================================================================
   REVIEWS
   ========================================================================= */
.reviews{position:relative}
.reviews__head{display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;margin-bottom:3rem}
.reviews__score{display:flex;align-items:center;gap:1rem;padding:1rem 1.4rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--ink-2)}
.reviews__score b{font-family:var(--display);font-size:2.4rem;color:var(--cream);line-height:1}
.reviews__score .stars svg{width:18px;height:18px}
.reviews__score small{color:var(--muted);font-size:.78rem;display:block}
.rev-grid{columns:3;column-gap:1.6rem}
.rev{break-inside:avoid;margin-bottom:1.6rem;padding:1.6rem;border:1px solid var(--line-soft);border-radius:var(--radius);background:var(--ink-2);transition:.5s var(--ease)}
.rev:hover{border-color:var(--line);transform:translateY(-4px)}
.rev .stars{margin-bottom:.9rem}
.rev p{font-family:var(--serif);font-size:1.08rem;line-height:1.55;color:var(--bone);margin-bottom:1.1rem}
.rev__by{display:flex;align-items:center;gap:.8rem}
.rev__av{width:40px;height:40px;border-radius:50%;flex:none;display:grid;place-items:center;font-family:var(--display);font-size:.9rem;color:#160c05;background:var(--gold-grad)}
.rev__by b{font-family:var(--body);font-weight:600;font-size:.86rem;color:var(--cream)}
.rev__by small{color:var(--muted);font-size:.74rem;display:flex;align-items:center;gap:.4rem}
.verified{color:var(--ember-2);display:inline-flex;align-items:center;gap:.2rem;font-size:.68rem}

/* =========================================================================
   FAQ
   ========================================================================= */
.faq{max-width:840px;margin-inline:auto}
.faq__item{border-bottom:1px solid var(--line-soft)}
.faq__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;text-align:left;padding:1.5rem 0;font-family:var(--display);text-transform:uppercase;letter-spacing:.04em;font-size:clamp(1rem,2vw,1.25rem);color:var(--cream);transition:color .3s}
.faq__q:hover{color:var(--ember-2)}
.faq__ico{flex:none;width:30px;height:30px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;position:relative;transition:.4s var(--ease)}
.faq__ico::before,.faq__ico::after{content:"";position:absolute;background:var(--ember-2);transition:.4s var(--ease)}
.faq__ico::before{width:12px;height:2px}
.faq__ico::after{width:2px;height:12px}
.faq__item.open .faq__ico{background:var(--ember);border-color:var(--ember)}
.faq__item.open .faq__ico::before,.faq__item.open .faq__ico::after{background:#160c05}
.faq__item.open .faq__ico::after{transform:scaleY(0)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.faq__a p{padding:0 0 1.6rem;color:var(--muted);font-size:.98rem;line-height:1.7;max-width:90%}

/* =========================================================================
   NEWSLETTER / CTA
   ========================================================================= */
.cta-band{position:relative;overflow:hidden;border-radius:var(--radius);padding:clamp(3rem,7vw,6rem);text-align:center;background:linear-gradient(135deg,#1d1410,#120c08);border:1px solid var(--line)}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 120% at 50% 0%,rgba(232,120,43,.18),transparent 60%);z-index:0}
.cta-band>*{position:relative;z-index:1}
.cta-band h2{margin:1rem 0}
.cta-band p{color:var(--sand);max-width:520px;margin:0 auto 2rem}
.subscribe{display:flex;gap:.7rem;max-width:480px;margin-inline:auto;flex-wrap:wrap}
.subscribe input{flex:1;min-width:200px;background:var(--ink);border:1px solid var(--line);border-radius:var(--radius);padding:1.05em 1.2em;color:var(--cream);font-family:var(--body);font-size:.92rem}
.subscribe input:focus{outline:none;border-color:var(--ember)}

/* =========================================================================
   FOOTER
   ========================================================================= */
.footer{background:var(--ink);border-top:1px solid var(--line-soft);padding-top:clamp(3rem,6vw,5rem)}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.5rem;padding-bottom:3rem;border-bottom:1px solid var(--line-soft)}
.footer__brand img{width:84px;margin-bottom:1.2rem}
.footer__brand p{color:var(--muted);font-size:.88rem;max-width:280px}
.footer__col h4{font-family:var(--display);text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;color:var(--cream);margin-bottom:1.2rem}
.footer__col a{display:block;color:var(--muted);font-size:.86rem;padding:.35rem 0;transition:color .3s,padding-left .3s}
.footer__col a:hover{color:var(--ember-2);padding-left:.3rem}
.footer__bottom{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;padding-block:1.8rem;color:var(--muted-2);font-size:.78rem}
.footer__bottom a{color:var(--gold-2)}
.socials{display:flex;gap:.7rem}
.socials a{width:38px;height:38px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;transition:.4s var(--ease)}
.socials a:hover{border-color:var(--ember);background:rgba(232,120,43,.08);transform:translateY(-3px)}
.socials svg{width:17px;height:17px;stroke:var(--bone)}

/* =========================================================================
   CART DRAWER
   ========================================================================= */
.overlay{position:fixed;inset:0;background:rgba(5,4,3,.7);backdrop-filter:blur(3px);z-index:300;opacity:0;visibility:hidden;transition:.45s var(--ease)}
.overlay.show{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(440px,100%);background:var(--ink);border-left:1px solid var(--line);z-index:310;transform:translateX(100%);transition:transform .55s var(--ease);display:flex;flex-direction:column}
.drawer.show{transform:none}
.drawer__head{display:flex;align-items:center;justify-content:space-between;padding:1.5rem var(--gut);border-bottom:1px solid var(--line-soft)}
.drawer__head h3{font-size:1.3rem}
.drawer__close{width:40px;height:40px;border:1px solid var(--line-soft);border-radius:50%;display:grid;place-items:center;transition:.3s}
.drawer__close:hover{border-color:var(--ember);color:var(--ember-2)}
.drawer__body{flex:1;overflow-y:auto;padding:1.2rem var(--gut)}
.cart-empty{text-align:center;padding:4rem 1rem;color:var(--muted)}
.cart-empty svg{width:54px;height:54px;stroke:var(--line);margin-bottom:1rem}
.cart-item{display:flex;gap:1rem;padding:1.1rem 0;border-bottom:1px solid var(--line-soft)}
.cart-item__img{width:72px;height:72px;border-radius:var(--radius);overflow:hidden;flex:none;position:relative}
.cart-item__info{flex:1;min-width:0}
.cart-item__info b{font-family:var(--display);text-transform:uppercase;font-size:.92rem;color:var(--cream);display:block;line-height:1.1}
.cart-item__info small{color:var(--muted);font-size:.74rem}
.qty{display:inline-flex;align-items:center;gap:.2rem;margin-top:.5rem;border:1px solid var(--line);border-radius:40px}
.qty button{width:26px;height:26px;display:grid;place-items:center;color:var(--bone);font-size:1rem}
.qty button:hover{color:var(--ember-2)}
.qty span{min-width:24px;text-align:center;font-family:var(--display);font-size:.86rem}
.cart-item__right{text-align:right;display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end}
.cart-item__right .price{font-size:1.05rem}
.remove{color:var(--muted-2);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;transition:color .3s}
.remove:hover{color:var(--flame)}
.drawer__foot{border-top:1px solid var(--line);padding:1.4rem var(--gut)}
.cart-line{display:flex;justify-content:space-between;color:var(--muted);font-size:.86rem;margin-bottom:.6rem}
.cart-line.total{color:var(--cream);font-family:var(--display);font-size:1.3rem;text-transform:uppercase;margin-block:1rem;padding-top:1rem;border-top:1px solid var(--line-soft)}
.ship-toggle{display:flex;gap:.5rem;margin-bottom:1.2rem}
.ship-toggle button{flex:1;padding:.8em;border:1px solid var(--line);border-radius:var(--radius);font-family:var(--display);text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;color:var(--muted);transition:.3s}
.ship-toggle button.active{background:var(--char-2);border-color:var(--ember);color:var(--cream)}

/* =========================================================================
   MODAL (account)
   ========================================================================= */
.modal{position:fixed;inset:0;z-index:320;display:grid;place-items:center;padding:1.5rem;opacity:0;visibility:hidden;transition:.4s var(--ease)}
.modal.show{opacity:1;visibility:visible}
.modal__card{width:min(440px,100%);background:var(--ink);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.8rem,4vw,2.6rem);transform:translateY(20px) scale(.98);transition:.5s var(--ease);box-shadow:var(--shadow)}
.modal.show .modal__card{transform:none}
.modal__card .logo-top{width:64px;margin:0 auto 1.2rem}
.modal__tabs{display:flex;gap:.4rem;background:var(--ink-2);padding:.3rem;border-radius:40px;margin-bottom:1.6rem}
.modal__tabs button{flex:1;padding:.7em;border-radius:40px;font-family:var(--display);text-transform:uppercase;letter-spacing:.1em;font-size:.74rem;color:var(--muted);transition:.3s}
.modal__tabs button.active{background:var(--char-2);color:var(--cream)}
.field{margin-bottom:1rem}
.field label{display:block;font-family:var(--display);text-transform:uppercase;letter-spacing:.12em;font-size:.66rem;color:var(--muted);margin-bottom:.5rem}
.field input{width:100%;background:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius);padding:.95em 1.1em;color:var(--cream);font-family:var(--body);font-size:.92rem;transition:border-color .3s}
.field input:focus{outline:none;border-color:var(--ember)}
.modal__alt{text-align:center;margin-top:1.2rem;color:var(--muted);font-size:.8rem}
.modal__alt a{color:var(--gold-2)}
.modal__close{position:absolute;top:18px;right:18px}

/* account chip when logged in */
.acct-chip{display:none;align-items:center;gap:.5rem;padding:.4rem .4rem .4rem .9rem;border:1px solid var(--line);border-radius:40px;font-size:.78rem;color:var(--cream)}
.acct-chip.show{display:inline-flex}
.acct-chip .av{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-size:.78rem;color:#160c05;background:var(--gold-grad)}

/* toast */
.toast{position:fixed;bottom:26px;left:50%;transform:translate(-50%,140%);z-index:400;background:var(--cream);color:#160c05;padding:.95em 1.5em;border-radius:40px;font-family:var(--display);text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;font-weight:600;box-shadow:var(--shadow);display:flex;align-items:center;gap:.6rem;transition:transform .5s var(--ease)}
.toast.show{transform:translate(-50%,0)}
.toast svg{width:18px;height:18px}

/* =========================================================================
   SHOP PAGE
   ========================================================================= */
.shop-hero{padding:clamp(120px,18vh,180px) 0 clamp(40px,6vw,70px);position:relative;overflow:hidden;border-bottom:1px solid var(--line-soft)}
.shop-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(70% 100% at 50% 0%,rgba(232,120,43,.12),transparent 55%);z-index:0}
.shop-hero__inner{position:relative;z-index:1}
.breadcrumb{font-family:var(--display);text-transform:uppercase;letter-spacing:.16em;font-size:.68rem;color:var(--muted);margin-bottom:1rem}
.breadcrumb a:hover{color:var(--ember-2)}
.shop-layout{display:grid;grid-template-columns:230px 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}
.filters{position:sticky;top:90px}
.filters h4{font-family:var(--display);text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;color:var(--cream);margin:1.6rem 0 .9rem;padding-bottom:.6rem;border-bottom:1px solid var(--line-soft)}
.filters h4:first-child{margin-top:0}
.filter-btn{display:flex;align-items:center;justify-content:space-between;width:100%;text-align:left;padding:.55rem 0;color:var(--muted);font-size:.88rem;transition:color .3s,padding-left .3s}
.filter-btn:hover{color:var(--bone);padding-left:.25rem}
.filter-btn.active{color:var(--ember-2);font-weight:600}
.filter-btn small{color:var(--muted-2);font-size:.74rem}
.shop-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.6rem;flex-wrap:wrap}
.shop-toolbar .count{color:var(--muted);font-size:.84rem}
.select{position:relative}
.select select{appearance:none;background:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius);padding:.7em 2.6em .7em 1em;color:var(--bone);font-family:var(--display);text-transform:uppercase;letter-spacing:.08em;font-size:.74rem}
.select::after{content:"";position:absolute;right:14px;top:50%;width:7px;height:7px;border-right:1.5px solid var(--muted);border-bottom:1.5px solid var(--muted);transform:translateY(-65%) rotate(45deg);pointer-events:none}
.chips{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.8rem}
.chip{padding:.5em 1em;border:1px solid var(--line);border-radius:40px;font-family:var(--display);text-transform:uppercase;letter-spacing:.1em;font-size:.68rem;color:var(--muted);transition:.3s;white-space:nowrap}
.chip:hover{color:var(--bone);border-color:var(--line)}
.chip.active{background:var(--ember);border-color:var(--ember);color:#160c05}

/* =========================================================================
   REVEAL ANIMATIONS
   ========================================================================= */
[data-reveal]{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal-stagger]>*{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal-stagger].in>*{opacity:1;transform:none}
[data-reveal-stagger].in>*:nth-child(1){transition-delay:.05s}
[data-reveal-stagger].in>*:nth-child(2){transition-delay:.13s}
[data-reveal-stagger].in>*:nth-child(3){transition-delay:.21s}
[data-reveal-stagger].in>*:nth-child(4){transition-delay:.29s}
[data-reveal-stagger].in>*:nth-child(5){transition-delay:.37s}
[data-reveal-stagger].in>*:nth-child(6){transition-delay:.45s}
[data-reveal-stagger].in>*:nth-child(7){transition-delay:.53s}
[data-reveal-stagger].in>*:nth-child(8){transition-delay:.61s}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media(max-width:1024px){
  .grid--4{grid-template-columns:repeat(2,1fr)}
  .cats{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .footer__top{grid-template-columns:1fr 1fr}
  .rev-grid{columns:2}
  .shop-layout{grid-template-columns:1fr}
  .filters{position:static;display:grid;grid-template-columns:repeat(2,1fr);gap:0 2rem}
}
@media(max-width:760px){
  .nav__links{display:none}
  .nav__burger{display:flex}
  .nav__links.open{display:flex;position:fixed;inset:64px 0 auto 0;flex-direction:column;gap:0;background:rgba(11,10,9,.97);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding:1rem var(--gut) 1.6rem}
  .nav__links.open a{padding:1rem 0;border-bottom:1px solid var(--line-soft);width:100%;font-size:1rem}
  .split{grid-template-columns:1fr}
  .split--rev .split__media{order:0}
  .pillars{grid-template-columns:1fr}
  .grid--3,.grid--4{grid-template-columns:1fr}
  .cats{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr}
  .rev-grid{columns:1}
  .footer__top{grid-template-columns:1fr;gap:2rem}
  .reviews__head{justify-content:center;text-align:center}
  /* shop filters: compact wrapping chips so products stay visible */
  .filters{display:block;position:static}
  .filters h4{margin:1.1rem 0 .6rem}
  #catFilters,#priceFilters,#tagFilters{display:flex;flex-wrap:wrap;gap:.5rem}
  .filters .filter-btn{width:auto;justify-content:flex-start;gap:.4rem;padding:.5rem .85rem;border:1px solid var(--line);border-radius:40px;font-size:.8rem}
  .filters .filter-btn.active{border-color:var(--ember);background:rgba(232,120,43,.12);color:var(--ember-2)}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;transition-duration:.001s!important}
  html{scroll-behavior:auto}
}
