/* =========================================================
   Nature's Sustainable Beef — design system
   Display: Fraunces · Body: Hanken Grotesk · Tags: Space Mono
   ========================================================= */
:root{
  --pasture:#2E4A23; --pasture-900:#1B2C14; --moss:#3E5C30; --grass:#7C9A5E;
  --ochre:#B08D2E; --ochre-300:#D9BE7E; --bone:#F4EFE3; --bone-200:#FBF8F1;
  --char:#1C1B17; --char-70:#4A463D; --clay:#6E2A23; --line:#E2DAC8;
  --radius:6px; --maxw:1180px;
  --shadow:0 18px 40px -22px rgba(27,44,20,.45);
  --serif:"Fraunces",Georgia,serif; --sans:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"Space Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; font-family:var(--sans); color:var(--char); background:var(--bone-200);
  font-size:17px; line-height:1.6; -webkit-font-smoothing:antialiased;
}
img,svg{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
h1,h2,h3{font-family:var(--serif); font-weight:500; line-height:1.05; margin:0;
  font-optical-sizing:auto; letter-spacing:-.01em}
p{margin:0 0 1rem}
.container{max-width:var(--maxw); margin:0 auto; padding:0 24px}
.eyebrow{font-family:var(--mono); font-size:.72rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--ochre); margin:0 0 14px}
.section{padding:96px 0}
.section--tight{padding:64px 0}
.lead{font-size:1.18rem; color:var(--char-70); max-width:60ch}

/* provenance tag — signature element */
.tag{display:inline-flex; align-items:center; gap:8px; font-family:var(--mono);
  font-size:.7rem; letter-spacing:.12em; text-transform:uppercase;
  border:1px solid var(--ochre); color:var(--ochre); padding:6px 12px;
  border-radius:100px; background:transparent}
.tag::before{content:"▦"; font-size:.8em; opacity:.85}
.tag--solid{background:var(--ochre); color:var(--pasture-900); border-color:var(--ochre)}

/* buttons */
.btn{display:inline-flex; align-items:center; gap:10px; font-family:var(--sans);
  font-weight:600; font-size:.98rem; padding:14px 26px; border-radius:100px;
  border:1.5px solid transparent; cursor:pointer; transition:.18s ease; line-height:1}
.btn--primary{background:var(--ochre); color:var(--pasture-900)}
.btn--primary:hover{background:var(--ochre-300); transform:translateY(-1px)}
.btn--ghost{background:transparent; border-color:currentColor; color:var(--bone)}
.btn--ghost:hover{background:rgba(244,239,227,.12)}
.btn--dark{background:var(--pasture); color:var(--bone)}
.btn--dark:hover{background:var(--moss)}
.btn--block{width:100%; justify-content:center}
.btn--sm{padding:10px 18px; font-size:.9rem}

/* ---------- header ---------- */
.site-header{position:sticky; top:0; z-index:60; background:rgba(251,248,241,.86);
  backdrop-filter:blur(10px); border-bottom:1px solid var(--line)}
.nav{display:flex; align-items:center; gap:28px; height:70px}
.brand{display:flex; align-items:center; gap:12px; color:var(--pasture)}
.brand .mark{width:38px; height:38px; flex:none}
.brand b{font-family:var(--serif); font-weight:600; font-size:1.18rem;
  letter-spacing:-.02em; line-height:1; color:var(--pasture)}
.brand small{display:block; font-family:var(--mono); font-size:.56rem;
  letter-spacing:.22em; text-transform:uppercase; color:var(--ochre); margin-top:3px}
.nav-links{display:flex; gap:26px; margin-left:auto; align-items:center}
.nav-links a{font-weight:500; font-size:.96rem; color:var(--char); padding:6px 0;
  border-bottom:2px solid transparent; transition:.15s}
.nav-links a:hover,.nav-links a[aria-current="page"]{border-color:var(--ochre)}
.cart-btn{position:relative; display:inline-flex; align-items:center; gap:8px;
  background:var(--pasture); color:var(--bone); border:none; cursor:pointer;
  padding:10px 16px; border-radius:100px; font-family:var(--sans); font-weight:600; font-size:.9rem}
.cart-btn:hover{background:var(--moss)}
.cart-count{background:var(--ochre); color:var(--pasture-900); min-width:20px; height:20px;
  border-radius:100px; font-size:.72rem; display:grid; place-items:center; font-weight:700; padding:0 5px}
