/* ============================================================
   GENOVES — Luxury Stylesheet v3
   Cinzel · Cormorant Garamond · Jost
   Palette: #0D0B08 · #C9A96E · #F5EDD8
   ============================================================ */

/* RESET
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --f-display: 'Cinzel', Georgia, serif;
  --f-sub:     'Cormorant Garamond', Georgia, serif;
  --f-body:    'Jost', system-ui, sans-serif;

  --ink:       #0D0B08;
  --ink-90:    rgba(13,11,8,.9);
  --cream:     #F5EDD8;
  --warm:      #2C2218;
  --gold:      #C9A96E;
  --gold-lt:   #E8D5A3;
  --gold-dim:  rgba(201,169,110,.22);
  --gold-glow: rgba(201,169,110,.12);
  --muted:     #8A7B6A;
  --white:     #FFFFFF;
  --white-10:  rgba(255,255,255,.10);
  --white-20:  rgba(255,255,255,.20);
  --white-50:  rgba(255,255,255,.50);
  --white-70:  rgba(255,255,255,.70);

  --gap-section: clamp(100px, 14vw, 180px);
  --container:   min(1280px, 92vw);
  --ease:        cubic-bezier(0.16, 1, 0.3, 1);
}

html { scroll-behavior: smooth; font-size: 16px; }

body {
  background: var(--ink);
  color: var(--cream);
  font-family: var(--f-body);
  font-weight: 300;
  line-height: 1.65;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

img { display: block; max-width: 100%; height: auto; }
a   { color: inherit; text-decoration: none; }
ul  { list-style: none; }
em  { font-family: var(--f-sub); font-style: italic; }

/* TYPOGRAPHY
   ============================================================ */
h1, h2, h3 {
  font-family: var(--f-display);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: 0.04em;
}

h1 em, h2 em, h3 em {
  font-family: var(--f-sub);
  font-style: italic;
  font-weight: 300;
  letter-spacing: -0.01em;
  color: var(--gold-lt);
}

.section-label {
  font-family: var(--f-body);
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--gold);
  display: block;
  margin-bottom: 24px;
}
.section-label--light { color: var(--gold-lt); }

/* NOISE TEXTURE
   ============================================================ */
.noise {
  position: fixed;
  inset: -50%;
  width: 200%;
  height: 200%;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");
  background-size: 128px 128px;
  opacity: .028;
  pointer-events: none;
  z-index: 1000;
  animation: noiseShift 0.15s steps(2) infinite;
}
@keyframes noiseShift {
  0%   { transform: translate(0,0); }
  25%  { transform: translate(-2%,-1%); }
  50%  { transform: translate(1%,2%); }
  75%  { transform: translate(2%,-2%); }
  100% { transform: translate(-1%,1%); }
}

/* PROGRESS BAR
   ============================================================ */
.progress-bar {
  position: fixed;
  top: 0; left: 0;
  height: 1px;
  background: var(--gold);
  width: 0%;
  z-index: 999;
  transition: width 0.1s linear;
}

/* REVEAL ANIMATIONS
   ============================================================ */
[data-reveal] {
  opacity: 0;
  transition: opacity 1s var(--ease), transform 1s var(--ease);
  transition-delay: var(--delay, 0s);
}
[data-reveal="up"]    { transform: translateY(40px); }
[data-reveal="left"]  { transform: translateX(-32px); }
[data-reveal="right"] { transform: translateX(32px); }

[data-reveal].in-view {
  opacity: 1;
  transform: none;
}

.word-reveal, .line-reveal {
  display: inline-block;
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1.1s var(--ease);
}
.word-reveal.revealed, .line-reveal.revealed {
  clip-path: inset(0 0% 0 0);
}

/* NAV
   ============================================================ */
.nav {
  position: fixed;
  inset: 0 0 auto;
  z-index: 500;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 28px clamp(20px, 5vw, 60px);
  transition: padding .5s var(--ease), background .5s var(--ease);
}
.nav::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(13,11,8,.45), transparent);
  pointer-events: none;
  opacity: 1;
  transition: opacity .5s ease;
  z-index: -1;
}
.nav.solid {
  padding-top: 18px;
  padding-bottom: 18px;
  background: rgba(13,11,8,.94);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(255,255,255,.04);
}
.nav.solid::after { opacity: 0; }

.nav__logo {
  font-family: var(--f-display);
  font-size: 18px;
  font-weight: 400;
  letter-spacing: 0.26em;
  color: var(--white);
}

.nav__links {
  display: flex;
  gap: 36px;
}
.nav__links a {
  font-family: var(--f-body);
  font-size: 11px;
  font-weight: 300;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--white-70);
  transition: color .3s;
}
.nav__links a:hover { color: var(--white); }

.nav__shop {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--f-body);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold-lt);
  border: 1px solid var(--gold-dim);
  padding: 9px 18px;
  transition: all .3s var(--ease);
}
.nav__shop:hover {
  background: var(--gold);
  border-color: var(--gold);
  color: var(--ink);
}

.nav__burger {
  display: none;
  flex-direction: column;
  gap: 7px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
}
.nav__burger span {
  display: block;
  width: 26px;
  height: 1px;
  background: var(--white);
  transition: transform .4s var(--ease), opacity .3s;
}
.nav__burger.open span:nth-child(1) { transform: translateY(4px) rotate(45deg); }
.nav__burger.open span:nth-child(2) { transform: translateY(-4px) rotate(-45deg); }

