/* ============ RESET / TOKENS ============ */
:root{
  /* brand color */
  --red:#d81f26;
  --red-dark:#b3131a;
  --red-deep:#9c1119;
  --ink:#161616;
  --gray:#4a4a4a;
  --gray-soft:#6b6b6b;
  --soft:#f2f2f2;
  --line:#e6e6e6;

  /* spacing scale (8px base) */
  --s-1:8px;  --s-2:16px; --s-3:24px; --s-4:32px; --s-5:40px;
  --s-6:48px; --s-8:64px; --s-10:80px; --s-12:96px; --s-14:112px; --s-16:128px;

  /* container width — fluid, grows on large screens */
  --container:1180px;

  /* semantic spacing — fluid via clamp(min, vw, max) */
  --section-pad:clamp(96px, 8vw, 168px);
  --section-pad-lg:clamp(128px, 10vw, 220px);
  --head-gap:clamp(64px, 5vw, 104px);
  --gutter:clamp(40px, 5vw, 96px);
  --rail:calc(50% - (var(--container) / 2) + var(--gutter)); /* container gutter line */

  /* motion + elevation */
  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow-sm:0 4px 12px rgba(22,22,22,.08);
  --shadow-md:0 12px 28px rgba(22,22,22,.10);
  --shadow-red:0 10px 24px rgba(216,31,38,.30);
  --shadow-red-lg:0 18px 40px rgba(216,31,38,.34);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:"Montserrat",Arial,sans-serif;
  color:var(--ink);
  background:#fff;
  overflow-x:hidden;
  font-size:16px;
  line-height:1.65;
}
h1,h2,h3,.head{font-family:"Anton","Montserrat",sans-serif;font-weight:400;letter-spacing:.25px;line-height:1.0}
a{text-decoration:none;color:inherit}
.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
img,svg{display:block}

/* ============ BRAND SHAPE (signature container) ============
   3 large rounded corners + 1 sharp corner at bottom-right.
   --bs = signature radius; applied to all main cards & blocks. */
:root{ --bs:34px; --bs-lg:56px; }
.story-card,.works-photo,.prod,.cap,.flow-step,.cert,.oc-card,
.bs-card,.feature-img,.feature-card,.taste-card,.assure .split-media,
.split .split-media,.oa-card,.brand-card{
  border-radius:var(--bs) var(--bs) 0 var(--bs) !important;
}
/* larger blocks get the bigger signature radius */
.feature-img,.feature-card,.oc-card,.assure .split-media,.split .split-media,.story-card{
  border-radius:var(--bs-lg) var(--bs-lg) 0 var(--bs-lg) !important;
}

