/* ============================================================
   TRUE ORIGIN FOODS — trueoriginfoods.in
   Design system: "Fresh by the thousands"
   Palette: Milk / Butter / Crust / Cocoa / Jam
   Type: Bricolage Grotesque (display) · Hanken Grotesk (body)
         Spline Sans Mono (specs, eyebrows, stats)
   ============================================================ */

:root{
  --milk:        #FFF8EE;
  --milk-2:      #FFF0D9;
  --butter:      #F7C04A;
  --butter-soft: #FBDD96;
  --crust:       #C06722;
  --cocoa:       #2C1A0E;
  --cocoa-soft:  #5C4732;
  --jam:         #E03E2D;
  --jam-deep:    #BC2F20;
  --card:        #FFFFFF;
  --line:        rgba(44,26,14,.12);
  --wa:          #1FA855;

  --font-display:"Bricolage Grotesque",system-ui,sans-serif;
  --font-body:"Hanken Grotesk",system-ui,sans-serif;
  --font-mono:"Spline Sans Mono",ui-monospace,monospace;

  --pop: cubic-bezier(.3,1.45,.45,1);   /* snappy, slight overshoot */
  --ease: cubic-bezier(.22,.9,.3,1);

  --r-lg: 28px;
  --r-md: 18px;
  --r-pill: 999px;

  --shadow-card: 0 2px 6px rgba(44,26,14,.05), 0 14px 34px rgba(44,26,14,.09);
  --shadow-pop:  0 6px 14px rgba(44,26,14,.12), 0 22px 48px rgba(44,26,14,.16);

  --max: 1180px;
}

/* ---------- Base ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--font-body);
  background:var(--milk);
  color:var(--cocoa);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
button{ font:inherit; cursor:pointer; border:none; background:none; }

::selection{ background:var(--butter); color:var(--cocoa); }

:focus-visible{
  outline:3px solid var(--jam);
  outline-offset:3px;
  border-radius:6px;
}

.container{ width:min(var(--max), 92%); margin-inline:auto; }
.section{ padding:84px 0; }
.section--tight{ padding:60px 0; }
.section--tint{ background:var(--milk-2); }

/* ---------- Type ---------- */
h1,h2,h3,.display{
  font-family:var(--font-display);
  font-weight:800;
  line-height:1.04;
  letter-spacing:-.02em;
}
h1{ font-size:clamp(2.7rem, 6.4vw, 4.8rem); }
h2{ font-size:clamp(2rem, 4.2vw, 3.1rem); margin-bottom:14px; }
h3{ font-size:1.3rem; font-weight:700; letter-spacing:-.01em; line-height:1.2; }

.eyebrow{
  font-family:var(--font-mono);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--crust);
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-bottom:16px;
}
.eyebrow::before{
  content:"";
  width:26px; height:3px;
  background:var(--butter);
  border-radius:2px;
}
.lede{
  font-size:1.13rem;
  color:var(--cocoa-soft);
  max-width:620px;
}
.section-head{ max-width:680px; margin-bottom:46px; }
.center{ text-align:center; }
.center .eyebrow{ justify-content:center; }
.center .lede,.center.section-head{ margin-inline:auto; }

.hl{ color:var(--jam); }
.hl-butter{
  background:linear-gradient(transparent 58%, var(--butter) 58%, var(--butter) 92%, transparent 92%);
  padding:0 .08em;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:9px;
  font-family:var(--font-display);
  font-weight:700;
  font-size:1rem;
  letter-spacing:.005em;
  padding:15px 30px;
  border-radius:var(--r-pill);
  transition:transform .35s var(--pop), box-shadow .35s var(--pop), background .2s var(--ease);
  will-change:transform;
}
.btn:active{ transform:scale(.96); }
.btn--jam{
  background:var(--jam);
  color:#FFF6EC;
  box-shadow:0 6px 16px rgba(224,62,45,.32);
}
.btn--jam:hover{
  background:var(--jam-deep);
  transform:translateY(-3px) scale(1.02);
  box-shadow:0 14px 30px rgba(224,62,45,.4);
}
.btn--ghost{
  background:transparent;
  color:var(--cocoa);
  box-shadow:inset 0 0 0 2px var(--cocoa);
}
.btn--ghost:hover{
  background:var(--cocoa);
  color:var(--milk);
  transform:translateY(-3px);
}
.btn--butter{
  background:var(--butter);
  color:var(--cocoa);
  box-shadow:0 6px 16px rgba(192,103,34,.25);
}
.btn--butter:hover{
  transform:translateY(-3px) scale(1.02);
  box-shadow:0 14px 30px rgba(192,103,34,.33);
}
.btn--sm{ padding:11px 22px; font-size:.92rem; }
.btn .arr{ transition:transform .35s var(--pop); }
.btn:hover .arr{ transform:translateX(4px); }