/* MOBILE MENU
   ============================================================ */
.mobile-menu {
  position: fixed;
  inset: 0;
  background: var(--ink);
  z-index: 400;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .5s var(--ease);
}
.mobile-menu.open {
  opacity: 1;
  pointer-events: all;
}
.mobile-menu ul {
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.mobile-link {
  font-family: var(--f-sub);
  font-size: clamp(36px, 8vw, 56px);
  font-weight: 300;
  font-style: italic;
  color: var(--cream);
  display: block;
  padding: 8px 0;
  transition: color .3s;
}
.mobile-link:hover { color: var(--gold); }

/* HERO
   ============================================================ */
.hero {
  position: relative;
  height: 100svh;
  min-height: 640px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  overflow: hidden;
}

/* SPLIT HERO
   ============================================================ */
.hero--split {
  display: grid;
  grid-template-columns: 40% 60%;
  height: 100svh;
  min-height: 680px;
  flex-direction: unset;
  justify-content: unset;
  background: var(--ink);
  overflow: hidden;
}

.hero__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(80px, 10vh, 120px) clamp(40px, 5vw, 72px) clamp(60px, 8vh, 100px) clamp(32px, 6vw, 80px);
  position: relative;
  z-index: 2;
}

.hero__brand-display {
  margin: clamp(28px, 4vh, 52px) 0 clamp(20px, 3vh, 36px);
}

.hero__brand-name {
  display: block;
  font-family: var(--f-display);
  font-size: clamp(44px, 4.5vw, 72px);
  font-weight: 400;
  letter-spacing: 0.18em;
  color: var(--cream);
  line-height: 1;
  text-transform: uppercase;
}

.hero__brand-est {
  display: block;
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--gold);
  margin-top: 16px;
}

.hero__tagline {
  font-family: var(--f-display);
  font-size: clamp(16px, 1.8vw, 24px);
  font-weight: 400;
  letter-spacing: 0.05em;
  color: rgba(245,237,216,.7);
  margin-bottom: 10px;
  line-height: 1.35;
}

.hero__tagline em {
  font-family: var(--f-sub);
  font-style: italic;
  color: var(--gold-lt);
  letter-spacing: -0.01em;
}

.hero__actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: clamp(32px, 5vh, 56px);
}

/* Image panel — dominant, edge-to-edge, full height */
.hero__product-visual {
  position: relative;
  height: 100svh;
  min-height: 680px;
  overflow: hidden;
  background: var(--warm);
}

.hero__product-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}

@media (max-width: 900px) {
  .hero--split {
    grid-template-columns: 1fr;
    height: auto;
    min-height: unset;
  }
  .hero__product-visual {
    height: 65svh;
    min-height: 360px;
    order: -1;
  }
  .hero__product-img {
    position: absolute;
  }
  .hero__content {
    padding: clamp(40px, 6vw, 72px) clamp(24px, 5vw, 48px) clamp(48px, 6vw, 72px);
  }
}

.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 40%;
  transform: scale(1.06);
  animation: heroZoom 12s var(--ease) forwards;
}
@keyframes heroZoom {
  to { transform: scale(1); }
}

.hero__grain {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='1'/%3E%3C/svg%3E");
  background-size: 200px;
  opacity: .06;
  mix-blend-mode: overlay;
  pointer-events: none;
}
.hero__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to top, rgba(13,11,8,.92) 0%, transparent 50%),
    linear-gradient(to right, rgba(13,11,8,.6) 0%, transparent 60%),
    linear-gradient(to bottom, rgba(13,11,8,.35) 0%, transparent 25%);
}

.hero__body {
  position: relative;
  z-index: 2;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: clamp(100px, 12vh, 140px) clamp(24px, 6vw, 80px) clamp(48px, 7vh, 80px);
}

.hero__top { display: flex; align-items: center; gap: 24px; }
.hero__eyebrow {
  display: flex;
  align-items: center;
  gap: 20px;
  font-family: var(--f-body);
  font-size: 10px;
  font-weight: 300;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--white-50);
}
.hero__dash {
  display: block;
  width: 40px;
  height: 1px;
  background: var(--gold-dim);
  flex-shrink: 0;
}

.hero__center { margin: clamp(32px, 5vh, 60px) 0; }

.hero__h1 {
  font-family: var(--f-display);
  font-size: clamp(58px, 9.5vw, 136px);
  font-weight: 400;
  line-height: 0.95;
  letter-spacing: 0.06em;
  color: var(--white);
  text-transform: uppercase;
}
.hero__h1--indent { padding-left: clamp(40px, 8vw, 120px); }
.italic {
  font-family: var(--f-sub);
  font-style: italic;
  font-weight: 300;
  letter-spacing: -0.01em;
  color: var(--gold-lt);
  text-transform: none;
}

.hero__bottom {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
.hero__bottom-left { display: flex; flex-direction: column; gap: 4px; }
.hero__sub {
  font-family: var(--f-body);
  font-size: 13px;
  font-weight: 300;
  letter-spacing: 0.08em;
  color: var(--white-50);
}

.btn-circle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  transition: transform .6s var(--ease);
  animation: circlePulse 3s ease-in-out infinite;
}
.btn-circle:hover { transform: scale(1.1); animation: none; }
.btn-circle svg { width: 64px; height: 64px; }
@keyframes circlePulse {
  0%, 100% { opacity: 1; }
  50% { opacity: .6; }
}