.nav-toggle{display:none; background:none; border:none; cursor:pointer; color:var(--pasture)}

/* ---------- hero ---------- */
.hero{position:relative; background:var(--pasture-900); color:var(--bone); overflow:hidden}
.hero-bg{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.96}
.hero-inner{position:relative; z-index:2; padding:120px 0 140px; max-width:680px}
.hero h1{font-size:clamp(2.6rem,6vw,4.7rem); color:var(--bone); margin:18px 0 22px}
.hero h1 em{font-style:italic; color:var(--ochre-300)}
.hero p{font-size:1.2rem; color:#E9E4D5; max-width:48ch; margin-bottom:32px}
.hero .eyebrow{color:var(--ochre-300)}
.hero-cta{display:flex; gap:14px; flex-wrap:wrap}
.hero-foot{position:relative; z-index:2; display:flex; gap:28px; flex-wrap:wrap;
  padding:0 0 46px}
.hero-foot .tag{color:var(--ochre-300); border-color:rgba(217,190,126,.5)}

/* ---------- value props ---------- */
.values{background:var(--bone)}
.values-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:26px; margin-top:40px}
.value{padding:30px 24px; background:var(--bone-200); border:1px solid var(--line);
  border-radius:var(--radius)}
.value .ico{width:40px; height:40px; color:var(--pasture); margin-bottom:16px}
.value h3{font-size:1.22rem; margin-bottom:8px}
.value p{font-size:.96rem; color:var(--char-70); margin:0}

/* ---------- section heading ---------- */
.head{display:flex; align-items:flex-end; justify-content:space-between; gap:24px;
  flex-wrap:wrap; margin-bottom:8px}
.head h2{font-size:clamp(2rem,4vw,2.9rem)}
.rule{height:1px; background:var(--line); margin:0}

/* ---------- products ---------- */
.products{background:var(--bone-200)}
.product-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:26px; margin-top:40px}
.card{background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; display:flex; flex-direction:column; transition:.2s}
.card:hover{box-shadow:var(--shadow); transform:translateY(-3px)}
.card-media{aspect-ratio:4/3; position:relative; display:grid; place-items:center;
  background:linear-gradient(135deg,var(--pasture),var(--moss)); color:var(--ochre-300)}
.card-media .cut{width:62%; opacity:.92}
.card-media .tag{position:absolute; left:14px; top:14px; background:rgba(27,44,20,.55);
  color:var(--ochre-300); border-color:rgba(217,190,126,.4)}
.card-body{padding:20px 20px 22px; display:flex; flex-direction:column; gap:6px; flex:1}
.card-body h3{font-size:1.3rem}
.card-cut{font-family:var(--mono); font-size:.7rem; letter-spacing:.1em;
  text-transform:uppercase; color:var(--char-70)}
.card-desc{font-size:.92rem; color:var(--char-70); margin:4px 0 12px; flex:1}
.card-foot{display:flex; align-items:center; justify-content:space-between; gap:10px}
.price{font-family:var(--serif); font-size:1.4rem; color:var(--pasture); font-weight:600}
.price small{font-family:var(--mono); font-size:.62rem; color:var(--char-70);
  letter-spacing:.06em; display:block; text-transform:uppercase; font-weight:400}