/* ---------- Nav ---------- */
.nav{
  position:sticky; top:0; z-index:60;
  background:rgba(255,248,238,.84);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s var(--ease), box-shadow .3s var(--ease);
}
.nav.scrolled{
  border-bottom-color:var(--line);
  box-shadow:0 8px 26px rgba(44,26,14,.06);
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0; gap:18px;
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand-mark{
  width:46px; height:46px; flex:none;
  transition:transform .45s var(--pop);
}
img.brand-mark{ object-fit:contain; }
.brand-mark--chip{
  background:var(--milk);
  border-radius:13px;
  padding:5px;
  display:flex; align-items:center; justify-content:center;
}
.brand-mark--chip img{ width:100%; height:100%; object-fit:contain; display:block; }
.brand:hover .brand-mark{ transform:rotate(-8deg) scale(1.06); }
.brand-name{
  font-family:var(--font-display);
  font-weight:800; font-size:1.22rem; line-height:1.05;
  letter-spacing:-.015em;
}
.brand-sub{
  display:block;
  font-family:var(--font-mono);
  font-weight:500; font-size:.6rem;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--crust); margin-top:2px;
}
.nav-links{ display:flex; align-items:center; gap:28px; }
.nav-links a:not(.btn){
  font-weight:600; font-size:.98rem;
  position:relative; padding:4px 0;
  color:var(--cocoa-soft);
  transition:color .2s var(--ease);
}
.nav-links a:not(.btn):hover{ color:var(--cocoa); }
.nav-links a:not(.btn)::after{
  content:""; position:absolute; left:0; bottom:-2px;
  width:100%; height:3px; border-radius:2px;
  background:var(--butter);
  transform:scaleX(0); transform-origin:left;
  transition:transform .35s var(--pop);
}
.nav-links a:not(.btn):hover::after,
.nav-links a.active::after{ transform:scaleX(1); }
.nav-links a.active{ color:var(--cocoa); }

.nav-toggle{
  display:none;
  width:46px; height:46px;
  border-radius:14px;
  background:var(--cocoa);
  color:var(--milk);
  align-items:center; justify-content:center;
}
.mobile-menu{
  display:none;
  border-top:1px solid var(--line);
  background:var(--milk);
  padding:18px 0 26px;
}
.mobile-menu.open{ display:block; animation:menuDrop .4s var(--pop); }
@keyframes menuDrop{
  from{ opacity:0; transform:translateY(-12px); }
  to{ opacity:1; transform:translateY(0); }
}
.mobile-menu a{
  display:block;
  font-family:var(--font-display); font-weight:700; font-size:1.25rem;
  padding:13px 0;
  border-bottom:1px dashed var(--line);
}
.mobile-menu .btn{ margin-top:18px; width:100%; }