.hero__scroll-text {
  position: absolute;
  bottom: 40px;
  left: 50%;
  transform: translateX(-50%) rotate(90deg);
  font-family: var(--f-body);
  font-size: 9px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--white-20);
  white-space: nowrap;
  z-index: 2;
  animation: fadeUp 1s var(--ease) 2s both;
}
@keyframes fadeUp {
  from { opacity: 0; transform: translateX(-50%) rotate(90deg) translateY(10px); }
  to   { opacity: 1; transform: translateX(-50%) rotate(90deg) translateY(0); }
}

/* MARQUEE
   ============================================================ */
.marquee {
  background: var(--gold);
  overflow: hidden;
  padding: 14px 0;
  position: relative;
  z-index: 10;
}
.marquee__track {
  display: flex;
  align-items: center;
  gap: 36px;
  white-space: nowrap;
  width: max-content;
  animation: marqueeScroll 30s linear infinite;
}
.marquee__track span {
  font-family: var(--f-body);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink);
}
.marquee__sep {
  opacity: 0.35 !important;
}
@keyframes marqueeScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* MANIFESTO
   ============================================================ */
.manifesto {
  background: var(--warm);
  color: var(--cream);
  padding: var(--gap-section) clamp(24px, 8vw, 120px);
}

.manifesto__inner { margin-bottom: 60px; }
.manifesto__line {
  display: flex;
  align-items: baseline;
  gap: 24px;
  opacity: 0;
  transform: translateY(30px);
  transition: all .9s var(--ease);
  transition-delay: var(--delay, 0s);
}
.manifesto__line.in-view { opacity: 1; transform: none; }

.manifesto__line p {
  font-family: var(--f-display);
  font-size: clamp(40px, 6.5vw, 96px);
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: 0.04em;
}
.manifesto__line p em {
  font-family: var(--f-sub);
  font-style: italic;
  color: var(--gold);
}
.manifesto__num {
  font-family: var(--f-sub);
  font-size: clamp(28px, 4vw, 56px);
  color: var(--gold);
  flex-shrink: 0;
}

.manifesto__body {
  max-width: 520px;
  margin-left: auto;
  margin-bottom: 80px;
  opacity: 0;
  transform: translateY(20px);
  transition: all .9s var(--ease);
  transition-delay: var(--delay, 0s);
}
.manifesto__body.in-view { opacity: 1; transform: none; }
.manifesto__body p {
  font-family: var(--f-body);
  font-size: clamp(15px, 1.5vw, 18px);
  line-height: 1.8;
  color: var(--muted);
}

.manifesto__stats {
  display: flex;
  gap: 0;
  border-top: 1px solid rgba(201,169,110,.15);
  padding-top: 48px;
  opacity: 0;
  transform: translateY(20px);
  transition: all .9s var(--ease);
  transition-delay: var(--delay, 0s);
}
.manifesto__stats.in-view { opacity: 1; transform: none; }

.manifesto__pillars {
  display: flex;
  gap: clamp(32px, 6vw, 80px);
  border-top: 1px solid rgba(201,169,110,.15);
  padding-top: 48px;
  opacity: 0;
  transform: translateY(20px);
  transition: all .9s var(--ease);
  transition-delay: var(--delay, 0s);
}
.manifesto__pillars.in-view { opacity: 1; transform: none; }

.pillar { flex: 1; }
.pillar__word {
  display: block;
  font-family: var(--f-display);
  font-size: clamp(28px, 4vw, 52px);
  font-weight: 400;
  letter-spacing: 0.06em;
  color: var(--gold);
  line-height: 1;
  margin-bottom: 10px;
}
.pillar p {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
}

.m-stat { flex: 1; }
.m-stat__divider {
  width: 1px;
  background: rgba(201,169,110,.15);
  margin: 0 clamp(24px, 4vw, 60px);
}
.m-stat__n, .m-stat__sym {
  display: block;
  font-family: var(--f-display);
  font-size: clamp(48px, 6vw, 80px);
  font-weight: 400;
  color: var(--gold);
  line-height: 1;
  margin-bottom: 12px;
}
.m-stat p {
  font-family: var(--f-body);
  font-size: 12px;
  letter-spacing: 0.05em;
  color: var(--muted);
  max-width: 160px;
  line-height: 1.5;
}

/* EDITORIAL PRODUCT
   ============================================================ */
.editorial {
  position: relative;
  background: var(--ink);
}

.editorial__label {
  position: sticky;
  top: 80px;
  z-index: 10;
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 20px clamp(24px, 6vw, 80px);
  font-family: var(--f-body);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  border-bottom: 1px solid rgba(255,255,255,.04);
  background: var(--ink);
  opacity: 0;
  transform: translateX(-24px);
  transition: all .8s var(--ease);
}
.editorial__label.in-view { opacity: 1; transform: none; }

.editorial__frame {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 80vh;
}
.editorial__frame--dark { background: #080604; }
.editorial__frame--mid  { background: #1A1208; }
.editorial__frame--warm { background: var(--warm); }

.editorial__visual {
  overflow: hidden;
  position: relative;
}

.editorial__img-wrap {
  width: 100%;
  height: 100%;
  min-height: 500px;
  position: relative;
  overflow: hidden;
}
.editorial__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 1.2s var(--ease);
}
.editorial__frame:hover .editorial__img-wrap img { transform: scale(1.04); }

.editorial__img-caption {
  position: absolute;
  bottom: 24px;
  left: 24px;
  font-family: var(--f-body);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--white-50);
  background: rgba(13,11,8,.4);
  backdrop-filter: blur(8px);
  padding: 6px 14px;
}