/* ============ BUTTONS ============ */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  font-family:"Montserrat";font-weight:700;font-size:12px;letter-spacing:1.5px;
  text-transform:uppercase;padding:14px 30px;border-radius:40px;cursor:pointer;
  border:2px solid transparent;will-change:transform;
  transition:transform .28s var(--ease), box-shadow .28s var(--ease),
             background-color .2s ease, color .2s ease, border-color .2s ease;
}
.btn.sm{padding:11px 24px;font-size:11px}
.btn-solid{background:var(--red);color:#fff;box-shadow:var(--shadow-red)}
.btn-solid:hover{background:var(--red-dark);transform:translateY(-3px);box-shadow:var(--shadow-red-lg)}
.btn-solid:active{transform:translateY(-1px);box-shadow:var(--shadow-red)}
.btn-ghost{border-color:#fff;color:#fff;background:transparent}
.btn-ghost:hover{background:#fff;color:var(--red);transform:translateY(-3px);box-shadow:0 14px 30px rgba(0,0,0,.22)}
.btn-ghost:active{transform:translateY(-1px)}
.btn:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(255,255,255,.6),var(--shadow-red)}

/* ============ HEADER — FLOATING CENTER RIBBON ============ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;justify-content:center;
  padding:20px var(--gutter) 0;
  transition:padding .3s ease;
  pointer-events:none; /* let hero clicks pass through the transparent gaps; ribbon re-enables */
}
/* the ribbon bar itself — a contained centered bar, NOT full width.
   Grid keeps the logo dead-center: equal side columns flank the auto logo. */
.ribbon{
  pointer-events:auto;position:relative;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  width:auto;max-width:calc(100% - 140px);
  height:60px;padding:0 44px;
  /* brand-red gradient gives depth */
  background:linear-gradient(180deg,#bf161d 0%,#9c1119 100%);
  box-shadow:0 8px 20px rgba(0,0,0,.22);
  transition:height .3s ease, box-shadow .3s ease;
}
/* notched ribbon tails (left & right) — larger, with a fishtail clip */
.ribbon::before,.ribbon::after{
  content:"";position:absolute;top:0;width:64px;height:60px;
  background:linear-gradient(180deg,#a4121a 0%,#840d13 100%);
  filter:drop-shadow(0 4px 8px rgba(0,0,0,.18));
  transition:height .3s ease;
}
/* fishtail: outer edge notched inward, inner edge straight (tucks under the bar) */
.ribbon::before{left:-58px;clip-path:polygon(0 50%, 38% 0, 100% 0, 100% 100%, 38% 100%)}
.ribbon::after{right:-58px;clip-path:polygon(0 0, 62% 0, 100% 50%, 62% 100%, 0 100%)}
/* small folded corners under the tails for depth */
.ribbon .fold-l,.ribbon .fold-r{position:absolute;bottom:-10px;width:22px;height:12px;background:#6e0a10;z-index:-1}
.ribbon .fold-l{left:-22px;clip-path:polygon(0 0,100% 0,100% 100%)}
.ribbon .fold-r{right:-22px;clip-path:polygon(0 0,100% 0,0 100%)}

.site-header.scrolled{padding-top:12px}
.site-header.scrolled .ribbon{height:54px;box-shadow:0 6px 18px rgba(0,0,0,.26)}
.site-header.scrolled .ribbon::before,.site-header.scrolled .ribbon::after{height:54px}

/* nav split into two halves around the centered logo, with clear breathing room.
   Inner padding keeps text off the logo; grid 1fr columns keep the logo centered. */
.main-nav{display:flex;align-items:center;gap:clamp(22px,2vw,40px)}
.main-nav.nav-left{justify-content:flex-end;padding-right:48px}
.main-nav.nav-right{justify-content:flex-start;padding-left:48px}
.main-nav a{
  color:#fff;font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;
  opacity:.9;position:relative;padding:4px 0;transition:opacity .2s ease;white-space:nowrap;
}
.main-nav a:hover,.main-nav a.active{opacity:1}
.main-nav a::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:2px;background:#fff;border-radius:2px;transition:width .28s var(--ease)}
.main-nav a:hover::after,.main-nav a.active::after{width:100%}

/* center logo — raised above the ribbon, shows the bean mark filling the circle */
.logo{flex:none;display:flex;align-items:center;justify-content:center;line-height:0;transition:transform .25s var(--ease);
  width:74px;height:74px;border-radius:50%;background:var(--red);box-shadow:0 8px 20px rgba(0,0,0,.24);
  margin-top:-18px;border:4px solid #fff;overflow:hidden}
.logo:hover{transform:scale(1.06)}
.logo-img{width:100%;height:100%;display:block;object-fit:cover;transition:transform .3s ease;filter:drop-shadow(0 2px 6px rgba(0,0,0,.12))}
.site-header.scrolled .logo{width:66px;height:66px;margin-top:-15px}

.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;pointer-events:auto}
.nav-toggle span{width:26px;height:3px;background:#fff;border-radius:2px;transition:.3s}

/* ============ HERO — giant wordmark behind product ============ */
.hero{position:relative;background:radial-gradient(120% 100% at 50% 30%, #e22128 0%, var(--red) 42%, #9c1119 100%);
  min-height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center}

/* the big flowing brand name sitting behind everything */
.hero-wordmark{
  position:absolute;top:48%;left:50%;transform:translate(-50%,-50%);z-index:1;
  font-family:"Pacifico",cursive;white-space:nowrap;line-height:.8;
  font-size:clamp(120px, 24vw, 460px);
  color:#fce9e3;opacity:.2;letter-spacing:-2px;pointer-events:none;user-select:none;
  text-shadow:0 4px 40px rgba(0,0,0,.12);
}
.hero-wordmark .wm-2{color:#fff;opacity:.85}

/* hero object (cappuccino splash), centered on top of the wordmark */
.hero-stage{position:relative;z-index:2;display:grid;place-items:center;padding-top:40px}
.hero-products{
  max-height:clamp(420px, 78vh, 820px);width:auto;max-width:86vw;
  filter:drop-shadow(0 36px 50px rgba(0,0,0,.4));
  animation:floatY 6s ease-in-out infinite;
}

/* lower-right blurb + read more (sits above the bottom controls) */
.hero-blurb{position:absolute;z-index:3;right:var(--gutter);bottom:210px;max-width:clamp(280px,28vw,440px);text-align:right;color:#fff}
.hero-blurb p{font-size:clamp(14px,1.05vw,18px);line-height:1.6;color:rgba(255,255,255,.92);margin-bottom:16px;font-weight:500}
.hero-readmore{display:inline-flex;align-items:center;gap:8px;font-family:"Montserrat";font-weight:700;font-size:13px;letter-spacing:2px;text-transform:uppercase;color:#fff;transition:gap .25s var(--ease),opacity .2s ease}
.hero-readmore span{transition:transform .25s var(--ease)}
.hero-readmore:hover{opacity:.85}
.hero-readmore:hover span{transform:translateX(5px)}

/* bottom-left social */
.hero-social{position:absolute;z-index:5;left:var(--gutter);bottom:140px;display:flex;align-items:center;gap:14px;color:#fff}
.hero-social a{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;border:1.5px solid rgba(255,255,255,.5);transition:.22s var(--ease)}
.hero-social a:hover{background:#fff;color:var(--red);transform:translateY(-3px);border-color:#fff}
.hero-social a svg{width:18px;height:18px}

/* bottom-right prev/next */
.hero-arrows{position:absolute;z-index:5;right:var(--gutter);bottom:140px;display:flex;gap:12px}
.hero-arrows button{width:46px;height:46px;border-radius:50%;border:1.5px solid rgba(255,255,255,.5);background:transparent;color:#fff;cursor:pointer;display:grid;place-items:center;transition:.22s var(--ease)}
.hero-arrows button:hover{background:#fff;color:var(--red);transform:translateY(-3px);border-color:#fff}
.hero-arrows svg{width:20px;height:20px}

/* waves */
.wave{position:absolute;left:0;width:100%;height:120px;z-index:4}
.wave-bottom{bottom:-1px}
.wave-top{top:-1px}

/* ============ SECTION NUMBER BADGES ============ */
.sec-badge{
  position:absolute;z-index:8;width:52px;height:52px;border-radius:50%;
  background:linear-gradient(150deg,var(--red) 0%,var(--red-dark) 100%);
  color:#fff;font-family:"Anton";font-size:19px;display:grid;place-items:center;
  box-shadow:0 10px 24px rgba(216,31,38,.34);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.sec-badge::before{content:"";position:absolute;inset:-6px;border-radius:50%;border:1px solid rgba(216,31,38,.28)}
.sec-badge:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 16px 32px rgba(216,31,38,.42)}
.sec-badge.left{left:var(--rail);top:64px}
.sec-badge.right{right:var(--rail);top:64px}

/* ============ SECTION 01 ABOUT ============ */
.sec-about{position:relative;padding:var(--section-pad) 0;background:#fff}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-5);align-items:center}
.about-left{padding-top:48px}
.eyebrow{font-family:"Montserrat";font-weight:700;font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--red);margin-bottom:16px}
.eyebrow span{font-family:"Montserrat"}
.about-left h2{font-size:clamp(30px, 3vw, 56px);line-height:1.0;margin-bottom:18px}
.about-left h2 em{color:var(--red);font-style:normal}
.muted{color:var(--gray);font-size:clamp(16px, 1.05vw, 19px);line-height:1.65;max-width:clamp(420px, 32vw, 560px);margin-bottom:24px}
.about-right{position:relative;display:grid;place-items:center}
.story-card{position:relative;width:100%;border-radius:18px;overflow:hidden;box-shadow:0 26px 50px rgba(0,0,0,.22)}
.story-card img{width:100%;height:auto;display:block}
.story-tag{position:absolute;left:16px;bottom:16px;background:var(--red);color:#fff;font-family:"Anton";font-size:16px;letter-spacing:.5px;padding:10px 16px;border-radius:10px;box-shadow:var(--shadow-red);line-height:1.1}
.story-tag small{display:block;font-family:"Montserrat";font-weight:600;font-size:10px;letter-spacing:1px;text-transform:uppercase;opacity:.9;margin-top:3px}

/* ============ SECTION 02 WORKS ============ */
.sec-works{position:relative;padding:var(--section-pad) 0;background:#fff}
.center-head{text-align:center;font-size:clamp(28px, 3vw, 56px);line-height:1.0;letter-spacing:.25px;margin:0 0 var(--head-gap)}
.center-head span{color:var(--red)}
.works-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-8);align-items:center}
.works-art{position:relative;display:flex;align-items:center;justify-content:center}
.works-photo{position:relative;width:100%;max-width:480px;border-radius:16px;overflow:hidden;box-shadow:0 24px 50px rgba(0,0,0,.2);transform:rotate(-2deg)}
.works-photo img{width:100%;height:auto;display:block}
.works-badge{position:absolute;left:16px;bottom:16px;background:#fff;color:var(--red);font-family:"Anton";font-size:16px;letter-spacing:.5px;padding:10px 16px;border-radius:10px;box-shadow:0 10px 24px rgba(0,0,0,.18);line-height:1.1}
.works-badge small{display:block;font-family:"Montserrat";font-weight:600;font-size:10px;letter-spacing:.5px;text-transform:uppercase;color:var(--gray-soft);margin-top:3px}
.works-steps{display:grid;grid-template-columns:1fr 42px;gap:48px;align-items:start}
.step-content h3{color:var(--red);font-size:clamp(26px, 2vw, 36px);line-height:1.05;margin-bottom:14px}
.step-content p{color:var(--gray);font-size:clamp(16px, 1.05vw, 19px);line-height:1.65;margin-bottom:24px}
.step-dots{position:relative;list-style:none;display:flex;flex-direction:column;gap:22px}
.step-dots::before{content:"";position:absolute;left:50%;top:18px;bottom:18px;width:2px;transform:translateX(-50%);background:var(--line);z-index:0}
.step-dots li{
  position:relative;z-index:1;width:42px;height:42px;border-radius:50%;
  border:2px solid var(--red);color:var(--red);background:#fff;display:grid;place-items:center;font-weight:800;cursor:pointer;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), background .25s ease, color .25s ease;
}
.step-dots li:hover{transform:scale(1.08);box-shadow:0 6px 16px rgba(216,31,38,.22)}
.step-dots li.active{background:var(--red);color:#fff;transform:scale(1.12);box-shadow:0 10px 22px rgba(216,31,38,.36)}
.step-dots li.active::after{content:"";position:absolute;inset:-5px;border-radius:50%;border:2px solid rgba(216,31,38,.30);animation:stepPulse 2s var(--ease) infinite}

/* ============ RANGE / SLIDER ============ */
.sec-range{padding:var(--section-pad) 0;background:#fff}
.slider-wrap{position:relative}
.slider{display:flex;gap:var(--s-3);overflow-x:auto;overflow-y:hidden;overscroll-behavior:contain;
  scroll-snap-type:x mandatory;scroll-behavior:smooth;
  padding:6px 2px 24px;margin:-6px -2px 0;
  scrollbar-width:none;-ms-overflow-style:none}
.slider::-webkit-scrollbar{display:none}
.slider .brand-card{scroll-snap-align:start;flex:0 0 calc((100% - 2 * var(--s-3)) / 3)} /* 3 cards per view on desktop */
.brand-card{
  position:relative;overflow:hidden;isolation:isolate;height:340px;
  background:linear-gradient(160deg,#fff 0%,#fafafa 100%);
  border:1px solid var(--line);border-radius:18px;
  display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:10px;padding:26px 18px 24px;
  box-shadow:var(--shadow-sm);color:inherit;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .3s ease, background .35s ease;
}
.brand-card::before{content:"";position:absolute;inset:0;z-index:-1;opacity:0;
  background:radial-gradient(120% 80% at 50% 0%, rgba(216,31,38,.07), transparent 70%);transition:opacity .35s ease}
.brand-card::after{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:0;height:4px;border-radius:0 0 6px 6px;background:var(--red);transition:width .35s var(--ease)}
.brand-card:hover{transform:translateY(-10px);border-color:transparent;box-shadow:var(--shadow-red-lg)}
.brand-card:hover::before{opacity:1}
.brand-card:hover::after{width:56px}
.bc-shot{flex:1;display:grid;place-items:center;width:100%;min-height:0}
.bc-shot img{max-height:210px;max-width:96%;width:auto;object-fit:contain;filter:drop-shadow(0 16px 22px rgba(0,0,0,.18));transition:transform .35s var(--ease)}
.brand-card:hover .bc-shot img{transform:scale(1.07) translateY(-3px)}
.bc-logo{font-family:"Anton";font-size:23px;color:var(--ink);transition:color .25s ease;margin-top:4px}
.brand-card:hover .bc-logo{color:var(--red)}
.brand-card span{font-size:11px;color:var(--gray);letter-spacing:.5px;text-align:center}

.slider-controls{display:flex;align-items:center;justify-content:center;gap:20px;margin-top:var(--s-6)}
.slider-bar{position:relative;flex:1;max-width:520px;height:4px;background:var(--line);border-radius:99px;overflow:hidden}
.slider-bar span{display:block;height:100%;width:38%;border-radius:99px;
  background:linear-gradient(90deg,var(--red),var(--red-dark));box-shadow:0 0 12px rgba(216,31,38,.45);
  transition:width .45s var(--ease), margin-left .45s var(--ease)}
.slide-next{
  flex:0 0 auto;width:46px;height:46px;border-radius:50%;
  border:2px solid var(--line);background:#fff;color:var(--red);cursor:pointer;display:grid;place-items:center;
  box-shadow:var(--shadow-sm);
  transition:transform .28s var(--ease), box-shadow .28s var(--ease), background .2s ease, color .2s ease, border-color .2s ease;
}
.slide-next svg{width:20px;height:20px}
.slide-next:hover{background:var(--red);color:#fff;border-color:var(--red);transform:translateY(-3px) scale(1.06);box-shadow:var(--shadow-red)}
.slide-next:active{transform:translateY(-1px) scale(1.02)}
.slide-next:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(216,31,38,.35)}

/* ============ BANNER ============ */
.sec-banner{position:relative;text-align:center;padding:var(--s-10) 0 calc(var(--s-10) + 70px);margin-bottom:-1px;overflow:hidden;
  background:url("assets/backgrounds/golden-white-marble-textured-background-design-resource.jpg") center/cover no-repeat}
.banner-pattern{position:absolute;inset:0;background:rgba(251,246,239,.82);backdrop-filter:saturate(108%)}
.sec-banner h2{position:relative;font-size:clamp(26px, 2.4vw, 44px);letter-spacing:.25px}
.sec-banner p{position:relative;color:var(--gray-soft);font-weight:700;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;margin-top:10px}

/* ============ BIG CTA ============ */
.sec-cta{position:relative;background:var(--red);padding:var(--section-pad-lg) 0;overflow:hidden}
.cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-5);align-items:center;position:relative;z-index:3}
.cta-art{position:relative;display:grid;place-items:center}
.cta-products{max-height:clamp(360px, 38vw, 620px);width:auto;max-width:100%;filter:drop-shadow(0 24px 34px rgba(0,0,0,.34));animation:floatY 6s ease-in-out infinite .4s}
.cta-copy h2{color:#fff;font-size:clamp(34px, 3vw, 56px);line-height:1.0}
.cta-copy h2 .xl{font-size:clamp(52px, 5.4vw, 100px);line-height:.96;text-transform:uppercase;letter-spacing:0;display:block;margin-top:6px}
.cta-copy p{color:rgba(255,255,255,.85);max-width:clamp(420px, 32vw, 560px);margin:var(--s-3) 0 var(--s-5);font-size:clamp(16px, 1.05vw, 19px);line-height:1.65}
.store-btns{display:flex;gap:14px;flex-wrap:wrap}
.store-btn{display:inline-flex;align-items:center;gap:12px;background:#fff;color:var(--ink);border-radius:14px;padding:12px 20px;box-shadow:0 12px 26px rgba(0,0,0,.2);transition:transform .28s var(--ease),box-shadow .28s var(--ease)}
.store-btn:hover{transform:translateY(-3px);box-shadow:0 18px 34px rgba(0,0,0,.28)}
.store-btn img{width:34px;height:34px;object-fit:contain}
.store-btn span{font-size:11px;line-height:1.2;letter-spacing:.5px;text-transform:uppercase;color:var(--gray-soft)}
.store-btn b{font-family:"Anton";font-weight:400;font-size:17px;letter-spacing:.5px;color:var(--ink);text-transform:none}

/* ============ FOOTER ============ */
.site-footer{background:#fff;padding:var(--s-10) 0 0;border-top:1px solid var(--line)}
.foot-brand{display:flex;flex-direction:column;align-items:flex-start;gap:14px;margin-bottom:var(--s-6)}
.foot-brand .foot-logo{height:72px;width:auto;display:block}
.foot-brand p{color:var(--gray);font-size:13.5px;max-width:340px;margin:0}
.foot-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-4)}
.site-footer h4{font-size:12px;letter-spacing:1.5px;color:var(--ink);margin-bottom:16px;font-family:"Montserrat";font-weight:700;text-transform:uppercase}
.site-footer a{display:block;color:var(--gray);font-size:13px;font-weight:500;line-height:1.55;margin-bottom:9px;transition:.2s}
.site-footer a:hover{color:var(--red)}
.site-footer a.on{color:var(--red)}
.foot-social{text-align:left}
.fs-icons{display:flex;gap:12px}
.fs-icons a{width:38px;height:38px;border-radius:50%;background:var(--ink);color:#fff!important;display:grid;place-items:center;margin:0;transition:.2s var(--ease)}
.fs-icons a svg{width:18px;height:18px}
.fs-icons a:hover{background:var(--red);transform:translateY(-2px)}
.foot-demo .btn{margin-bottom:16px}
.foot-stores{display:flex;gap:12px;margin-bottom:18px}
.foot-stores a{width:46px;height:46px;border-radius:12px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;transition:.25s var(--ease)}
.foot-stores a:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:transparent}
.foot-stores img{width:26px;height:26px;object-fit:contain}
.contact-line{display:flex;align-items:center;gap:9px;font-size:12px;font-weight:600;letter-spacing:.8px;color:var(--gray-soft);margin-bottom:9px;text-transform:none}
.contact-line .cl-ic{width:16px;height:16px;object-fit:contain;opacity:.85}
.copyright{text-align:center;border-top:1px solid var(--line);margin-top:var(--s-6);padding:24px;font-size:11px;color:#999}

/* ============ SUB-PAGE HERO (about / products / oem / certifications) ============ */
.page-hero{position:relative;background:radial-gradient(120% 130% at 50% 0%, #e22128 0%, var(--red) 48%, #9c1119 100%);
  padding:calc(var(--s-16) + 60px) 0 var(--s-14);overflow:hidden;text-align:center}
.page-hero .container{position:relative;z-index:2}
.page-hero .ph-mark{position:absolute;inset:0;display:grid;place-items:center;z-index:0;pointer-events:none;
  font-family:"Pacifico",cursive;font-size:clamp(120px,22vw,360px);color:#fff;opacity:.07;white-space:nowrap;line-height:.8}
.page-hero .eyebrow{color:rgba(255,255,255,.85)}
.page-hero h1{font-family:"Anton";color:#fff;font-size:clamp(40px,6vw,96px);line-height:.98;letter-spacing:.5px;margin-bottom:18px}
.page-hero h1 em{color:#ffd9d0;font-style:normal}
.page-hero p.lead{color:rgba(255,255,255,.92);font-size:clamp(15px,1.3vw,20px);font-weight:500;line-height:1.6;max-width:620px;margin:0 auto}
.crumb{display:inline-flex;align-items:center;gap:8px;margin-bottom:22px;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.75)}
.crumb a{color:#fff;opacity:.85;transition:.2s}
.crumb a:hover{opacity:1}
.crumb span{opacity:.5}

/* ============ GENERIC PAGE SECTIONS ============ */
.sec{padding:var(--section-pad) 0;position:relative;background:#fff}
.sec.alt{background:var(--soft)}
.sec-head{text-align:center;max-width:680px;margin:0 auto var(--head-gap)}
.sec-head .eyebrow{display:block}
.sec-head h2{font-size:clamp(28px,3vw,52px);line-height:1.02;margin-bottom:16px}
.sec-head h2 span{color:var(--red)}
.sec-head p{color:var(--gray);font-size:clamp(15px,1.05vw,18px);line-height:1.65}

/* split row (image + text), alternating */
.split{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-8);align-items:center}
.split + .split{margin-top:var(--section-pad)}
.split .split-media{position:relative;border-radius:18px;overflow:hidden;box-shadow:0 26px 50px rgba(0,0,0,.18)}
.split .split-media img{width:100%;height:auto;display:block}
.split.reverse .split-media{order:2}
.split h3{font-size:clamp(24px,2.4vw,40px);line-height:1.05;margin-bottom:16px}
.split h3 em{color:var(--red);font-style:normal}
.split p{color:var(--gray);font-size:clamp(15px,1.05vw,18px);line-height:1.7;margin-bottom:16px}
.split .tag{display:inline-block;font-family:"Montserrat";font-weight:700;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--red);margin-bottom:14px}

/* stat strip */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-4);text-align:center}
.stat{padding:var(--s-3) var(--s-2)}
.stat b{display:block;font-family:"Anton";font-size:clamp(34px,4vw,64px);color:var(--red);line-height:1}
.stat span{display:block;margin-top:8px;font-size:12px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--gray-soft)}

/* ============ PRODUCTS PAGE ============ */
.cat-block{margin-bottom:var(--section-pad)}
.cat-block:last-child{margin-bottom:0}
.cat-head{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--s-3);margin-bottom:var(--s-5);
  border-bottom:2px solid var(--line);padding-bottom:18px}
.cat-head h2{font-size:clamp(24px,2.6vw,42px);line-height:1}
.cat-head h2 small{display:block;font-family:"Montserrat";font-weight:700;font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--red);margin-bottom:8px}
.cat-head .cat-shop{flex:none;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--red);display:inline-flex;align-items:center;gap:6px}
.cat-head .cat-shop:hover{color:var(--red-dark)}
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-3)}
.prod{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px 18px 22px;text-align:center;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .2s ease;display:flex;flex-direction:column}
.prod:hover{transform:translateY(-6px);box-shadow:0 22px 44px rgba(22,22,22,.12);border-color:transparent}
.prod-shot{height:200px;display:grid;place-items:center;margin-bottom:16px}
.prod-shot img{max-height:200px;max-width:90%;width:auto;height:auto;object-fit:contain;filter:drop-shadow(0 14px 24px rgba(0,0,0,.14))}
.prod h4{font-family:"Anton";font-size:18px;letter-spacing:.4px;margin-bottom:4px;line-height:1.1}
.prod .p-sub{font-size:12px;color:var(--gray-soft);font-weight:600;margin-bottom:14px;flex:1}
.prod .p-buy{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--red)}

/* ============ OEM PAGE ============ */
.cap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-4)}
.cap{background:#fff;border:1px solid var(--line);border-radius:18px;padding:34px 28px;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.cap:hover{transform:translateY(-6px);box-shadow:0 22px 44px rgba(22,22,22,.12)}
.cap .cap-ic{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(150deg,var(--red),var(--red-dark));color:#fff;margin-bottom:20px}
.cap .cap-ic svg{width:26px;height:26px}
.cap h4{font-family:"Anton";font-size:21px;letter-spacing:.4px;margin-bottom:10px}
.cap p{color:var(--gray);font-size:15px;line-height:1.65}

/* process timeline */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-3);counter-reset:flow}
.flow-step{position:relative;padding:34px 22px 26px;background:var(--soft);border-radius:18px}
.flow-step::before{counter-increment:flow;content:counter(flow,decimal-leading-zero);font-family:"Anton";font-size:46px;color:var(--red);opacity:.25;line-height:1;display:block;margin-bottom:14px}
.flow-step h4{font-family:"Anton";font-size:19px;margin-bottom:10px}
.flow-step p{color:var(--gray);font-size:14px;line-height:1.6}

/* feature list (checks) */
.checks{display:grid;grid-template-columns:repeat(2,1fr);gap:16px 32px;margin-top:8px}
.checks li{list-style:none;position:relative;padding-left:34px;color:var(--gray);font-size:15px;line-height:1.5;font-weight:500}
.checks li::before{content:"";position:absolute;left:0;top:1px;width:22px;height:22px;border-radius:50%;background:var(--red);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");background-size:14px;background-position:center;background-repeat:no-repeat}

/* ============ CERTIFICATIONS PAGE ============ */
.cert-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-4)}
.cert{background:#fff;border:1px solid var(--line);border-radius:20px;padding:38px 30px;text-align:center;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.cert:hover{transform:translateY(-6px);box-shadow:0 24px 48px rgba(216,31,38,.16)}
.cert .cert-badge{width:96px;height:96px;margin:0 auto 22px;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(150deg,#fff 0%,#fff 100%);border:3px solid var(--red);color:var(--red);
  font-family:"Anton";font-size:26px;letter-spacing:.5px;box-shadow:0 14px 30px rgba(216,31,38,.18)}
.cert h4{font-family:"Anton";font-size:22px;margin-bottom:10px;letter-spacing:.4px}
.cert p{color:var(--gray);font-size:15px;line-height:1.65}
.assure{display:grid;grid-template-columns:1.1fr .9fr;gap:var(--s-8);align-items:center}
.assure .tag{display:inline-block;font-family:"Montserrat";font-weight:700;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--red);margin-bottom:14px}
.assure h3{font-family:"Anton","Montserrat",sans-serif;font-weight:400;font-size:clamp(24px,2.4vw,40px);line-height:1.05;letter-spacing:.25px;margin-bottom:16px}
.assure h3 em{color:var(--red);font-style:normal}
.assure p{color:var(--gray);font-size:clamp(15px,1.05vw,18px);line-height:1.7;margin-bottom:16px}
.assure .split-media{border-radius:18px;overflow:hidden;box-shadow:0 26px 50px rgba(0,0,0,.18)}
.assure .split-media img{width:100%;display:block}

/* ============ DUAL ORDER CTA (per-category + strip) ============ */
.cat-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:var(--s-4)}
.order-btn{display:inline-flex;align-items:center;gap:10px;font-family:"Montserrat";font-weight:700;font-size:12px;letter-spacing:1px;text-transform:uppercase;padding:13px 24px;border-radius:40px;border:2px solid var(--red);transition:transform .26s var(--ease),box-shadow .26s var(--ease),background .2s ease,color .2s ease}
.order-btn svg{width:17px;height:17px}
.order-btn.bulk{background:var(--red);color:#fff;box-shadow:var(--shadow-red)}
.order-btn.bulk:hover{background:var(--red-dark);transform:translateY(-3px);box-shadow:var(--shadow-red-lg)}
.order-btn.online{background:#fff;color:var(--red)}
.order-btn.online:hover{background:var(--red);color:#fff;transform:translateY(-3px);box-shadow:var(--shadow-red)}

/* big two-card order CTA block */
.order-cta{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-4)}
.oc-card{position:relative;border-radius:20px;padding:40px 34px;overflow:hidden;border:1px solid var(--line);background:#fff;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.oc-card:hover{transform:translateY(-6px);box-shadow:0 24px 48px rgba(22,22,22,.12)}
.oc-card.is-bulk{background:radial-gradient(120% 160% at 0% 0%,#e22128,var(--red) 60%,#9c1119);border-color:transparent;color:#fff}
.oc-ic{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;margin-bottom:20px}
.oc-card.is-bulk .oc-ic{background:rgba(255,255,255,.16);color:#fff}
.oc-card.is-online .oc-ic{background:linear-gradient(150deg,var(--red),var(--red-dark));color:#fff}
.oc-ic svg{width:26px;height:26px}
.oc-card h3{font-family:"Anton";font-size:clamp(22px,2.2vw,32px);letter-spacing:.4px;margin-bottom:12px;line-height:1.05}
.oc-card.is-online h3{color:var(--ink)}
.oc-card p{font-size:15px;line-height:1.65;margin-bottom:22px}
.oc-card.is-bulk p{color:rgba(255,255,255,.92)}
.oc-card.is-online p{color:var(--gray)}
.oc-card .btn{width:100%}
.oc-card.is-bulk .btn-solid{background:#fff;color:var(--red)}
.oc-card.is-bulk .btn-solid:hover{background:#f3f3f3;color:var(--red-dark)}

/* ============ ORDER FORM PAGE ============ */
.order-wrap{display:grid;grid-template-columns:1.5fr .85fr;gap:var(--s-6);align-items:start}
.order-form{background:#fff;border:1px solid var(--line);border-radius:20px;padding:clamp(24px,3vw,44px);box-shadow:var(--shadow-md)}
.of-title{font-family:"Anton";font-size:clamp(22px,2.2vw,30px);letter-spacing:.4px;margin-bottom:26px;line-height:1.1}
.of-field{margin-bottom:20px}
.of-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.of-label{display:block;font-size:12px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--ink);margin-bottom:8px}
.of-label .opt,.of-label .opt *{font-weight:500;text-transform:none;letter-spacing:0;color:var(--gray-soft)}
.order-form input,.order-form select,.order-form textarea{width:100%;font-family:"Montserrat";font-size:15px;color:var(--ink);background:#fafafa;border:1.5px solid var(--line);border-radius:12px;padding:13px 16px;transition:border-color .2s ease,box-shadow .2s ease}
.order-form input:focus,.order-form select:focus,.order-form textarea:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(216,31,38,.12);background:#fff}
.order-form textarea{resize:vertical;min-height:110px;line-height:1.6}
.of-toggle{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ot-opt{position:relative;cursor:pointer}
.ot-opt input{position:absolute;opacity:0;inset:0;cursor:pointer}
.ot-opt span{display:block;border:1.5px solid var(--line);border-radius:14px;padding:16px 18px;transition:.2s var(--ease)}
.ot-opt span b{display:block;font-size:15px;color:var(--ink)}
.ot-opt span small{display:block;font-size:12px;color:var(--gray-soft);margin-top:3px}
.ot-opt input:checked + span{border-color:var(--red);background:rgba(216,31,38,.05);box-shadow:0 0 0 3px rgba(216,31,38,.10)}
.ot-opt input:checked + span b{color:var(--red)}
.of-submit{width:100%;margin-top:6px}
.of-note{font-size:12px;color:var(--gray-soft);line-height:1.55;margin-top:14px}

.order-aside{display:flex;flex-direction:column;gap:var(--s-3)}
.oa-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:30px 28px}
.oa-card h4{font-family:"Anton";font-size:19px;letter-spacing:.4px;margin-bottom:10px}
.oa-card > p{color:var(--gray);font-size:14px;line-height:1.6;margin-bottom:18px}
.oa-line{display:flex;align-items:center;gap:14px;padding:12px 0;border-top:1px solid var(--line);font-size:13px;color:var(--gray)}
.oa-line:first-of-type{border-top:0}
.oa-line b{color:var(--ink);font-size:14px}
.oa-ic{width:40px;height:40px;flex:none;border-radius:11px;background:rgba(216,31,38,.08);color:var(--red);display:grid;place-items:center}
.oa-ic svg{width:20px;height:20px}
.oa-ic img{width:18px;height:18px;object-fit:contain}
.oa-shop .oa-stores{display:flex;gap:12px}
.oa-shop .store-btn{flex:1}

/* ============ MID-PAGE RED CTA STRIP ============ */
.cta-strip{background:radial-gradient(120% 160% at 50% 0%,#e22128,var(--red) 55%,#9c1119);text-align:center;padding:var(--section-pad) 0;color:#fff}
.cta-strip h2{font-family:"Anton";font-size:clamp(28px,3.4vw,52px);margin-bottom:16px;line-height:1.02}
.cta-strip p{color:rgba(255,255,255,.9);font-size:clamp(15px,1.1vw,18px);max-width:560px;margin:0 auto 28px;line-height:1.6}
.cta-strip .btn-ghost{border-color:#fff}
.cta-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ============ HOME: BEST SELLERS ============ */
.sec-best{padding:var(--section-pad) 0;background:#fff}
.best-head{display:flex;align-items:baseline;gap:14px;margin-bottom:var(--s-5)}
.best-head h2{font-family:"Anton";font-size:clamp(26px,3vw,46px);letter-spacing:.4px;line-height:1}
.best-head .shop-all{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--ink);text-decoration:underline;text-underline-offset:3px;transition:.2s}
.best-head .shop-all:hover{color:var(--red)}
.best-head .shop-all::after{content:"";width:8px;height:8px;border-radius:50%;background:var(--red)}
.best-grid{display:grid;grid-template-columns:repeat(3,1fr) 1.05fr;gap:var(--s-3);align-items:stretch}
.bs-card{text-align:center;padding:18px 14px 22px;border-radius:18px;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.bs-card:hover{transform:translateY(-6px);box-shadow:0 22px 44px rgba(22,22,22,.12)}
.bs-shot{height:200px;display:grid;place-items:center;margin-bottom:14px}
.bs-shot img{max-height:200px;max-width:92%;width:auto;object-fit:contain;filter:drop-shadow(0 16px 26px rgba(0,0,0,.16))}
.bs-stars{color:#f5a623;font-size:13px;letter-spacing:2px;margin-bottom:8px}
.bs-name{display:inline-flex;align-items:center;gap:8px;font-family:"Anton";font-size:17px;letter-spacing:.3px;line-height:1.15;margin-bottom:12px;justify-content:center}
.bs-name::after{content:"";width:9px;height:9px;border-radius:50%;background:var(--red);flex:none}
.bs-pack{font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--gray-soft);margin-bottom:4px}
.bs-price{font-family:"Anton";font-size:20px;color:var(--ink)}
/* create your own card (red) */
.bs-cyo{position:relative;padding:0 30px 30px;display:flex;flex-direction:column;justify-content:flex-end;color:#fff;overflow:visible}
/* red card background as a clipped pseudo-element, so the product can poke out above the top.
   Shape: three large rounded corners + a square bottom-right corner. */
.bs-cyo::before{content:"";position:absolute;inset:88px 0 0;z-index:0;
  background:radial-gradient(120% 130% at 100% 0%,#e22128,var(--red) 60%,#9c1119);
  border-radius:90px 90px 0 90px; /* TL TR BR BL — bottom-right is the sharp 90° corner */}
.bs-cyo > *{position:relative;z-index:1}
.bs-cyo .cyo-shot{position:absolute;top:-44px;left:50%;transform:translateX(-50%);width:138px;max-width:62%;z-index:2}
.bs-cyo .cyo-shot img{width:100%;height:auto;display:block;filter:drop-shadow(0 18px 30px rgba(0,0,0,.35))}
.bs-cyo h3{font-family:"Anton";font-size:23px;letter-spacing:.4px;margin:200px 0 0;line-height:1.05}
.bs-cyo .cyo-line{display:block;width:40px;height:4px;border-radius:3px;background:#f5b81c;margin:14px 0}
.bs-cyo p{font-size:13.5px;line-height:1.6;color:rgba(255,255,255,.92);margin:0 0 24px}
.bs-cyo .cyo-btn{align-self:flex-start;display:inline-flex;align-items:center;gap:10px;background:#f5b81c;color:#3a2a10;font-family:"Montserrat";font-weight:800;font-size:12px;letter-spacing:.5px;text-transform:uppercase;padding:13px 26px;border-radius:999px;transition:.25s var(--ease)}
.bs-cyo .cyo-btn:hover{transform:translateY(-3px);box-shadow:0 14px 28px rgba(0,0,0,.28)}

/* ============ HOME: FEATURE SPLIT (image + brown card) ============ */
.sec-feature{padding:var(--section-pad) 0;background:#fff}
.feature-grid{position:relative;display:grid;grid-template-columns:1.25fr .9fr;align-items:center}
.feature-img{border-radius:22px;overflow:hidden;box-shadow:0 26px 54px rgba(0,0,0,.20)}
.feature-img img{width:100%;height:100%;object-fit:cover;display:block;min-height:420px}
.feature-card{background:#4a3328;color:#fff;border-radius:22px;padding:clamp(34px,4vw,56px);margin-left:-60px;z-index:2;box-shadow:0 30px 60px rgba(0,0,0,.28)}
.feature-card .accent{width:46px;height:4px;background:#f5b81c;border-radius:3px;margin-bottom:18px}
.feature-card h2{font-family:"Anton";font-size:clamp(28px,3vw,44px);line-height:1.05;letter-spacing:.4px;margin-bottom:18px}
.feature-card p{color:rgba(255,255,255,.82);font-size:15px;line-height:1.75;margin-bottom:26px}
.feature-card .btn-yellow{display:inline-flex;align-items:center;gap:9px;background:#f5b81c;color:#3a2a10;font-family:"Montserrat";font-weight:800;font-size:12px;letter-spacing:1px;text-transform:uppercase;padding:13px 26px;border-radius:40px;transition:.25s var(--ease)}
.feature-card .btn-yellow:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(0,0,0,.3)}

/* ============ HOME: LIFESTYLE CARDS ============ */
.sec-taste{padding:var(--section-pad) 0;background:#fff}
.taste-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-4)}
.taste-card{position:relative;border-radius:20px;overflow:hidden;aspect-ratio:4/4.4;box-shadow:0 20px 44px rgba(0,0,0,.16)}
.taste-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.taste-card:hover img{transform:scale(1.05)}
.taste-tab{position:absolute;left:0;bottom:0;background:var(--red);color:#fff;border-top-right-radius:20px;padding:18px 26px 20px;min-width:54%}
.taste-card:nth-child(2) .taste-tab{background:#c8341f}
.taste-card:nth-child(3) .taste-tab{background:#9c4a1f}
.taste-tab h4{font-family:"Anton";font-size:20px;letter-spacing:.4px;margin-bottom:10px}
.taste-tab .shop-now{display:inline-flex;align-items:center;gap:8px;background:#f5b81c;color:#3a2a10;font-family:"Montserrat";font-weight:800;font-size:11px;letter-spacing:.5px;text-transform:uppercase;padding:9px 18px;border-radius:40px;transition:.25s var(--ease)}
.taste-tab .shop-now:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(0,0,0,.25)}

/* ============ HOME: NEWSLETTER STRIP ============ */
.sec-news{background:#4a3328;color:#fff;position:relative;overflow:hidden;padding:var(--s-8) 0}
.news-grid{display:grid;grid-template-columns:auto 1fr auto;gap:var(--s-5);align-items:center}
.news-art{width:clamp(120px,12vw,180px)}
.news-art img{width:100%;filter:drop-shadow(0 16px 28px rgba(0,0,0,.3))}
.news-copy h2{font-family:"Anton";font-size:clamp(24px,2.8vw,40px);line-height:1.08;letter-spacing:.4px}
.news-form{display:flex;align-items:center;background:#fff;border-radius:40px;padding:6px 6px 6px 22px;min-width:clamp(260px,26vw,380px)}
.news-form input{flex:1;border:0;background:transparent;font-family:"Montserrat";font-size:14px;color:var(--ink);padding:10px 8px}
.news-form input:focus{outline:none}
.news-form button{flex:none;width:44px;height:44px;border-radius:50%;border:0;background:#f5b81c;color:#3a2a10;cursor:pointer;display:grid;place-items:center;transition:.25s var(--ease)}
.news-form button:hover{transform:scale(1.08)}
.news-form button svg{width:20px;height:20px}

/* ============ ANIMATIONS ============ */
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-18px)}}
@keyframes stepPulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.35);opacity:0}}
.reveal{opacity:0;transform:translateY(34px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal-all .reveal{opacity:1!important;transform:none!important}
.reveal-all .hero{min-height:auto;padding:140px 0 180px}

/* ============ RESPONSIVE — LARGE / WIDESCREEN ============ */
/* ≥1440px: widen the container so content uses the screen */
@media(min-width:1440px){
  :root{ --container:1480px }
  .main-nav{gap:34px}
  .main-nav a{font-size:13px}
  .slider{gap:var(--s-4)}
}
/* ≥1700px: full-HD and up — wider still, larger hero presence */
@media(min-width:1700px){
  :root{ --container:1660px }
  .logo-img{height:48px}
}
/* ≥1920px: large desktops — content uses most of the screen */
@media(min-width:1920px){
  :root{ --container:1840px }
  body{font-size:17px}
}
/* ≥2200px: ultrawide / 4K — wide but capped so text stays comfortable */
@media(min-width:2200px){
  :root{ --container:2040px }
  body{font-size:18px}
  .slider{gap:var(--s-5)}
  .slider .brand-card{flex-basis:calc((100% - 2 * var(--s-5)) / 3)}
  .brand-card{height:400px}
  .bc-shot img{max-height:250px}
}
/* ≥2560px: very wide / ultrawide monitors — final comfortable cap */
@media(min-width:2560px){
  :root{ --container:2280px }
}

/* ============ RESPONSIVE — TABLET / MOBILE ============ */
@media(max-width:900px){
  :root{ --gutter:24px }
  .container{padding:0 var(--gutter)}

  /* mobile ribbon: logo on the left, hamburger on the right; nav groups slide out */
  .ribbon{justify-content:space-between;gap:0}
  .logo{margin-top:0;width:54px;height:54px;border-width:3px;order:-1}
  .logo-img{height:34px}
  .site-header.scrolled .logo{width:50px;height:50px;margin-top:0}
  .main-nav{position:fixed;inset:0 0 0 auto;width:74%;max-width:320px;background:var(--red);flex-direction:column;justify-content:center;gap:24px;padding:40px;transform:translateX(100%);transition:.35s;box-shadow:-10px 0 40px rgba(0,0,0,.25)}
  .main-nav.nav-left{padding-bottom:0}
  .main-nav.nav-right{padding-top:0;top:auto;bottom:auto}
  /* both groups occupy the same slide-out panel: stack them */
  .main-nav.nav-left{inset:0 0 50% auto;justify-content:flex-end}
  .main-nav.nav-right{inset:50% 0 0 auto;justify-content:flex-start}
  .main-nav.open{transform:none}
  .main-nav a{font-size:16px}
  .nav-toggle{display:flex;z-index:120}
  .nav-toggle.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

  /* mobile hero: vertical stack — product, then blurb, then social */
  .hero{min-height:auto;flex-direction:column;justify-content:flex-start;padding:120px 0 150px}
  .hero-stage{padding-top:20px}
  .hero-products{max-height:48vh;max-width:84vw}
  .hero-wordmark{font-size:46vw;top:38%}
  .hero-blurb{position:static;max-width:88%;margin:28px auto 0;text-align:center}
  .hero-arrows{display:none}
  .hero-social{position:static;margin:28px auto 0;transform:none}

  .about-grid,.works-grid,.cta-grid{grid-template-columns:1fr;gap:30px}
  .about-right{order:-1}
  .cta-art{height:auto}
  .cta-products{max-height:300px}
  .store-btns{justify-content:center}
  .works-photo{transform:none}
  .center-head{font-size:28px}
  .about-left h2{font-size:30px}
  .works-steps{grid-template-columns:1fr;gap:24px}
  .step-dots{flex-direction:row;justify-content:center}
  .step-dots::before{left:18px;right:18px;top:50%;bottom:auto;width:auto;height:2px}
  .slider .brand-card{flex-basis:calc((100% - var(--s-3)) / 2)} /* 2 cards per view on tablet */
  .cta-art{margin-bottom:10px}
  .cta-copy{text-align:center}
  .cta-copy h2{font-size:34px}
  .cta-copy h2 .xl{font-size:52px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .sec-badge.left,.sec-badge.right{display:none}

  /* sub-page responsive */
  .page-hero{padding:calc(var(--s-14) + 40px) 0 var(--s-10)}
  .split,.split.reverse{grid-template-columns:1fr;gap:30px}
  .split.reverse .split-media{order:-1}
  .split .split-media{order:-1}
  .stats{grid-template-columns:repeat(2,1fr);gap:24px}
  .prod-grid{grid-template-columns:repeat(2,1fr)}
  .cat-head{flex-direction:column;align-items:flex-start;gap:10px}
  .cap-grid{grid-template-columns:1fr}
  .flow{grid-template-columns:1fr 1fr}
  .checks{grid-template-columns:1fr}
  .cert-grid{grid-template-columns:1fr}
  .assure{grid-template-columns:1fr;gap:30px}
  .assure .split-media{order:-1}
  .order-cta{grid-template-columns:1fr}
  .order-wrap{grid-template-columns:1fr;gap:var(--s-4)}
  .of-row{grid-template-columns:1fr}
  .of-toggle{grid-template-columns:1fr}

  /* Lay's-style home sections */
  .best-grid{grid-template-columns:1fr 1fr}
  .bs-cyo{grid-column:1 / -1}
  .bs-cyo h3{margin-top:170px}
  .feature-grid{grid-template-columns:1fr}
  .feature-card{margin-left:0;margin-top:-40px;width:92%;margin-right:auto;margin-left:auto}
  .feature-img img{min-height:300px}
  .taste-grid{grid-template-columns:1fr;gap:24px}
  .taste-card{aspect-ratio:16/10}
  .news-grid{grid-template-columns:1fr;text-align:center;gap:24px;justify-items:center}
  .news-art{display:none}
}
@media(max-width:520px){
  .best-grid{grid-template-columns:1fr}
  .best-head{flex-direction:column;gap:6px}
}
@media(max-width:520px){
  .hero-wordmark{font-size:38vw}
  .hero-products{max-height:46vh}
  .center-head{font-size:24px}
  .slider .brand-card{flex-basis:calc(100% - 36px)} /* ~1 card per view on mobile, peek of next */
  .prod-grid{grid-template-columns:1fr 1fr}
  .flow{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
}