/* ---------- Hero ---------- */
.hero{
  position:relative;
  padding:96px 0 110px;
  overflow:hidden;
}
.hero-blob{
  position:absolute;
  width:min(640px, 88vw); aspect-ratio:1;
  right:-160px; top:-120px;
  background:radial-gradient(circle at 35% 35%, var(--butter-soft), var(--butter) 70%);
  border-radius:58% 42% 55% 45% / 48% 56% 44% 52%;
  animation:blob 14s ease-in-out infinite alternate;
  z-index:0;
  opacity:.9;
}
.hero-blob--2{
  width:300px; right:auto; left:-150px; top:auto; bottom:-130px;
  background:radial-gradient(circle at 60% 40%, #F2A65A, var(--crust) 75%);
  opacity:.28;
  animation-duration:18s;
  animation-delay:-6s;
}
@keyframes blob{
  0%  { border-radius:58% 42% 55% 45% / 48% 56% 44% 52%; transform:rotate(0deg) scale(1); }
  50% { border-radius:45% 55% 42% 58% / 55% 44% 56% 45%; transform:rotate(6deg) scale(1.05); }
  100%{ border-radius:52% 48% 60% 40% / 42% 58% 46% 54%; transform:rotate(-4deg) scale(.98); }
}
.hero-inner{ position:relative; z-index:1; max-width:780px; }
.hero h1{ margin-bottom:22px; }
.hero .lede{ font-size:1.22rem; margin-bottom:34px; }
.hero-ctas{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:34px; }
.hero-trust{
  display:flex; flex-wrap:wrap; gap:10px 22px;
  font-family:var(--font-mono);
  font-size:.8rem; font-weight:500;
  letter-spacing:.06em;
  color:var(--cocoa-soft);
}
.hero-trust span{ display:inline-flex; align-items:center; gap:7px; }
.hero-trust .dot{
  width:7px; height:7px; border-radius:50%;
  background:var(--jam); flex:none;
}

/* ---------- Conveyor (signature) ---------- */
.conveyor{
  background:var(--cocoa);
  transform:rotate(-1.4deg) scale(1.02);
  padding:16px 0;
  overflow:hidden;
  position:relative;
  z-index:2;
  box-shadow:0 18px 40px rgba(44,26,14,.22);
}
.conveyor-track{
  display:flex; gap:0;
  width:max-content;
  animation:belt 36s linear infinite;
}
.conveyor:hover .conveyor-track{ animation-play-state:paused; }
.conveyor-set{
  display:flex; align-items:center;
  white-space:nowrap;
}
.conveyor-set span{
  font-family:var(--font-display);
  font-weight:700; font-size:1.06rem;
  color:var(--milk);
  padding:0 26px;
  display:inline-flex; align-items:center; gap:12px;
}
.conveyor-set span i{
  font-style:normal; font-size:1.2rem;
  animation:bob 2.6s ease-in-out infinite;
}
.conveyor-set span:nth-child(2n) i{ animation-delay:-1.3s; }
@keyframes belt{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@keyframes bob{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-4px); } }

/* ---------- Card grids ---------- */
.grid{ display:grid; gap:22px; }
.grid--2{ grid-template-columns:repeat(2,1fr); }
.grid--3{ grid-template-columns:repeat(3,1fr); }
.grid--4{ grid-template-columns:repeat(4,1fr); }

.card{
  background:var(--card);
  border-radius:var(--r-lg);
  padding:30px 28px;
  box-shadow:var(--shadow-card);
  border:1px solid rgba(44,26,14,.05);
  transition:transform .45s var(--pop), box-shadow .45s var(--pop);
}
.card:hover{
  transform:translateY(-7px) rotate(-.4deg);
  box-shadow:var(--shadow-pop);
}
.card-emoji{
  width:62px; height:62px;
  border-radius:20px;
  background:var(--milk-2);
  display:flex; align-items:center; justify-content:center;
  font-size:1.9rem;
  margin-bottom:18px;
  transition:transform .45s var(--pop), background .3s var(--ease);
}
.card:hover .card-emoji{
  transform:rotate(-10deg) scale(1.12);
  background:var(--butter-soft);
}
.card h3{ margin-bottom:8px; }
.card p{ color:var(--cocoa-soft); font-size:.98rem; }
.card-link{
  display:inline-flex; align-items:center; gap:7px;
  margin-top:16px;
  font-family:var(--font-display); font-weight:700; font-size:.95rem;
  color:var(--jam);
}
.card-link .arr{ transition:transform .35s var(--pop); }
.card:hover .card-link .arr{ transform:translateX(5px); }

.card--butter{ background:var(--butter); border:none; }
.card--butter p{ color:rgba(44,26,14,.74); }
.card--butter .card-emoji{ background:rgba(255,248,238,.6); }

/* ---------- USP rows ---------- */
.usp{
  display:grid;
  grid-template-columns:84px 1fr;
  gap:24px;
  align-items:start;
  padding:30px 0;
  border-bottom:1px dashed var(--line);
}
.usp:last-child{ border-bottom:none; }
.usp-num{
  font-family:var(--font-mono);
  font-weight:600; font-size:.85rem;
  color:var(--crust);
  background:var(--milk-2);
  border-radius:14px;
  width:66px; height:66px;
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:2px;
}
.usp-num em{ font-style:normal; font-size:1.5rem; line-height:1; }
.usp h3{ margin-bottom:8px; font-size:1.45rem; }
.usp p{ color:var(--cocoa-soft); max-width:640px; }