.editorial__copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(48px, 7vw, 100px) clamp(32px, 5vw, 80px);
  background: inherit;
  color: var(--cream);
}

.editorial__index {
  font-family: var(--f-body);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 20px;
}

.editorial__h2 {
  font-family: var(--f-display);
  font-size: clamp(36px, 4.5vw, 66px);
  font-weight: 400;
  color: var(--cream);
  margin-bottom: 28px;
  letter-spacing: 0.05em;
}
.editorial__h2 em {
  font-family: var(--f-sub);
  font-style: italic;
  font-weight: 300;
  color: var(--gold-lt);
  letter-spacing: -0.01em;
}

.editorial__text {
  font-family: var(--f-body);
  font-size: 15px;
  line-height: 1.8;
  color: var(--muted);
  max-width: 380px;
  margin-bottom: 36px;
}

.editorial__specs {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 40px;
  border-top: 1px solid rgba(255,255,255,.06);
}
.editorial__specs li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
  font-family: var(--f-body);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--cream);
}
.editorial__specs li span:first-child {
  color: var(--muted);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: 10px;
}

/* BUTTONS
   ============================================================ */
.btn-line {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--f-body);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cream);
  padding-bottom: 6px;
  border-bottom: 1px solid var(--gold);
  transition: gap .3s var(--ease), color .3s;
}
.btn-line:hover { gap: 18px; color: var(--gold); }
.btn-line--light { color: var(--cream); }
.btn-line--light:hover { color: var(--gold-lt); }

.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 40px;
  background: var(--gold);
  color: var(--ink);
  font-family: var(--f-body);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  border: 1px solid var(--gold);
  transition: all .35s var(--ease);
}
.btn-primary:hover {
  background: transparent;
  color: var(--gold);
}

.btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 40px;
  background: transparent;
  color: var(--cream);
  font-family: var(--f-body);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  border: 1px solid rgba(255,255,255,.2);
  transition: all .35s var(--ease);
}
.btn-secondary:hover {
  border-color: var(--gold);
  color: var(--gold);
}

/* BOTANICALS
   ============================================================ */
.botanicals {
  background: var(--ink);
  padding: var(--gap-section) 0;
  border-top: 1px solid rgba(255,255,255,.04);
}

.botanicals__header {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  padding: 0 clamp(24px, 6vw, 80px);
  margin-bottom: 60px;
  align-items: end;
}
.botanicals__header-left h2 {
  font-size: clamp(36px, 5vw, 68px);
  color: var(--cream);
  letter-spacing: 0.05em;
}
.botanicals__header-right p {
  font-family: var(--f-body);
  font-size: 15px;
  line-height: 1.8;
  color: var(--muted);
  max-width: 400px;
}

.botanicals__herbs {
  padding: 40px clamp(24px, 6vw, 80px);
  border-top: 1px solid rgba(255,255,255,.04);
  border-bottom: 1px solid rgba(255,255,255,.04);
  margin-bottom: 0;
  opacity: 0;
  transform: translateY(24px);
  transition: all .9s var(--ease);
}
.botanicals__herbs.in-view { opacity: 1; transform: none; }

.botanicals__herbs-label {
  font-family: var(--f-body);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 20px;
}

.herbs-list {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.herbs-list span {
  font-family: var(--f-sub);
  font-size: clamp(14px, 2vw, 18px);
  font-style: italic;
  font-weight: 300;
  color: rgba(245,237,216,.5);
  border: 1px solid rgba(201,169,110,.15);
  padding: 8px 20px;
  transition: all .3s;
  cursor: default;
}
.herbs-list span:hover {
  color: var(--gold-lt);
  border-color: var(--gold-dim);
}

.botanicals__strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid rgba(255,255,255,.05);
}

.bot-card {
  padding: 48px clamp(20px, 3vw, 56px);
  border-right: 1px solid rgba(255,255,255,.05);
  position: relative;
  overflow: hidden;
  opacity: 0;
  transform: translateY(32px);
  transition: opacity .9s var(--ease), transform .9s var(--ease), background .4s;
  transition-delay: var(--delay, 0s);
}
.bot-card.in-view { opacity: 1; transform: none; }
.bot-card:last-child { border-right: none; }
.bot-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(201,169,110,.04) 0%, transparent 60%);
  opacity: 0;
  transition: opacity .4s;
}
.bot-card:hover { background: rgba(255,255,255,.01); }
.bot-card:hover::before { opacity: 1; }

.bot-card__num {
  font-family: var(--f-body);
  font-size: 11px;
  letter-spacing: 0.2em;
  color: var(--gold-dim);
  margin-bottom: 40px;
}

.bot-card__icon {
  width: 52px;
  height: 52px;
  color: var(--gold);
  margin-bottom: 32px;
  opacity: .8;
}
.bot-card__icon svg { width: 100%; height: 100%; }

.bot-card h3 {
  font-family: var(--f-display);
  font-size: 20px;
  font-weight: 400;
  letter-spacing: 0.06em;
  color: var(--cream);
  margin-bottom: 6px;
}