/* ---------- story band ---------- */
.band{background:var(--pasture); color:var(--bone)}
.band .eyebrow{color:var(--ochre-300)}
.band h2{color:var(--bone); font-size:clamp(2rem,4vw,3rem)}
.band p{color:#E4DFD0}
.band-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:60px; align-items:center}
.stat-row{display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:36px}
.stat .n{font-family:var(--serif); font-size:2.4rem; color:var(--ochre-300); line-height:1}
.stat .l{font-size:.86rem; color:#D7D2C2; margin-top:6px}
.band-art{border:1px solid rgba(217,190,126,.35); border-radius:var(--radius);
  padding:34px; background:rgba(27,44,20,.4)}
.band-art ul{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:18px}
.band-art li{display:flex; gap:14px; align-items:flex-start}
.band-art .dot{width:9px; height:9px; border-radius:50%; background:var(--ochre); margin-top:8px; flex:none}
.band-art h4{margin:0 0 2px; font-family:var(--sans); font-weight:700; font-size:1rem; color:var(--bone)}
.band-art span{font-size:.9rem; color:#CFCABA}

/* ---------- process ---------- */
.process-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:44px;
  counter-reset:step}
.step{position:relative; padding-top:28px; border-top:2px solid var(--ochre)}
.step .num{font-family:var(--mono); color:var(--ochre); font-size:.8rem; letter-spacing:.1em}
.step h3{font-size:1.2rem; margin:8px 0}
.step p{font-size:.92rem; color:var(--char-70); margin:0}

/* ---------- cta ---------- */
.cta{background:var(--ochre); color:var(--pasture-900); text-align:center}
.cta h2{font-size:clamp(2rem,4vw,3rem); color:var(--pasture-900)}
.cta p{color:#5b4a17; max-width:52ch; margin:10px auto 28px}

/* ---------- footer ---------- */
.site-footer{background:var(--pasture-900); color:#CFCABA; padding:72px 0 32px}
.foot-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1.3fr; gap:40px}
.site-footer .brand b{color:var(--bone)}
.site-footer h5{font-family:var(--mono); font-size:.72rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ochre-300); margin:0 0 16px}
.site-footer a{color:#CFCABA; display:block; margin-bottom:10px; font-size:.95rem}
.site-footer a:hover{color:var(--bone)}
.foot-form{display:flex; gap:8px; margin-top:6px}
.foot-form input{flex:1; padding:12px 14px; border-radius:100px; border:1px solid rgba(207,202,186,.3);
  background:rgba(244,239,227,.06); color:var(--bone); font-family:var(--sans)}
.foot-form input::placeholder{color:#9a958a}
.foot-bottom{border-top:1px solid rgba(207,202,186,.18); margin-top:48px; padding-top:24px;
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:.84rem; color:#9a958a}
.foot-bottom .credit{font-family:var(--mono); letter-spacing:.04em}

/* ---------- cart drawer ---------- */
.overlay{position:fixed; inset:0; background:rgba(27,44,20,.5); opacity:0; visibility:hidden;
  transition:.25s; z-index:90}
.overlay.open{opacity:1; visibility:visible}
.drawer{position:fixed; top:0; right:0; height:100%; width:min(420px,100%); background:var(--bone-200);
  z-index:100; transform:translateX(100%); transition:transform .3s ease; display:flex;
  flex-direction:column; box-shadow:-20px 0 50px -20px rgba(0,0,0,.4)}
.drawer.open{transform:translateX(0)}
.drawer-head{display:flex; align-items:center; justify-content:space-between; padding:22px 24px;
  border-bottom:1px solid var(--line)}
.drawer-head h3{font-size:1.4rem}
.drawer-close{background:none; border:none; font-size:1.6rem; cursor:pointer; color:var(--char); line-height:1}
.drawer-body{flex:1; overflow-y:auto; padding:8px 24px}
.cart-line{display:grid; grid-template-columns:54px 1fr auto; gap:14px; align-items:center;
  padding:16px 0; border-bottom:1px solid var(--line)}
.cart-line .thumb{width:54px; height:54px; border-radius:var(--radius);
  background:linear-gradient(135deg,var(--pasture),var(--moss)); display:grid; place-items:center; color:var(--ochre-300)}
.cart-line h4{margin:0; font-family:var(--sans); font-weight:700; font-size:.98rem}
.cart-line .meta{font-family:var(--mono); font-size:.68rem; color:var(--char-70); text-transform:uppercase; letter-spacing:.05em}
.qty{display:inline-flex; align-items:center; gap:10px; margin-top:6px}
.qty button{width:26px; height:26px; border-radius:6px; border:1px solid var(--line);
  background:#fff; cursor:pointer; font-size:1rem; line-height:1; color:var(--pasture)}
.cart-line .lp{font-weight:700; color:var(--pasture); white-space:nowrap}
.remove{background:none; border:none; color:var(--clay); cursor:pointer; font-size:.78rem; margin-top:6px}
.drawer-foot{border-top:1px solid var(--line); padding:22px 24px; background:var(--bone)}
.drawer-foot .row{display:flex; justify-content:space-between; margin-bottom:14px; font-size:1.05rem}
.drawer-foot .row b{font-family:var(--serif); font-size:1.5rem; color:var(--pasture)}
.cart-empty{text-align:center; color:var(--char-70); padding:60px 20px}
.pay-note{font-size:.78rem; color:var(--char-70); text-align:center; margin-top:12px}

/* ---------- forms / page header ---------- */
.page-hero{background:var(--pasture); color:var(--bone); padding:80px 0 64px}
.page-hero h1{color:var(--bone); font-size:clamp(2.4rem,5vw,3.6rem); margin-bottom:14px}
.page-hero p{color:#E4DFD0; max-width:60ch}
.page-hero .eyebrow{color:var(--ochre-300)}
.form{display:grid; gap:18px; max-width:540px}
.field{display:flex; flex-direction:column; gap:7px}
.field label{font-weight:600; font-size:.92rem}
.field input,.field textarea,.field select{padding:13px 15px; border:1px solid var(--line);
  border-radius:var(--radius); font-family:var(--sans); font-size:1rem; background:#fff; color:var(--char)}
.field textarea{min-height:120px; resize:vertical}
.two-col{display:grid; grid-template-columns:1fr 1fr; gap:18px}
.info-card{background:var(--bone); border:1px solid var(--line); border-radius:var(--radius); padding:26px}
.info-card h3{font-size:1.3rem; margin-bottom:10px}
.info-card a{color:var(--pasture); font-weight:600}

/* checkout */
.checkout-grid{display:grid; grid-template-columns:1.2fr .8fr; gap:48px; align-items:start}
.summary{background:var(--bone); border:1px solid var(--line); border-radius:var(--radius); padding:26px; position:sticky; top:90px}
.summary .line{display:flex; justify-content:space-between; padding:10px 0; border-bottom:1px dashed var(--line); font-size:.95rem}
.summary .total{display:flex; justify-content:space-between; padding-top:16px; font-size:1.1rem; align-items:baseline}
.summary .total b{font-family:var(--serif); font-size:1.7rem; color:var(--pasture)}
.pay-methods{display:flex; gap:10px; margin:14px 0; flex-wrap:wrap}
.pay-methods .chip{font-family:var(--mono); font-size:.66rem; letter-spacing:.08em; text-transform:uppercase;
  border:1px solid var(--line); border-radius:100px; padding:7px 12px; color:var(--char-70); background:#fff}
.notice{background:var(--bone); border-left:4px solid var(--ochre); padding:14px 18px; border-radius:6px;
  font-size:.9rem; color:var(--char-70); margin-top:16px}

.toast{position:fixed; bottom:26px; left:50%; transform:translateX(-50%) translateY(20px);
  background:var(--pasture-900); color:var(--bone); padding:14px 22px; border-radius:100px;
  font-size:.92rem; opacity:0; visibility:hidden; transition:.25s; z-index:120; box-shadow:var(--shadow)}
.toast.show{opacity:1; visibility:visible; transform:translateX(-50%) translateY(0)}

/* prose */
.prose{max-width:68ch}
.prose h2{font-size:2rem; margin:40px 0 14px}
.prose h3{font-size:1.4rem; margin:28px 0 10px; color:var(--pasture)}
.prose p{color:var(--char-70)}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .values-grid{grid-template-columns:repeat(2,1fr)}
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .band-grid{grid-template-columns:1fr; gap:36px}
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr; gap:32px}
  .checkout-grid{grid-template-columns:1fr; gap:28px}
  .summary{position:static}
}
@media(max-width:680px){
  .section{padding:68px 0}
  .nav-links{position:fixed; inset:70px 0 auto 0; background:var(--bone-200); flex-direction:column;
    align-items:flex-start; gap:0; padding:8px 24px 18px; border-bottom:1px solid var(--line);
    transform:translateY(-130%); transition:.25s; box-shadow:var(--shadow)}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{width:100%; padding:14px 0; border-bottom:1px solid var(--line)}
  .nav-toggle{display:block}
  .brand{margin-right:auto}
  .brand b{font-size:1rem}
  .brand small{display:none}
  .brand .mark{width:32px; height:32px}
  .values-grid,.product-grid,.process-grid,.foot-grid,.two-col{grid-template-columns:1fr}
  .stat-row{grid-template-columns:1fr 1fr}
  .hero-inner{padding:90px 0 90px}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important; scroll-behavior:auto!important}}