/* ---------- Dark band ---------- */
.band{
  background:var(--cocoa);
  color:var(--milk);
  border-radius:40px;
  padding:74px 8%;
  position:relative;
  overflow:hidden;
}
.band .eyebrow{ color:var(--butter); }
.band .eyebrow::before{ background:var(--jam); }
.band .lede{ color:rgba(255,248,238,.72); }
.band::after{
  content:"";
  position:absolute;
  width:420px; aspect-ratio:1;
  right:-140px; bottom:-200px;
  background:radial-gradient(circle, rgba(247,192,74,.28), transparent 70%);
  border-radius:50%;
}
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; margin-top:48px; position:relative; z-index:1; }
.step{
  background:rgba(255,248,238,.06);
  border:1px solid rgba(255,248,238,.14);
  border-radius:var(--r-md);
  padding:28px 24px;
  transition:transform .45s var(--pop), background .3s var(--ease);
}
.step:hover{ transform:translateY(-6px); background:rgba(255,248,238,.1); }
.step-k{
  font-family:var(--font-mono); font-weight:600; font-size:.78rem;
  letter-spacing:.14em;
  color:var(--butter);
  display:block; margin-bottom:14px;
}
.step h3{ color:var(--milk); margin-bottom:8px; }
.step p{ color:rgba(255,248,238,.68); font-size:.96rem; }

/* ---------- Stats ---------- */
.stats{
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:22px; text-align:center;
}
.stat-num{
  font-family:var(--font-display);
  font-weight:800;
  font-size:clamp(2.3rem, 4.5vw, 3.4rem);
  line-height:1;
  color:var(--cocoa);
}
.stat-num .unit{ color:var(--jam); }
.stat-label{
  font-family:var(--font-mono);
  font-size:.76rem; font-weight:500;
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--cocoa-soft);
  margin-top:10px;
}