.bot-card__tag {
  font-family: var(--f-body);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 20px;
}

.bot-card__desc {
  font-family: var(--f-body);
  font-size: 13px;
  line-height: 1.75;
  color: var(--muted);
}

.bot-card__line {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0%;
  height: 1px;
  background: var(--gold);
  transition: width .6s var(--ease);
}
.bot-card:hover .bot-card__line { width: 100%; }

/* BRAND QUOTE
   ============================================================ */
.brand-quote {
  position: relative;
  min-height: 70vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.brand-quote__bg {
  position: absolute;
  inset: 0;
}
.brand-quote__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transform: scale(1.04);
  transition: transform 8s var(--ease);
}
.brand-quote:hover .brand-quote__bg img { transform: scale(1); }
.brand-quote__overlay {
  position: absolute;
  inset: 0;
  background: rgba(13,11,8,.76);
}
.brand-quote__inner {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--gap-section) clamp(24px, 8vw, 120px);
  max-width: 900px;
}
.brand-quote__text {
  font-family: var(--f-sub);
  font-size: clamp(40px, 6vw, 88px);
  font-weight: 300;
  font-style: italic;
  color: var(--gold-lt);
  line-height: 1.2;
  letter-spacing: -0.01em;
  margin-bottom: 32px;
}
.brand-quote__sub {
  font-family: var(--f-body);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--white-50);
}

/* RITUAL
   ============================================================ */
.ritual {
  position: relative;
  min-height: 80vh;
  display: flex;
  align-items: center;
  overflow: hidden;
}
.ritual__bg {
  position: absolute;
  inset: 0;
}
.ritual__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transform: scale(1.05);
  transition: transform 8s var(--ease);
}
.ritual:hover .ritual__bg img { transform: scale(1); }
.ritual__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to right, rgba(13,11,8,.94) 0%, rgba(13,11,8,.7) 50%, rgba(13,11,8,.3) 100%);
}
.ritual__content {
  position: relative;
  z-index: 2;
  width: 100%;
  padding: var(--gap-section) clamp(24px, 6vw, 80px);
}
.ritual__header { margin-bottom: 64px; }
.ritual__header h2 {
  font-size: clamp(36px, 5vw, 68px);
  color: var(--cream);
  letter-spacing: 0.05em;
}
.ritual__steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: rgba(255,255,255,.05);
  max-width: 900px;
}
.ritual__step {
  background: rgba(13,11,8,.7);
  backdrop-filter: blur(8px);
  padding: 36px 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .8s var(--ease), transform .8s var(--ease), background .3s;
  transition-delay: var(--delay, 0s);
}
.ritual__step.in-view { opacity: 1; transform: none; }
.ritual__step:hover { background: rgba(201,169,110,.06); }
.ritual__n {
  display: block;
  font-family: var(--f-display);
  font-size: 36px;
  font-weight: 400;
  color: var(--gold);
  opacity: .5;
  line-height: 1;
  letter-spacing: 0.04em;
}
.ritual__step h3 {
  font-family: var(--f-display);
  font-size: 15px;
  font-weight: 400;
  color: var(--cream);
  letter-spacing: 0.08em;
}
.ritual__step p {
  font-family: var(--f-body);
  font-size: 13px;
  line-height: 1.7;
  color: var(--white-50);
}

/* PRODUCTS
   ============================================================ */
.products {
  background: var(--ink);
  padding: var(--gap-section) clamp(24px, 6vw, 80px);
  border-top: 1px solid rgba(255,255,255,.04);
}

.products__header {
  max-width: 600px;
  margin-bottom: 80px;
}
.products__header h2 {
  font-size: clamp(40px, 5.5vw, 76px);
  color: var(--cream);
  margin-bottom: 16px;
  letter-spacing: 0.05em;
}
.products__sub {
  font-family: var(--f-body);
  font-size: 13px;
  color: var(--muted);
  letter-spacing: 0.04em;
}

.products__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
}

.product-card {
  position: relative;
  background: #100D09;
  border: 1px solid rgba(255,255,255,.04);
  overflow: hidden;
  opacity: 0;
  transform: translateY(32px);
  transition: opacity .9s var(--ease), transform .9s var(--ease), border-color .4s;
  transition-delay: var(--delay, 0s);
}
.product-card.in-view { opacity: 1; transform: none; }
.product-card:hover { border-color: var(--gold-dim); }

.product-card__badge {
  position: absolute;
  top: 20px;
  right: 20px;
  z-index: 2;
  font-family: var(--f-body);
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink);
  background: var(--gold);
  padding: 6px 14px;
}

.product-card__visual {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4/3;
}
.product-card__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 1s var(--ease);
}
.product-card:hover .product-card__visual img { transform: scale(1.05); }

.product-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(13,11,8,.6), transparent 50%);
}

.product-card__info {
  padding: 32px 28px;
  border-top: 1px solid rgba(255,255,255,.04);
}

.product-card__label {
  font-family: var(--f-body);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 12px;
}

.product-card__name {
  font-family: var(--f-display);
  font-size: clamp(16px, 2vw, 22px);
  font-weight: 400;
  color: var(--cream);
  letter-spacing: 0.05em;
  margin-bottom: 8px;
  line-height: 1.3;
}

.product-card__desc {
  font-family: var(--f-body);
  font-size: 12px;
  color: var(--muted);
  letter-spacing: 0.06em;
  margin-bottom: 28px;
}

.product-card__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.product-card__price {
  font-family: var(--f-display);
  font-size: clamp(22px, 2.5vw, 30px);
  font-weight: 400;
  color: var(--gold-lt);
  letter-spacing: 0.04em;
}

.btn-add {
  display: inline-flex;
  align-items: center;
  padding: 10px 24px;
  background: transparent;
  color: var(--cream);
  font-family: var(--f-body);
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  border: 1px solid rgba(255,255,255,.15);
  transition: all .3s var(--ease);
  white-space: nowrap;
}
.btn-add:hover {
  background: var(--gold);
  border-color: var(--gold);
  color: var(--ink);
}

.product-card--featured { border-color: var(--gold-dim); }
.product-card--featured .product-card__name { color: var(--gold-lt); }

/* COCKTAILS
   ============================================================ */
.cocktails {
  background: var(--warm);
  padding: var(--gap-section) clamp(24px, 6vw, 80px);
  border-top: 1px solid rgba(201,169,110,.08);
}

.cocktails__header {
  max-width: 600px;
  margin-bottom: 80px;
}
.cocktails__header h2 {
  font-size: clamp(40px, 5.5vw, 76px);
  color: var(--cream);
  letter-spacing: 0.05em;
}

.cocktails__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  margin-bottom: 80px;
}

.cocktail-card {
  background: rgba(13,11,8,.5);
  border: 1px solid rgba(201,169,110,.08);
  overflow: hidden;
  opacity: 0;
  transform: translateY(32px);
  transition: opacity .9s var(--ease), transform .9s var(--ease), border-color .4s;
  transition-delay: var(--delay, 0s);
}
.cocktail-card.in-view { opacity: 1; transform: none; }
.cocktail-card:hover { border-color: var(--gold-dim); }

.cocktail-card__visual {
  overflow: hidden;
  aspect-ratio: 4/3;
}
.cocktail-card__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  filter: brightness(.85);
  transition: transform 1s var(--ease), filter .5s;
}
.cocktail-card:hover .cocktail-card__visual img {
  transform: scale(1.05);
  filter: brightness(.95);
}

.cocktail-card__body { padding: 36px 32px; }

.cocktail-card__num {
  display: block;
  font-family: var(--f-display);
  font-size: 11px;
  letter-spacing: 0.24em;
  color: var(--gold);
  margin-bottom: 16px;
}

.cocktail-card__name {
  font-family: var(--f-display);
  font-size: clamp(18px, 2.2vw, 26px);
  font-weight: 400;
  color: var(--cream);
  letter-spacing: 0.06em;
  margin-bottom: 16px;
  line-height: 1.2;
}

.cocktail-card__desc {
  font-family: var(--f-body);
  font-size: 13px;
  line-height: 1.75;
  color: var(--muted);
  margin-bottom: 24px;
}

.cocktail-card__ingredients {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-top: 20px;
  border-top: 1px solid rgba(201,169,110,.12);
}
.cocktail-card__ingredients li {
  font-family: var(--f-body);
  font-size: 11px;
  letter-spacing: 0.08em;
  color: rgba(245,237,216,.4);
  padding-left: 12px;
  position: relative;
}
.cocktail-card__ingredients li::before {
  content: '—';
  position: absolute;
  left: 0;
  color: var(--gold);
  opacity: .5;
  font-size: 9px;
}

.cocktails__note {
  text-align: center;
  font-family: var(--f-body);
  font-size: 13px;
  color: var(--muted);
  max-width: 480px;
  margin: 0 auto;
  line-height: 1.8;
  opacity: 0;
  transform: translateY(16px);
  transition: all .8s var(--ease);
}
.cocktails__note.in-view { opacity: 1; transform: none; }
.cocktails__note em { color: var(--gold-lt); }

/* STORY
   ============================================================ */
.story {
  background: var(--ink);
  color: var(--cream);
  padding: var(--gap-section) clamp(24px, 6vw, 80px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(48px, 6vw, 100px);
  align-items: start;
  border-top: 1px solid rgba(255,255,255,.04);
}

.story__h2 {
  font-size: clamp(40px, 5.5vw, 80px);
  font-weight: 400;
  line-height: 1.05;
  color: var(--cream);
  letter-spacing: 0.05em;
}

.story__body { padding-top: 80px; }
.story__lead {
  font-family: var(--f-sub);
  font-size: clamp(18px, 2.2vw, 26px);
  font-weight: 300;
  font-style: italic;
  line-height: 1.5;
  color: var(--cream);
  margin-bottom: 28px;
  padding-left: 20px;
  border-left: 1px solid var(--gold);
}
.story__body p {
  font-family: var(--f-body);
  font-size: 14px;
  line-height: 1.85;
  color: var(--muted);
  margin-bottom: 20px;
}
.story__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 36px;
}
.story__tags span {
  font-family: var(--f-body);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
  border: 1px solid rgba(255,255,255,.1);
  padding: 8px 16px;
  transition: all .3s;
}
.story__tags span:hover { border-color: var(--gold); color: var(--gold); }

.story__visual {
  position: relative;
  overflow: hidden;
  aspect-ratio: 3/4;
}
.story__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.2s var(--ease);
}
.story__visual:hover img { transform: scale(1.04); }
.story__visual-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 24px 28px;
  background: linear-gradient(to top, rgba(13,11,8,.7), transparent);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--f-body);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--white-50);
}