/* ---------- Split teaser ---------- */
.split{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:54px;
  align-items:center;
}
.split-art{
  background:linear-gradient(135deg, var(--butter-soft), var(--butter) 55%, #EFA93C);
  border-radius:40px;
  min-height:380px;
  display:flex; align-items:center; justify-content:center;
  position:relative;
  overflow:hidden;
}
.split-art .big-emoji{
  font-size:7.5rem;
  filter:drop-shadow(0 18px 26px rgba(44,26,14,.22));
  animation:bob 4s ease-in-out infinite;
}
.split-art .chip{
  position:absolute;
  background:var(--milk);
  border-radius:var(--r-pill);
  padding:10px 18px;
  font-family:var(--font-display); font-weight:700; font-size:.9rem;
  box-shadow:var(--shadow-card);
  animation:bob 5s ease-in-out infinite;
}
.split-art .chip--a{ top:13%; left:9%; transform:rotate(-5deg); }
.split-art .chip--b{ bottom:15%; right:8%; transform:rotate(4deg); animation-delay:-2.5s; }
.split-list{ margin-top:22px; display:grid; gap:13px; }
.split-list li{
  display:flex; gap:12px; align-items:flex-start;
  color:var(--cocoa-soft);
}
.split-list .tick{
  flex:none; width:24px; height:24px; margin-top:2px;
  border-radius:8px;
  background:var(--butter);
  color:var(--cocoa);
  display:flex; align-items:center; justify-content:center;
  font-size:.8rem; font-weight:800;
}

/* ---------- FAQ ---------- */
.faq{ max-width:780px; margin-inline:auto; display:grid; gap:14px; }
.faq details{
  background:var(--card);
  border:1px solid rgba(44,26,14,.06);
  border-radius:var(--r-md);
  box-shadow:var(--shadow-card);
  overflow:hidden;
  transition:transform .35s var(--pop);
}
.faq details[open]{ transform:scale(1.012); }
.faq summary{
  list-style:none;
  display:flex; justify-content:space-between; align-items:center; gap:16px;
  padding:21px 24px;
  font-family:var(--font-display); font-weight:700; font-size:1.06rem;
  cursor:pointer;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq .plus{
  flex:none; width:30px; height:30px;
  border-radius:10px;
  background:var(--milk-2);
  color:var(--crust);
  display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:1.1rem;
  transition:transform .4s var(--pop), background .25s var(--ease);
}
.faq details[open] .plus{
  transform:rotate(135deg);
  background:var(--jam); color:#FFF6EC;
}
.faq .faq-a{
  padding:0 24px 22px;
  color:var(--cocoa-soft);
  font-size:.98rem;
}

/* ---------- CTA band ---------- */
.cta-band{
  background:linear-gradient(120deg, var(--butter-soft), var(--butter) 60%);
  border-radius:40px;
  padding:70px 8%;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.cta-band::before,
.cta-band::after{
  content:"";
  position:absolute;
  width:240px; aspect-ratio:1;
  border-radius:48% 52% 56% 44% / 52% 44% 56% 48%;
  background:rgba(255,248,238,.4);
}
.cta-band::before{ left:-100px; top:-100px; }
.cta-band::after{ right:-90px; bottom:-110px; background:rgba(192,103,34,.16); }
.cta-band h2{ position:relative; z-index:1; max-width:640px; margin:0 auto 14px; }
.cta-band p{ position:relative; z-index:1; color:rgba(44,26,14,.72); max-width:520px; margin:0 auto 30px; }
.cta-band .hero-ctas{ justify-content:center; margin-bottom:0; position:relative; z-index:1; }

.cta-phone{
  display:block;
  font-family:var(--font-mono); font-weight:600;
  font-size:.92rem; letter-spacing:.04em;
  color:var(--cocoa);
  margin-top:24px;
  position:relative; z-index:1;
}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{
  padding:78px 0 64px;
  position:relative;
  overflow:hidden;
}
.page-hero .hero-blob{ width:440px; right:-180px; top:-160px; opacity:.65; }
.page-hero h1{ font-size:clamp(2.4rem, 5.4vw, 4rem); margin-bottom:18px; max-width:760px; position:relative; z-index:1; }
.page-hero .lede{ position:relative; z-index:1; }
.crumb{
  position:relative; z-index:1;
  font-family:var(--font-mono); font-size:.76rem; font-weight:500;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--cocoa-soft);
  margin-bottom:22px;
  display:flex; gap:8px; flex-wrap:wrap;
}
.crumb a:hover{ color:var(--jam); }

/* ---------- Product catalogue ---------- */
.prod-cat{
  background:var(--card);
  border:1px solid rgba(44,26,14,.05);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-card);
  padding:38px 36px;
  margin-bottom:26px;
  transition:transform .45s var(--pop), box-shadow .45s var(--pop);
}
.prod-cat:hover{ transform:translateY(-4px); box-shadow:var(--shadow-pop); }
.prod-cat-head{
  display:flex; gap:20px; align-items:flex-start;
  margin-bottom:22px;
}
.prod-cat-head .card-emoji{ margin-bottom:0; }
.prod-cat-head h3{ font-size:1.55rem; margin-bottom:6px; }
.prod-cat-head p{ color:var(--cocoa-soft); max-width:620px; }
.spec-row{ display:flex; flex-wrap:wrap; gap:10px; }
.spec{
  font-family:var(--font-mono);
  font-size:.83rem; font-weight:500;
  background:var(--milk-2);
  border:1px solid rgba(192,103,34,.16);
  color:var(--cocoa);
  border-radius:var(--r-pill);
  padding:9px 16px;
  transition:transform .3s var(--pop), background .2s var(--ease), border-color .2s var(--ease);
}
.spec:hover{
  transform:translateY(-3px) rotate(-1deg);
  background:var(--butter-soft);
  border-color:var(--crust);
}
.spec b{ font-weight:700; }
.prod-use{
  margin-top:20px;
  padding:14px 18px;
  border-left:4px solid var(--butter);
  background:var(--milk);
  border-radius:0 14px 14px 0;
  font-size:.94rem;
  color:var(--cocoa-soft);
}
.prod-use b{ color:var(--cocoa); }

/* ---------- Prose (about) ---------- */
.prose{ max-width:740px; }
.prose p{ margin-bottom:20px; color:var(--cocoa-soft); font-size:1.05rem; }
.prose p b, .prose p strong{ color:var(--cocoa); }
.prose h2{ margin-top:54px; }
.prose .eyebrow{ margin-top:8px; }
.callout{
  background:var(--milk-2);
  border:1px dashed rgba(192,103,34,.4);
  border-radius:var(--r-md);
  padding:24px 26px;
  margin:30px 0;
  font-size:1rem;
  color:var(--cocoa-soft);
}
.callout b{ color:var(--cocoa); }

/* ---------- Contact ---------- */
.contact-card{
  text-align:center;
  display:flex; flex-direction:column; align-items:center;
}
.contact-card .card-emoji{ margin-inline:auto; }
.contact-card a.big{
  font-family:var(--font-display); font-weight:800; font-size:1.3rem;
  color:var(--cocoa);
  transition:color .2s var(--ease);
}
.contact-card a.big:hover{ color:var(--jam); }
.map-wrap{
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--shadow-card);
  border:1px solid rgba(44,26,14,.06);
  line-height:0;
}
.map-wrap iframe{ width:100%; height:430px; border:0; }