/* PRESS
   ============================================================ */
.press {
  background: var(--ink);
  border-top: 1px solid rgba(255,255,255,.04);
  padding: 60px clamp(24px, 6vw, 80px);
}
.press__inner { text-align: center; }
.press__label {
  font-family: var(--f-body);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 36px;
  opacity: 0;
  transition: opacity .8s var(--ease);
}
.press__label.in-view { opacity: 1; }
.press__logos {
  display: flex;
  justify-content: center;
  gap: clamp(28px, 5vw, 72px);
  flex-wrap: wrap;
  opacity: 0;
  transform: translateY(16px);
  transition: all .8s var(--ease);
  transition-delay: var(--delay, .1s);
}
.press__logos.in-view { opacity: 1; transform: none; }
.press__logos span {
  font-family: var(--f-sub);
  font-size: clamp(16px, 2.2vw, 26px);
  font-weight: 300;
  font-style: italic;
  color: rgba(245,237,216,.12);
  transition: color .4s;
  cursor: default;
}
.press__logos span:hover { color: rgba(245,237,216,.4); }

/* CTA
   ============================================================ */
.cta {
  background: var(--warm);
  padding: var(--gap-section) clamp(24px, 6vw, 80px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  border-top: 1px solid rgba(201,169,110,.08);
}
.cta__h2 {
  font-size: clamp(40px, 5.5vw, 76px);
  font-weight: 400;
  color: var(--cream);
  margin-top: 8px;
  letter-spacing: 0.05em;
}
.cta__right p {
  font-family: var(--f-body);
  font-size: 14px;
  line-height: 1.8;
  color: var(--muted);
  margin-bottom: 40px;
  max-width: 380px;
}
.cta__actions { display: flex; gap: 16px; flex-wrap: wrap; }
.cta__visual { display: none; }

/* FOOTER
   ============================================================ */
.footer {
  background: #080604;
  padding: 80px clamp(24px, 6vw, 80px) 40px;
  border-top: 1px solid rgba(255,255,255,.04);
}
.footer__top {
  display: flex;
  justify-content: space-between;
  gap: 60px;
  padding-bottom: 64px;
  border-bottom: 1px solid rgba(255,255,255,.04);
  margin-bottom: 40px;
  flex-wrap: wrap;
  align-items: flex-start;
}
.footer__brand { display: flex; flex-direction: column; }

.footer__mascot {
  width: 56px;
  height: auto;
  color: var(--gold);
  opacity: .55;
  margin-bottom: 20px;
  transition: opacity .4s;
}
.footer__mascot:hover { opacity: .8; }

.footer__wordmark {
  font-family: var(--f-display);
  font-size: 26px;
  font-weight: 400;
  letter-spacing: 0.24em;
  color: var(--cream);
  margin-bottom: 8px;
}
.footer__claim {
  font-family: var(--f-body);
  font-size: 12px;
  color: var(--muted);
  letter-spacing: 0.06em;
}
.footer__nav {
  display: flex;
  gap: clamp(40px, 6vw, 96px);
  flex-wrap: wrap;
}
.footer__col {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.footer__col-title {
  font-family: var(--f-body);
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 4px;
}
.footer__col a {
  font-family: var(--f-body);
  font-size: 13px;
  color: rgba(245,237,216,.3);
  transition: color .3s;
}
.footer__col a:hover { color: var(--cream); }
.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  font-family: var(--f-body);
  font-size: 11px;
  color: rgba(255,255,255,.12);
}
.footer__legal { display: flex; gap: 24px; }
.footer__legal a { color: rgba(255,255,255,.12); transition: color .3s; }
.footer__legal a:hover { color: rgba(255,255,255,.35); }
.footer__est {
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  margin-top: 8px;
  opacity: .7;
}
.footer__compliance {
  width: 100%;
  font-size: 10px;
  letter-spacing: 0.12em;
  color: rgba(255,255,255,.2);
  text-align: center;
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,.06);
  margin-top: 4px;
}

/* CANS SHOWCASE
   ============================================================ */
.cans-showcase {
  background: var(--ink);
  padding: var(--gap-section) 0;
  border-top: 1px solid rgba(255,255,255,.04);
}

.cans-showcase__header {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  padding: 0 clamp(24px, 6vw, 80px);
  margin-bottom: 72px;
  align-items: end;
}
.cans-showcase__header-left h2 {
  font-size: clamp(36px, 5vw, 68px);
  color: var(--cream);
  letter-spacing: 0.05em;
}
.cans-showcase__header-right p {
  font-family: var(--f-body);
  font-size: 15px;
  line-height: 1.8;
  color: var(--muted);
  max-width: 420px;
  margin-bottom: 4px;
}

.cans-showcase__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  margin-bottom: 2px;
}

/* Each panel uses CSS object-position to isolate a different can */
.can-panel {
  position: relative;
  overflow: hidden;
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 1s var(--ease), transform 1s var(--ease);
  transition-delay: var(--delay, 0s);
}
.can-panel.in-view { opacity: 1; transform: none; }

.can-panel__img-wrap {
  overflow: hidden;
  aspect-ratio: 2/3;
  position: relative;
}
.can-panel__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.2s var(--ease);
  filter: brightness(.9);
}
.can-panel:hover .can-panel__img-wrap img {
  transform: scale(1.06);
  filter: brightness(1);
}

/* Crop each panel to isolate one can */
.can-panel--1 .can-panel__img-wrap img { object-position: 37% 55%; }
.can-panel--2 .can-panel__img-wrap img { object-position: 47% 55%; }
.can-panel--3 .can-panel__img-wrap img { object-position: 56% 55%; }

/* Gold line reveal on hover */
.can-panel__img-wrap::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 0%;
  height: 2px;
  background: var(--gold);
  transition: width .6s var(--ease);
}
.can-panel:hover .can-panel__img-wrap::after { width: 100%; }

/* Subtle dark overlay on each panel */
.can-panel__img-wrap::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(13,11,8,.75) 0%, rgba(13,11,8,.15) 50%, transparent 100%);
  z-index: 1;
  pointer-events: none;
}

.can-panel__info {
  padding: 28px 24px 32px;
  background: #0D0A07;
  border-top: 1px solid rgba(255,255,255,.04);
  border-right: 1px solid rgba(255,255,255,.03);
  transition: background .3s;
}
.can-panel:hover .can-panel__info { background: #140E09; }

.can-panel__num {
  display: block;
  font-family: var(--f-body);
  font-size: 10px;
  letter-spacing: 0.24em;
  color: var(--gold);
  margin-bottom: 12px;
}

.can-panel h3 {
  font-family: var(--f-display);
  font-size: clamp(16px, 1.8vw, 22px);
  font-weight: 400;
  letter-spacing: 0.06em;
  color: var(--cream);
  margin-bottom: 6px;
}

.can-panel__desc {
  font-family: var(--f-sub);
  font-size: 13px;
  font-style: italic;
  color: var(--muted);
  margin-bottom: 20px;
}

.can-panel__footer {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.04);
}

.can-panel__price {
  font-family: var(--f-display);
  font-size: clamp(20px, 2.2vw, 28px);
  font-weight: 400;
  color: var(--gold-lt);
  letter-spacing: 0.04em;
}

.can-panel__vol {
  font-family: var(--f-body);
  font-size: 10px;
  letter-spacing: 0.14em;
  color: var(--muted);
  text-transform: uppercase;
}

.cans-showcase__footer {
  background: #0D0A07;
  border-top: 1px solid rgba(255,255,255,.04);
  padding: 48px clamp(24px, 6vw, 80px);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0;
  opacity: 0;
  transform: translateY(20px);
  transition: all .9s var(--ease);
}
.cans-showcase__footer.in-view { opacity: 1; transform: none; }
.cans-showcase__note {
  font-size: 13px;
  font-weight: 300;
  letter-spacing: 0.06em;
  color: var(--muted);
  max-width: 480px;
}

.cans-showcase__pack {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.cans-showcase__pack-label {
  font-family: var(--f-body);
  font-size: 9px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--gold);
}
.cans-showcase__pack > p {
  font-family: var(--f-display);
  font-size: clamp(18px, 2vw, 24px);
  font-weight: 400;
  letter-spacing: 0.08em;
  color: var(--cream);
}
.cans-showcase__pack-price {
  font-family: var(--f-display);
  font-size: clamp(28px, 3.5vw, 48px);
  font-weight: 400;
  color: var(--gold-lt);
  letter-spacing: 0.04em;
}
.cans-showcase__pack-price em {
  font-family: var(--f-body);
  font-size: 13px;
  font-style: normal;
  color: var(--muted);
  letter-spacing: 0.04em;
}

/* RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .botanicals__strip { grid-template-columns: repeat(2, 1fr); }

  .editorial__frame {
    grid-template-columns: 1fr;
  }
  .editorial__img-wrap { min-height: 400px; }

  .story { grid-template-columns: 1fr; }
  .story__body { padding-top: 0; }
  .story__visual { aspect-ratio: 16/9; }

  .cta { grid-template-columns: 1fr; gap: 48px; }

  .products__grid { grid-template-columns: 1fr 1fr; }
  .cocktails__grid { grid-template-columns: 1fr 1fr; }

  .cans-showcase__header { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .nav__links, .nav__shop { display: none; }
  .nav__burger { display: flex; }

  .manifesto__stats { flex-direction: column; gap: 40px; }
  .m-stat__divider { width: 40px; height: 1px; margin: 0; }

  .botanicals__header { grid-template-columns: 1fr; }
  .botanicals__strip  { grid-template-columns: 1fr 1fr; }

  .ritual__steps { grid-template-columns: 1fr 1fr; }

  .hero__h1 { font-size: clamp(44px, 12vw, 72px); }
  .hero__h1--indent { padding-left: clamp(20px, 6vw, 60px); }

  .cans-showcase__grid { grid-template-columns: 1fr; }
  .can-panel--1 .can-panel__img-wrap img,
  .can-panel--2 .can-panel__img-wrap img,
  .can-panel--3 .can-panel__img-wrap img { object-position: 47% 55%; }
  .can-panel__img-wrap { aspect-ratio: 16/9; }

  .products__grid { grid-template-columns: 1fr; }
  .cocktails__grid { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .ritual__steps     { grid-template-columns: 1fr; }
  .editorial__frame  { min-height: unset; }
  .botanicals__strip { grid-template-columns: 1fr; }
  .manifesto__pillars { flex-direction: column; gap: 20px; }
}