/* ---------- WhatsApp float ---------- */
.wa-float{
  position:fixed;
  right:20px; bottom:20px;
  z-index:80;
  display:flex; align-items:center; gap:10px;
  background:var(--wa);
  color:#fff;
  font-family:var(--font-display); font-weight:700; font-size:.95rem;
  padding:14px 20px;
  border-radius:var(--r-pill);
  box-shadow:0 10px 26px rgba(31,168,85,.42);
  transition:transform .4s var(--pop), box-shadow .4s var(--pop);
}
.wa-float:hover{
  transform:translateY(-4px) scale(1.04);
  box-shadow:0 16px 36px rgba(31,168,85,.5);
}
.wa-float svg{ width:21px; height:21px; flex:none; }

/* ---------- Footer ---------- */
.footer{
  background:var(--cocoa);
  color:rgba(255,248,238,.78);
  margin-top:90px;
  padding:70px 0 0;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1.2fr;
  gap:40px;
  padding-bottom:50px;
}
.footer .brand-name{ color:var(--milk); }
.footer-blurb{ margin-top:16px; font-size:.95rem; max-width:300px; color:rgba(255,248,238,.62); }
.footer h4{
  font-family:var(--font-mono);
  font-size:.76rem; font-weight:600;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--butter);
  margin-bottom:18px;
}
.footer-links li{ margin-bottom:11px; }
.footer-links a{
  font-size:.96rem;
  transition:color .2s var(--ease), padding-left .3s var(--pop);
}
.footer-links a:hover{ color:var(--butter); padding-left:5px; }
.footer-contact li{
  margin-bottom:12px; font-size:.95rem;
  display:flex; gap:10px; align-items:flex-start;
}
.footer-contact .k{
  font-family:var(--font-mono); font-size:.72rem; font-weight:600;
  letter-spacing:.1em; color:var(--butter);
  margin-top:4px; flex:none; width:52px;
}
.footer-contact a:hover{ color:var(--butter); }
.footer-bottom{
  border-top:1px solid rgba(255,248,238,.12);
  padding:24px 0;
  display:flex; justify-content:space-between; align-items:center; gap:14px; flex-wrap:wrap;
  font-family:var(--font-mono);
  font-size:.74rem; letter-spacing:.05em;
  color:rgba(255,248,238,.45);
}

/* ---------- Reveal animations ---------- */
.rv{
  opacity:0;
  transform:translateY(26px) scale(.985);
  transition:opacity .55s var(--ease), transform .6s var(--pop);
  transition-delay:var(--d, 0s);
}
.rv.in{ opacity:1; transform:translateY(0) scale(1); }

/* ---------- Responsive ---------- */
@media (max-width: 1020px){
  .grid--4{ grid-template-columns:repeat(2,1fr); }
  .grid--3{ grid-template-columns:repeat(2,1fr); }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .split{ grid-template-columns:1fr; gap:34px; }
  .split-art{ min-height:300px; }
  .steps{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:repeat(2,1fr); gap:34px 18px; }
}
@media (max-width: 760px){
  body{ font-size:16px; }
  .section{ padding:60px 0; }
  .nav-links{ display:none; }
  .nav-toggle{ display:flex; }
  .grid--2, .grid--3{ grid-template-columns:1fr; }
  .hero{ padding:64px 0 84px; }
  .hero-blob{ right:-220px; top:-60px; opacity:.55; }
  .band{ padding:54px 7%; border-radius:30px; }
  .cta-band{ padding:54px 7%; border-radius:30px; }
  .usp{ grid-template-columns:1fr; gap:14px; }
  .prod-cat{ padding:28px 22px; }
  .prod-cat-head{ flex-direction:column; gap:14px; }
  .footer-grid{ grid-template-columns:1fr; gap:34px; }
  .wa-float span{ display:none; }
  .wa-float{ padding:16px; }
  .map-wrap iframe{ height:320px; }
}
@media (max-width: 460px){
  .grid--4{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:1fr 1fr; }
  .hero-ctas .btn{ width:100%; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
  }
  html{ scroll-behavior:auto; }
  .rv{ opacity:1; transform:none; }
  .conveyor-track{ animation:none; }
}
