:root {
  --ink: #101715;
  --ink-2: #1e2a26;
  --paper: #f3efe7;
  --white: #fbfaf6;
  --muted: #6d7873;
  --line: rgba(16, 23, 21, 0.14);
  --lime: #dfff45;
  --mint: #bcefd9;
  --coral: #ff755f;
  --blue: #6db8ff;
  --navy: #132b3d;
  --heading: "Manrope", sans-serif;
  --body: "DM Sans", sans-serif;
  --radius: 22px;
  --shadow: 0 25px 60px rgba(22, 31, 28, 0.14);
}

/* Foundation */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--white);
  font-family: var(--body);
  -webkit-font-smoothing: antialiased;
}
body.is-locked { overflow: hidden; }
button, input, select { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
button { color: inherit; cursor: pointer; }
a { color: inherit; text-decoration: none; }
img, svg { display: block; }
svg { fill: none; stroke: currentColor; stroke-linecap: round; stroke-linejoin: round; }
[hidden] { display: none !important; }

.shell { width: min(1240px, calc(100% - 48px)); margin-inline: auto; }
.section { padding: 108px 0; }
.eyebrow {
  margin: 0 0 11px;
  color: #68756f;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.eyebrow--light { color: rgba(255,255,255,.56); }
.section-heading { margin-bottom: 42px; }
.section-heading--split { display: flex; align-items: end; justify-content: space-between; gap: 35px; }
.section-heading h2, .reviews h2, .newsletter h2 {
  max-width: 760px;
  margin: 0;
  font: 700 clamp(38px, 5vw, 62px)/.98 var(--heading);
  letter-spacing: -.07em;
}
.section-heading__copy {
  max-width: 330px;
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.7;
}
.section-footer { display: flex; justify-content: center; margin-top: 44px; }
.button {
  display: inline-flex;
  min-height: 51px;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 0 23px;
  border: 1px solid transparent;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  transition: transform .25s ease, background .25s ease, color .25s ease;
}
.button:hover { transform: translateY(-2px); }
.button--dark { color: white; background: var(--ink); }
.button--lime { color: var(--ink); background: var(--lime); }
.button--outline { border-color: var(--ink); background: transparent; }
.button--glass { color: white; border-color: rgba(255,255,255,.25); background: rgba(255,255,255,.08); backdrop-filter: blur(12px); }
.mobile-only { display: none; }

/* Global header */
.announcement {
  position: relative;
  z-index: 30;
  overflow: hidden;
  color: var(--ink);
  background: var(--lime);
}
.announcement__track {
  display: flex;
  min-height: 34px;
  align-items: center;
  justify-content: center;
  gap: 22px;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.announcement i { width: 3px; height: 3px; border-radius: 50%; background: currentColor; }

.site-header {
  position: relative;
  z-index: 25;
  border-bottom: 1px solid var(--line);
  background: rgba(251,250,246,.96);
}
.header-main {
  display: grid;
  min-height: 82px;
  grid-template-columns: 220px 1fr 310px;
  align-items: center;
  gap: 30px;
}
.brand { display: flex; width: fit-content; align-items: center; gap: 9px; }
.brand__mark {
  display: grid;
  width: 39px;
  height: 39px;
  flex: 0 0 auto;
  place-items: center;
  border-radius: 50%;
  color: var(--lime);
  background: var(--ink);
  font: 800 19px/1 var(--heading);
}
.brand > span:last-child { display: flex; flex-direction: column; gap: 3px; }
.brand b { font: 800 17px/1 var(--heading); letter-spacing: -.04em; }
.brand small { color: #78817d; font-size: 6px; font-weight: 800; letter-spacing: .23em; }
.search-bar {
  display: flex;
  height: 46px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 100px;
  background: white;
}
.search-bar input { min-width: 0; flex: 1; padding: 0 18px; border: 0; outline: 0; background: transparent; font-size: 11px; }
.search-bar button { display: grid; width: 51px; border: 0; place-items: center; color: white; background: var(--ink); }
.search-bar svg { width: 17px; stroke-width: 1.8; }
.header-actions { display: flex; align-items: center; justify-content: flex-end; gap: 7px; }
.header-action {
  display: flex;
  min-height: 42px;
  align-items: center;
  gap: 8px;
  padding: 0 10px;
  border: 1px solid transparent;
  border-radius: 100px;
  background: transparent;
  font-size: 10px;
  font-weight: 700;
}
.header-action:hover { border-color: var(--line); background: white; }
.header-action svg { width: 17px; stroke-width: 1.7; }
.header-action b {
  display: grid;
  min-width: 25px;
  height: 25px;
  padding: 0 5px;
  place-items: center;
  border-radius: 50%;
  background: var(--lime);
  font-size: 9px;
}
.category-nav { border-top: 1px solid var(--line); }
.category-nav .shell { display: flex; min-height: 42px; align-items: center; justify-content: center; gap: 42px; }
.category-nav a { position: relative; font-size: 10px; font-weight: 700; }
.category-nav a::after {
  position: absolute;
  right: 50%;
  bottom: -14px;
  left: 50%;
  height: 2px;
  background: var(--ink);
  content: "";
  transition: left .2s, right .2s;
}
.category-nav a:hover::after { right: 0; left: 0; }
.category-nav a.active::after { right: 0; left: 0; }
.category-nav .sale-link { color: #d54532; }

/* Campaign hero */
.hero {
  position: relative;
  min-height: 675px;
  overflow: hidden;
  color: white;
  background: #080e0c;
}
.hero__background {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(90deg, rgba(7,12,10,.96) 0%, rgba(7,12,10,.7) 43%, rgba(7,12,10,.03) 72%), url("../images/hero-devices-3d.png");
  background-position: center, center;
  background-size: cover;
  transform: translate3d(var(--motion-x, 0), var(--motion-y, 0), 0) scale(1.045);
  transition: transform .6s cubic-bezier(.2,.8,.2,1);
  animation: heroReveal 1.1s ease both;
}
.hero__background::after {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 70px 70px;
  content: "";
  mask-image: linear-gradient(to bottom, black, transparent);
}
.hero__inner { position: relative; display: flex; min-height: 625px; align-items: center; justify-content: space-between; }
.hero__copy { position: relative; z-index: 3; max-width: 620px; padding: 65px 0 88px; }
.hero__kicker { display: flex; align-items: center; gap: 10px; margin-bottom: 25px; color: rgba(255,255,255,.6); font-size: 9px; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; }
.hero__kicker span { width: 30px; height: 1px; background: var(--lime); }
.hero h1 { margin: 0; font: 700 clamp(68px, 7.4vw, 105px)/.89 var(--heading); letter-spacing: -.09em; }
.hero h1 em, .flavour-lab h2 em { color: var(--lime); font-family: Georgia, serif; font-weight: 400; letter-spacing: -.07em; }
.hero__copy > p { max-width: 505px; margin: 26px 0 31px; color: rgba(255,255,255,.64); font-size: 14px; line-height: 1.75; }
.hero__actions { display: flex; flex-wrap: wrap; gap: 8px; }
.hero__proof { display: flex; gap: 26px; margin-top: 47px; }
.hero__proof div { display: flex; flex-direction: column; gap: 3px; }
.hero__proof strong { font: 800 17px/1 var(--heading); letter-spacing: -.05em; }
.hero__proof span { color: rgba(255,255,255,.42); font-size: 7px; font-weight: 800; letter-spacing: .11em; text-transform: uppercase; }
.hero__deal {
  position: absolute;
  z-index: 4;
  right: 0;
  bottom: 44px;
  display: flex;
  width: 330px;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 15px;
  background: rgba(5,11,9,.57);
  backdrop-filter: blur(15px);
}
.hero__deal div { display: flex; min-width: 0; flex-direction: column; gap: 4px; }
.hero__deal p { margin: 0 0 5px; color: var(--lime); font-size: 7px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.hero__deal strong { overflow: hidden; font: 700 13px/1 var(--heading); text-overflow: ellipsis; white-space: nowrap; }
.hero__deal div > span { color: rgba(255,255,255,.43); font-size: 7px; }
.hero__deal button { display: grid; width: 45px; height: 45px; flex: 0 0 auto; border: 1px solid rgba(255,255,255,.18); border-radius: 50%; place-items: center; color: white; background: rgba(255,255,255,.07); font-size: 8px; font-weight: 800; }
.hero__deal button span { display: block; font-size: 11px; }
.hero__ticker { position: absolute; z-index: 5; right: 0; bottom: 0; left: 0; overflow: hidden; border-top: 1px solid rgba(255,255,255,.12); background: rgba(0,0,0,.3); }
.hero__ticker div { display: flex; width: max-content; gap: 34px; padding: 15px 0; animation: ticker 28s linear infinite; color: rgba(255,255,255,.5); font-size: 7px; font-weight: 800; letter-spacing: .2em; }
.hero__ticker b { color: var(--lime); }
.smoke { position: absolute; z-index: 2; width: 370px; height: 140px; border: 18px solid rgba(197,255,203,.08); border-radius: 50%; filter: blur(20px); pointer-events: none; }
.smoke--one { right: 18%; bottom: 16%; animation: smokeDrift 9s ease-in-out infinite; }
.smoke--two { top: 12%; right: 5%; animation: smokeDrift 11s ease-in-out -4s infinite reverse; }
.motion-atmosphere {
  position: absolute;
  z-index: 1;
  inset: -15%;
  overflow: hidden;
  pointer-events: none;
  transform: translate3d(calc(var(--motion-x, 0) * -.45), calc(var(--motion-y, 0) * -.45), 0);
  transition: transform .8s cubic-bezier(.2,.8,.2,1);
}
.motion-atmosphere i {
  position: absolute;
  width: 520px;
  height: 150px;
  border: 22px solid rgba(214,255,223,.065);
  border-right-color: transparent;
  border-left-color: transparent;
  border-radius: 50%;
  filter: blur(18px);
  opacity: .35;
  mix-blend-mode: screen;
  animation: vapourRibbon 14s ease-in-out infinite;
}
.motion-atmosphere i:nth-child(1) { right: 2%; bottom: 13%; }
.motion-atmosphere i:nth-child(2) { top: 18%; right: 22%; width: 380px; height: 110px; animation-delay: -5s; animation-duration: 17s; }
.motion-atmosphere i:nth-child(3) { right: -12%; bottom: 37%; width: 660px; height: 180px; animation-delay: -9s; animation-duration: 20s; }

/* Trust and catalogue */
.trust-row { border-bottom: 1px solid var(--line); background: var(--paper); }
.trust-row__grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.trust-row article { display: flex; min-height: 90px; align-items: center; gap: 13px; padding: 18px 20px; border-right: 1px solid var(--line); }
.trust-row article:first-child { border-left: 1px solid var(--line); }
.trust-row article > span { display: grid; width: 33px; height: 33px; flex: 0 0 auto; place-items: center; border-radius: 50%; background: var(--lime); font: 800 8px/1 var(--heading); }
.trust-row article div { display: flex; flex-direction: column; gap: 4px; }
.trust-row strong { font: 700 11px/1 var(--heading); }
.trust-row small { color: var(--muted); font-size: 8px; }

/* Page templates */
.page-hero {
  position: relative;
  display: flex;
  min-height: 475px;
  overflow: hidden;
  align-items: center;
  color: white;
  background: var(--ink);
}
.page-hero::before {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(90deg, rgba(5,11,9,.96), rgba(5,11,9,.55) 55%, rgba(5,11,9,.1)), url("../images/hero-devices-3d.png");
  background-position: center;
  background-size: cover;
  content: "";
  transform: translate3d(var(--motion-x, 0), var(--motion-y, 0), 0) scale(1.055);
  transition: transform .7s cubic-bezier(.2,.8,.2,1);
}
.page-hero::after {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 70px 70px;
  content: "";
  mask-image: linear-gradient(to bottom, black, transparent);
}
.page-hero--brands::before { filter: hue-rotate(20deg) saturate(.75); }
.page-hero--shop::before {
  background-image: linear-gradient(90deg, rgba(5,11,9,.96), rgba(5,11,9,.55) 55%, rgba(5,11,9,.08)), url("../images/smoke-lifestyle-3d.png");
}
.page-hero--delivery::before { filter: hue-rotate(-20deg) saturate(.7); background-position: 60% center; }
.page-hero--about::before { filter: grayscale(.35) sepia(.12); background-position: 70% center; }
.page-hero .shell { position: relative; z-index: 2; padding: 65px 0; }
.page-hero h1, .flavour-lab h1 {
  max-width: 780px;
  margin: 0;
  font: 700 clamp(58px, 7.5vw, 94px)/.9 var(--heading);
  letter-spacing: -.09em;
}
.page-hero h1 em, .flavour-lab h1 em { color: var(--lime); font-family: Georgia, serif; font-weight: 400; letter-spacing: -.07em; }
.page-hero p:not(.eyebrow) { max-width: 520px; margin: 24px 0 0; color: rgba(255,255,255,.62); font-size: 13px; line-height: 1.75; }
.text-link { padding-bottom: 5px; border-bottom: 1px solid currentColor; font-size: 10px; font-weight: 800; }
.home-paths { background: var(--paper); }
.path-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px; }
.path-card {
  position: relative;
  display: flex;
  min-height: 285px;
  overflow: hidden;
  flex-direction: column;
  align-items: flex-start;
  padding: 30px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  transition: transform .25s ease, box-shadow .25s ease;
}
.path-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.path-card::after { position: absolute; right: -35px; bottom: -80px; width: 230px; height: 230px; border: 28px solid rgba(16,23,21,.1); border-radius: 50%; content: ""; }
.path-card:hover::after { animation: pathOrbit 5s linear infinite; }
.path-card--shop { background: var(--mint); }
.path-card--flavour { color: white; background: var(--navy); }
.path-card--brand { background: #e9e1d1; }
.path-card--delivery { background: var(--coral); }
.path-card span { font-size: 7px; font-weight: 800; letter-spacing: .16em; opacity: .55; text-transform: uppercase; }
.path-card h3 { max-width: 390px; margin: 22px 0 8px; font: 700 clamp(30px,4vw,48px)/1 var(--heading); letter-spacing: -.07em; }
.path-card p { max-width: 330px; margin: 0; font-size: 10px; line-height: 1.6; opacity: .65; }
.path-card b { margin-top: auto; padding-bottom: 4px; border-bottom: 1px solid currentColor; font-size: 9px; }
.featured-preview { background: var(--white); }
.catalogue-help { padding: 75px 0; color: white; background: var(--navy); }
.catalogue-help__inner { display: flex; align-items: end; justify-content: space-between; gap: 35px; }
.catalogue-help h2 { margin: 0; font: 700 clamp(36px,5vw,60px)/1 var(--heading); letter-spacing: -.07em; }
.catalogue-help p:not(.eyebrow) { max-width: 530px; margin: 17px 0 0; color: rgba(255,255,255,.58); font-size: 11px; line-height: 1.7; }
.catalogue-help__inner > div:last-child { display: flex; gap: 7px; }
.brand-proof { background: var(--white); }
.flavour-lab--page, .flavour-lab--page .flavour-lab__inner { min-height: 570px; }
.flavour-lab--page .flavour-lab__copy { max-width: 620px; }
.flavour-guide { background: var(--paper); }
.flavour-guide__grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; }
.flavour-guide__grid button { min-height: 250px; padding: 24px; border: 1px solid var(--line); border-radius: 17px; text-align: left; transition: transform .25s ease; }
.flavour-guide__grid button:hover { transform: translateY(-5px); }
.flavour-guide__grid button:nth-child(1) { background: #dbeef2; }
.flavour-guide__grid button:nth-child(2) { background: #eaddec; }
.flavour-guide__grid button:nth-child(3) { background: #f5dfb7; }
.flavour-guide__grid button:nth-child(4) { background: #f1d4cd; }
.flavour-guide__grid span { font-size: 7px; font-weight: 800; letter-spacing: .15em; opacity: .55; text-transform: uppercase; }
.flavour-guide__grid h3 { margin: 75px 0 8px; font: 700 25px/1 var(--heading); letter-spacing: -.06em; }
.flavour-guide__grid p { margin: 0; color: var(--muted); font-size: 9px; line-height: 1.6; }
.flavour-results { background: var(--white); }
.delivery-page { background: var(--white); }
.delivery-page__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.delivery-page .delivery-card { min-height: 500px; }
.delivery-steps { display: grid; gap: 10px; }
.delivery-steps article { position: relative; display: flex; min-height: 155px; flex-direction: column; justify-content: center; padding: 28px; border: 1px solid var(--line); border-radius: 17px; background: var(--paper); }
.delivery-steps span { position: absolute; top: 20px; right: 20px; color: #8b9490; font-size: 7px; font-weight: 800; letter-spacing: .15em; }
.delivery-steps h3 { margin: 0 0 8px; font: 700 20px/1 var(--heading); letter-spacing: -.05em; }
.delivery-steps p { margin: 0; color: var(--muted); font-size: 9px; line-height: 1.6; }
.shipping-options { background: var(--paper); }
.brand-story { background: var(--white); }
.brand-story__grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 80px; }
.brand-story h2 { margin: 0; font: 700 clamp(42px,5vw,65px)/1 var(--heading); letter-spacing: -.075em; }
.brand-story__grid > div:last-child { padding-top: 20px; }
.brand-story__grid > div:last-child p { margin: 0 0 20px; color: var(--muted); font-size: 12px; line-height: 1.9; }
.faq-section { background: var(--white); }
.faq-list { border-top: 1px solid var(--line); }
.faq-list details { border-bottom: 1px solid var(--line); }
.faq-list summary { display: flex; align-items: center; justify-content: space-between; padding: 25px 0; cursor: pointer; font: 700 18px/1.3 var(--heading); letter-spacing: -.04em; list-style: none; }
.faq-list summary::-webkit-details-marker { display: none; }
.faq-list summary span { font-size: 20px; font-weight: 400; }
.faq-list details[open] summary span { transform: rotate(45deg); }
.faq-list p { max-width: 700px; margin: -8px 0 25px; color: var(--muted); font-size: 10px; line-height: 1.75; }

.shop-section { background: var(--white); }
.shop-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 25px; margin-bottom: 25px; }
.filter-tabs { display: flex; gap: 5px; padding: 4px; border: 1px solid var(--line); border-radius: 100px; background: white; }
.filter-tabs button { min-height: 36px; padding: 0 15px; border: 0; border-radius: 100px; color: #707a76; background: transparent; font-size: 9px; font-weight: 800; }
.filter-tabs button.active { color: white; background: var(--ink); }
.shop-toolbar__right { display: flex; align-items: center; gap: 17px; }
.shop-toolbar__right span { color: var(--muted); font-size: 9px; font-weight: 700; }
.shop-toolbar select { min-height: 38px; padding: 0 30px 0 13px; border: 1px solid var(--line); border-radius: 100px; outline: 0; color: var(--ink); background: white; font-size: 9px; font-weight: 700; }
.product-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.product-card {
  --tilt-x: 0deg;
  --tilt-y: 0deg;
  position: relative;
  min-width: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: white;
  transform: perspective(900px) rotateX(var(--tilt-x)) rotateY(var(--tilt-y));
  transform-style: preserve-3d;
  transition: transform .22s ease, box-shadow .3s ease;
}
.product-card::after {
  position: absolute;
  z-index: 5;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(circle at var(--shine-x, 50%) var(--shine-y, 50%), rgba(255,255,255,.4), transparent 32%);
  content: "";
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
}
.product-card:hover { transform: perspective(900px) translateY(-6px) rotateX(var(--tilt-x)) rotateY(var(--tilt-y)); box-shadow: var(--shadow); }
.product-card:hover::after { opacity: .7; }
.product-card__visual {
  position: relative;
  display: grid;
  height: 280px;
  overflow: hidden;
  place-items: center;
  background: var(--card-bg, #f0ede7);
}
.product-card__visual::before {
  position: absolute;
  width: 170px;
  height: 170px;
  border-radius: 50%;
  background: var(--card-glow, rgba(188,239,217,.5));
  content: "";
  filter: blur(25px);
  opacity: .75;
  transition: transform .45s ease;
}
.product-card:hover .product-card__visual::before { transform: scale(1.2); }
.product-visual {
  position: relative;
  z-index: 2;
  display: grid;
  width: 160px;
  height: 220px;
  place-items: center;
  filter: drop-shadow(0 22px 16px rgba(0,0,0,.2));
  transition: transform .35s ease;
}
.product-card:hover .product-visual { transform: translateY(-6px) scale(1.045); }
.product-card:hover .product-visual__object { animation: productHoverFloat 2.7s ease-in-out infinite; }
.product-visual__object {
  position: relative;
  display: grid;
  width: 82px;
  height: 180px;
  overflow: hidden;
  place-items: center;
  transform: rotate(var(--visual-turn));
  border: 1px solid rgba(255,255,255,.55);
  border-radius: 18px;
  color: white;
  background: linear-gradient(155deg,
    hsl(calc(var(--visual-seed) * 31) 82% 72%),
    hsl(calc(var(--visual-seed) * 31 + 45) 70% 50%) 56%,
    hsl(calc(var(--visual-seed) * 31 + 90) 65% 31%));
  box-shadow: inset 6px 0 10px rgba(255,255,255,.3), inset -7px 0 13px rgba(0,0,0,.2);
}
.product-visual__object::before {
  position: absolute;
  top: -3px;
  left: 25%;
  width: 50%;
  height: 15px;
  border-radius: 0 0 8px 8px;
  background: #17201e;
  content: "";
}
.product-visual__object::after {
  position: absolute;
  top: 22%;
  left: 50%;
  width: 45px;
  height: 45px;
  transform: translateX(-50%);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 50%;
  background: rgba(12,20,18,.88);
  content: "";
}
.product-visual__object b {
  position: absolute;
  z-index: 2;
  top: calc(22% + 17px);
  left: 50%;
  transform: translateX(-50%);
  color: var(--lime);
  font: 800 10px/1 var(--heading);
}
.product-visual__object span {
  position: absolute;
  right: 0;
  bottom: 21%;
  left: 0;
  font: 800 7px/1 var(--heading);
  letter-spacing: .15em;
  text-align: center;
}
.product-visual__object i:first-child {
  position: absolute;
  top: 7%;
  right: 9%;
  width: 8%;
  height: 70%;
  border-radius: 100%;
  background: rgba(255,255,255,.3);
  filter: blur(2px);
}
.product-visual__shadow {
  position: absolute;
  bottom: 7px;
  left: 50%;
  width: 95px;
  height: 16px;
  transform: translateX(-50%);
  border-radius: 50%;
  background: rgba(0,0,0,.16);
  filter: blur(9px);
}
.product-visual--pods .product-visual__object {
  width: 74px;
  height: 145px;
  border-radius: 16px 16px 32px 32px;
}
.product-visual--liquid .product-visual__object {
  width: 93px;
  height: 133px;
  overflow: visible;
  border: 4px solid #17201e;
  border-radius: 12px 12px 22px 22px;
}
.product-visual--liquid .product-visual__object::before {
  top: -29px;
  left: 22px;
  width: 42px;
  height: 29px;
  border-radius: 7px 7px 0 0;
}
.product-visual--liquid .product-visual__object::after { top: 22px; width: 65px; height: 65px; border-radius: 7px; }
.product-visual--liquid .product-visual__object b { top: 48px; color: var(--lime); }
.product-visual--liquid .product-visual__object span { bottom: 9px; }
.product-visual--device .product-visual__object {
  width: 115px;
  height: 145px;
  border-radius: 18px 18px 26px 26px;
}
.product-visual--glass .product-visual__object {
  width: 82px;
  height: 178px;
  overflow: visible;
  border: 7px solid rgba(46,139,155,.65);
  border-radius: 15px 15px 38px 38px;
  background: linear-gradient(145deg, rgba(166,243,255,.72), rgba(61,151,180,.2));
  box-shadow: inset 5px 0 10px rgba(255,255,255,.55), 0 18px 22px rgba(31,85,98,.2);
  backdrop-filter: blur(2px);
}
.product-visual--glass .product-visual__object::before {
  top: -55px;
  left: 26px;
  width: 17px;
  height: 60px;
  border: 6px solid rgba(46,139,155,.65);
  border-radius: 9px 9px 0 0;
  background: rgba(190,247,255,.48);
}
.product-visual--glass .product-visual__object::after {
  top: 25px;
  left: auto;
  right: -35px;
  width: 47px;
  height: 13px;
  transform: rotate(-40deg);
  border: 5px solid rgba(46,139,155,.65);
  border-radius: 10px;
  background: rgba(190,247,255,.5);
}
.product-visual--glass .product-visual__object b { top: 80px; color: #12353c; }
.product-visual--glass .product-visual__object span { bottom: 22px; color: #12353c; }
.product-visual--rolling .product-visual__object {
  width: 135px;
  height: 82px;
  border-radius: 8px;
  background: linear-gradient(155deg, #eee7d3, hsl(calc(var(--visual-seed) * 31) 65% 57%));
}
.product-visual--rolling .product-visual__object::before { display: none; }
.product-visual--rolling .product-visual__object::after { top: 12px; width: 54px; height: 54px; }
.product-visual--rolling .product-visual__object b { top: 34px; }
.product-visual--rolling .product-visual__object span { right: auto; bottom: 8px; left: 10px; }
.product-visual--hookah .product-visual__object {
  width: 110px;
  height: 120px;
  overflow: visible;
  border-radius: 50% 50% 32% 32%;
}
.product-visual--hookah .product-visual__object::before {
  top: -73px;
  left: 47px;
  width: 10px;
  height: 78px;
  border-radius: 5px;
}
.product-visual--hookah .product-visual__object::after {
  top: -90px;
  width: 58px;
  height: 17px;
  border-radius: 50%;
  background: #17201e;
}
.product-visual--hookah .product-visual__object b { top: 43px; }
.product-visual--cigar .product-visual__object {
  width: 155px;
  height: 28px;
  border-color: #60391f;
  border-radius: 20px;
  background: linear-gradient(90deg, #4c2918, #9d6337 45%, #5d331d);
}
.product-visual--cigar .product-visual__object::before { top: 0; left: 65%; width: 22px; height: 100%; border-radius: 1px; background: #d0aa62; }
.product-visual--cigar .product-visual__object::after { display: none; }
.product-visual--cigar .product-visual__object b { display: none; }
.product-visual--cigar .product-visual__object span { bottom: 9px; font-size: 5px; }
.product-visual--accessory .product-visual__object {
  width: 120px;
  height: 120px;
  border: 14px solid #17201e;
  border-radius: 50%;
  background: hsl(calc(var(--visual-seed) * 31) 62% 60%);
}
.product-visual--accessory .product-visual__object::before { top: 27px; left: 27px; width: 38px; height: 38px; border: 5px solid rgba(255,255,255,.48); border-radius: 50%; background: transparent; }
.product-visual--accessory .product-visual__object::after { display: none; }
.product-visual--accessory .product-visual__object b { top: 50px; color: white; }
.product-visual--accessory .product-visual__object span { bottom: 15px; }
.product-visual--mini { width: 65px; height: 72px; filter: none; transform: scale(.37); }
.product-visual--large { width: 360px; height: 470px; transform: scale(1.75); }
.product-visual--large .product-visual__shadow { bottom: 85px; }
.product-card__image {
  position: relative;
  z-index: 2;
  width: 82%;
  height: 82%;
  object-fit: contain;
  mix-blend-mode: multiply;
  filter: drop-shadow(0 18px 15px rgba(0,0,0,.18));
  transition: transform .35s ease;
}
.product-card:hover .product-card__image { transform: translateY(-5px) scale(1.045) rotate(-1deg); }
.product-card__badges { position: absolute; z-index: 4; top: 12px; left: 12px; display: flex; gap: 5px; }
.product-card__badges span { padding: 6px 8px; border-radius: 100px; color: white; background: var(--ink); font-size: 6px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.product-card__badges .sale { color: var(--ink); background: var(--lime); }
.product-card__wishlist {
  position: absolute;
  z-index: 5;
  top: 10px;
  right: 10px;
  display: grid;
  width: 34px;
  height: 34px;
  border: 1px solid rgba(16,23,21,.1);
  border-radius: 50%;
  place-items: center;
  background: rgba(255,255,255,.84);
  backdrop-filter: blur(10px);
}
.product-card__wishlist svg { width: 14px; stroke-width: 1.8; }
.product-card__wishlist.active { color: #d94c52; background: white; }
.product-card__wishlist.active svg { fill: currentColor; }
.product-card__quick {
  position: absolute;
  z-index: 5;
  right: 12px;
  bottom: 12px;
  left: 12px;
  min-height: 40px;
  transform: translateY(58px);
  border: 0;
  border-radius: 100px;
  color: white;
  background: var(--ink);
  font-size: 9px;
  font-weight: 800;
  opacity: 0;
  transition: transform .25s ease, opacity .25s ease;
}
.product-card:hover .product-card__quick { transform: translateY(0); opacity: 1; }
.product-card__info { padding: 17px; }
.product-card__meta { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 7px; color: #7b8581; font-size: 7px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.stock { display: inline-flex; align-items: center; gap: 4px; color: #4f7860; }
.stock::before { width: 5px; height: 5px; border-radius: 50%; background: #61a66f; content: ""; }
.product-card h3 { min-height: 40px; margin: 0; font: 700 14px/1.35 var(--heading); letter-spacing: -.035em; }
.product-card__flavours { margin: 8px 0 0; color: var(--muted); font-size: 8px; }
.product-card__bottom { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-top: 14px; }
.product-card__price { display: flex; flex-direction: column; font: 800 14px/1 var(--heading); }
.product-card__price del { margin-bottom: 4px; color: #9aa19e; font-size: 8px; font-weight: 600; }
.product-card__add { display: grid; width: 35px; height: 35px; border: 1px solid var(--line); border-radius: 50%; place-items: center; background: transparent; font-size: 17px; transition: background .2s; }
.product-card__add:hover { background: var(--lime); }

/* Discovery and merchandising */
.brand-wall { background: var(--paper); }
.brand-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 10px; }
.brand-tile {
  position: relative;
  display: flex;
  min-height: 145px;
  overflow: hidden;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  padding: 17px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--white);
  transition: transform .25s ease, color .25s ease, background .25s ease;
}
.brand-tile:hover { transform: translateY(-4px); color: white; background: var(--ink); }
.brand-tile span { color: #8a938f; font-size: 7px; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; }
.brand-tile strong { font: 800 20px/1 var(--heading); letter-spacing: -.06em; }
.brand-tile b { font-size: 13px; font-weight: 500; transition: transform .2s ease; }
.brand-tile:hover b { transform: translate(3px,-3px); }

.flavour-lab { position: relative; min-height: 650px; overflow: hidden; color: white; background: #050b09; }
.flavour-lab__background {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(90deg, #050b09 0%, rgba(5,11,9,.88) 35%, rgba(5,11,9,.08) 72%), url("../images/flavour-spectrum-3d.png");
  background-position: center;
  background-size: cover;
  transform: translate3d(var(--motion-x, 0), var(--motion-y, 0), 0) scale(1.045);
  transition: filter .6s ease, transform .6s ease;
}
.flavour-lab.is-ice .flavour-lab__background { filter: hue-rotate(5deg) saturate(1.2); transform: translate3d(var(--motion-x, 0), var(--motion-y, 0), 0) scale(1.065); }
.flavour-lab.is-berry .flavour-lab__background { filter: hue-rotate(22deg) saturate(1.2); transform: translate3d(var(--motion-x, 0), var(--motion-y, 0), 0) scale(1.065); }
.flavour-lab.is-tropical .flavour-lab__background { filter: hue-rotate(-20deg) saturate(1.25); transform: translate3d(var(--motion-x, 0), var(--motion-y, 0), 0) scale(1.065); }
.flavour-lab.is-fruit .flavour-lab__background { filter: saturate(1.35); transform: translate3d(var(--motion-x, 0), var(--motion-y, 0), 0) scale(1.065); }
.flavour-lab__inner { position: relative; z-index: 2; display: flex; min-height: 650px; align-items: center; }
.flavour-lab__copy { max-width: 520px; }
.flavour-lab h2 { margin: 0; font: 700 clamp(50px, 7vw, 82px)/.93 var(--heading); letter-spacing: -.08em; }
.flavour-lab__copy > p:not(.eyebrow) { max-width: 420px; margin: 25px 0 30px; color: rgba(255,255,255,.58); font-size: 13px; line-height: 1.75; }
.flavour-pills { display: flex; flex-wrap: wrap; gap: 7px; }
.flavour-pills button { display: flex; min-height: 40px; align-items: center; gap: 8px; padding: 0 14px; border: 1px solid rgba(255,255,255,.2); border-radius: 100px; color: white; background: rgba(255,255,255,.06); backdrop-filter: blur(12px); font-size: 9px; font-weight: 700; transition: background .2s, color .2s; }
.flavour-pills button:hover { color: var(--ink); background: white; }
.pill-dot { width: 8px; height: 8px; border-radius: 50%; box-shadow: 0 0 15px currentColor; }
.pill-dot--ice { color: var(--blue); background: currentColor; }
.pill-dot--berry { color: #d45eac; background: currentColor; }
.pill-dot--tropical { color: #ffb53e; background: currentColor; }
.pill-dot--fruit { color: var(--coral); background: currentColor; }
.flavour-particle { position: absolute; z-index: 2; width: 18px; height: 18px; border-radius: 50%; background: var(--lime); box-shadow: 0 0 24px var(--lime); opacity: .5; pointer-events: none; }
.flavour-particle--one { top: 18%; right: 30%; animation: particleFloat 7s ease-in-out infinite; }
.flavour-particle--two { right: 10%; bottom: 20%; width: 9px; height: 9px; animation: particleFloat 9s ease-in-out -3s infinite reverse; }

.bundles { background: var(--white); }
.bundles__grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: 16px; }
.bundle-card, .delivery-card { min-height: 430px; overflow: hidden; border: 1px solid var(--line); border-radius: var(--radius); }
.bundle-card { position: relative; display: flex; align-items: center; padding: 45px; color: white; background: var(--navy); }
.bundle-card::before { position: absolute; inset: 0; background-image: radial-gradient(circle at 80% 40%, rgba(98,177,255,.35), transparent 37%), linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px); background-size: auto, 50px 50px, 50px 50px; content: ""; }
.bundle-card > div:first-child { position: relative; z-index: 3; max-width: 380px; }
.bundle-card h3, .delivery-card h3 { margin: 0; font: 700 clamp(34px, 4.3vw, 54px)/1 var(--heading); letter-spacing: -.07em; }
.bundle-card p:not(.eyebrow), .delivery-card > p:not(.eyebrow) { max-width: 350px; margin: 19px 0 24px; color: rgba(255,255,255,.56); font-size: 11px; line-height: 1.7; }
.bundle-stack { position: absolute; right: 35px; bottom: -35px; width: 260px; height: 370px; }
.bundle-stack i { position: absolute; right: 65px; bottom: 0; width: 100px; height: 290px; border: 1px solid rgba(255,255,255,.3); border-radius: 20px; background: linear-gradient(160deg,#e8ff5c,#55af60); box-shadow: inset 6px 0 10px rgba(255,255,255,.3), inset -6px 0 14px rgba(0,0,0,.2), 0 25px 35px rgba(0,0,0,.27); }
.bundle-stack i::before { position: absolute; top: 25%; left: 50%; display: grid; width: 54px; height: 54px; transform: translateX(-50%); border-radius: 50%; place-items: center; color: var(--lime); background: var(--ink); content: "50K"; font: 800 12px/1 var(--heading); }
.bundle-stack i:nth-child(2) { right: 0; bottom: -12px; height: 275px; transform: rotate(9deg); background: linear-gradient(160deg,#ffbe8c,#f16068); }
.bundle-stack i:nth-child(3) { right: 130px; bottom: -15px; height: 265px; transform: rotate(-10deg); background: linear-gradient(160deg,#a3eaff,#4c73e8); }
.delivery-card { display: flex; flex-direction: column; justify-content: center; padding: 45px; background: var(--paper); }
.delivery-card > p:not(.eyebrow) { color: var(--muted); }
.delivery-card form { display: flex; gap: 7px; margin-top: 5px; }
.delivery-card input { min-width: 0; flex: 1; padding: 0 17px; border: 1px solid var(--line); border-radius: 100px; outline: 0; background: white; font-size: 11px; font-weight: 700; text-transform: uppercase; }
.delivery-result { min-height: 34px; margin-top: 15px; color: #3b6b4c; font-size: 10px; font-weight: 700; line-height: 1.5; }

.why-us { background: var(--paper); }
.benefit-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.benefit-grid article { position: relative; padding: 25px; border: 1px solid var(--line); border-radius: 17px; background: var(--white); }
.benefit-grid article > span { position: absolute; top: 20px; right: 20px; color: #919a96; font-size: 7px; font-weight: 800; letter-spacing: .14em; }
.benefit-icon { display: grid; width: 47px; height: 47px; margin-bottom: 42px; border-radius: 50%; place-items: center; background: var(--lime); font: 800 12px/1 var(--heading); }
.benefit-grid h3 { margin: 0 0 9px; font: 700 16px/1.2 var(--heading); letter-spacing: -.04em; }
.benefit-grid p { margin: 0; color: var(--muted); font-size: 9px; line-height: 1.7; }

/* Social proof and footer */
.reviews { padding: 100px 0; color: white; background: var(--ink); }
.reviews__heading { display: flex; align-items: end; justify-content: space-between; gap: 30px; margin-bottom: 45px; }
.rating { display: grid; grid-template-columns: auto auto; align-items: center; gap: 3px 12px; }
.rating strong { grid-row: 1 / 3; font: 800 48px/1 var(--heading); letter-spacing: -.08em; }
.rating span { color: var(--lime); font-size: 11px; letter-spacing: .1em; }
.rating small { color: rgba(255,255,255,.42); font-size: 7px; letter-spacing: .09em; text-transform: uppercase; }
.review-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.review-grid article { padding: 27px; border: 1px solid rgba(255,255,255,.13); border-radius: 17px; background: rgba(255,255,255,.035); }
.review-grid article > span { color: var(--lime); font-size: 9px; letter-spacing: .1em; }
.review-grid article > p { min-height: 100px; margin: 23px 0 29px; color: rgba(255,255,255,.78); font: 600 15px/1.55 var(--heading); letter-spacing: -.025em; }
.review-grid footer { display: flex; align-items: center; gap: 11px; }
.review-grid footer > b { display: grid; width: 36px; height: 36px; place-items: center; border-radius: 50%; color: var(--ink); background: var(--mint); font-size: 8px; }
.review-grid footer div { display: flex; flex-direction: column; gap: 2px; }
.review-grid footer strong { font-size: 9px; }
.review-grid footer small { color: rgba(255,255,255,.4); font-size: 7px; }

.newsletter { padding: 80px 0; background: var(--lime); }
.newsletter__inner { display: grid; grid-template-columns: 1fr .85fr; align-items: end; gap: 90px; }
.newsletter form { display: flex; flex-direction: column; gap: 11px; }
.newsletter label { font-size: 10px; font-weight: 700; }
.newsletter form > div { display: flex; gap: 7px; }
.newsletter input { min-width: 0; flex: 1; padding: 0 17px; border: 1px solid rgba(16,23,21,.28); border-radius: 100px; outline: 0; background: rgba(255,255,255,.55); font-size: 11px; }
.newsletter small { font-size: 7px; opacity: .6; }

.footer { padding-top: 75px; color: white; background: #090e0c; }
.footer__grid { display: grid; grid-template-columns: 1.3fr repeat(3,.7fr); gap: 55px; padding-bottom: 65px; }
.brand--footer .brand__mark { color: var(--ink); background: var(--lime); }
.brand--footer small { color: rgba(255,255,255,.4); }
.footer__intro > p { max-width: 265px; margin: 20px 0; color: rgba(255,255,255,.43); font-size: 10px; line-height: 1.7; }
.footer__status { display: flex; align-items: center; gap: 7px; color: rgba(255,255,255,.56); font-size: 8px; font-weight: 700; }
.footer__status i { width: 6px; height: 6px; border-radius: 50%; background: var(--lime); box-shadow: 0 0 10px var(--lime); }
.footer h3 { margin: 0 0 19px; color: rgba(255,255,255,.4); font-size: 7px; letter-spacing: .17em; text-transform: uppercase; }
.footer__grid > div:not(.footer__intro) { display: flex; flex-direction: column; align-items: flex-start; gap: 10px; }
.footer a, .footer p { margin: 0; color: rgba(255,255,255,.7); font-size: 9px; line-height: 1.7; }
.footer strong { color: white; }
.footer__bottom { display: flex; min-height: 63px; align-items: center; justify-content: space-between; gap: 18px; border-top: 1px solid rgba(255,255,255,.1); color: rgba(255,255,255,.35); font-size: 7px; letter-spacing: .06em; }

/* Commerce overlays */
.age-gate { position: fixed; z-index: 120; inset: 0; display: grid; padding: 20px; place-items: center; transition: opacity .35s, visibility .35s; }
.age-gate.is-hidden { visibility: hidden; opacity: 0; }
.age-gate__backdrop { position: absolute; inset: 0; background: rgba(6,10,8,.84); backdrop-filter: blur(14px); }
.age-card { position: relative; width: min(510px,100%); padding: 42px; border: 1px solid rgba(255,255,255,.5); border-radius: 22px; background: var(--white); box-shadow: 0 35px 80px rgba(0,0,0,.33); text-align: center; }
.brand--age { margin: 0 auto 30px; }
.age-card h1 { margin: 0 0 13px; font: 700 42px/1 var(--heading); letter-spacing: -.07em; }
.age-card > p:not(.eyebrow) { max-width: 390px; margin: 0 auto 23px; color: var(--muted); font-size: 11px; line-height: 1.7; }
.age-card__actions { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; }
.age-card > small { display: block; margin-top: 18px; color: #8b9490; font-size: 7px; line-height: 1.5; }

.drawer, .wishlist-panel, .quick-view, .search-overlay { position: fixed; z-index: 100; inset: 0; visibility: hidden; opacity: 0; transition: opacity .3s, visibility .3s; }
.drawer.is-open, .wishlist-panel.is-open, .quick-view.is-open, .search-overlay.is-open { visibility: visible; opacity: 1; }
.drawer__backdrop, .wishlist-panel__backdrop, .quick-view__backdrop, .search-overlay__backdrop { position: absolute; inset: 0; background: rgba(7,12,10,.57); backdrop-filter: blur(5px); }
.drawer__panel, .wishlist-panel__inner {
  position: absolute;
  top: 0;
  right: 0;
  display: flex;
  width: min(450px,100%);
  height: 100%;
  flex-direction: column;
  transform: translateX(100%);
  background: var(--white);
  transition: transform .35s ease;
}
.drawer.is-open .drawer__panel, .wishlist-panel.is-open .wishlist-panel__inner { transform: translateX(0); }
.drawer header, .wishlist-panel header { display: flex; align-items: center; justify-content: space-between; padding: 24px; border-bottom: 1px solid var(--line); }
.drawer header .eyebrow, .wishlist-panel header .eyebrow { margin-bottom: 4px; }
.drawer h2, .wishlist-panel h2 { margin: 0; font: 700 26px/1 var(--heading); letter-spacing: -.06em; }
.drawer header button, .wishlist-panel header button, .search-overlay__top button, .quick-view__close {
  display: grid;
  width: 39px;
  height: 39px;
  border: 1px solid var(--line);
  border-radius: 50%;
  place-items: center;
  background: white;
  font-size: 21px;
  font-weight: 300;
}
.shipping-meter { padding: 15px 24px; border-bottom: 1px solid var(--line); background: var(--paper); }
.shipping-meter p { margin: 0 0 8px; font-size: 8px; font-weight: 700; }
.shipping-meter > div { height: 4px; overflow: hidden; border-radius: 100px; background: #d7d6ce; }
.shipping-meter span { display: block; width: 0; height: 100%; border-radius: inherit; background: var(--lime); transition: width .3s; }
.drawer__items { overflow-y: auto; padding: 8px 24px; }
.cart-item { display: grid; grid-template-columns: 75px 1fr auto; gap: 13px; padding: 15px 0; border-bottom: 1px solid var(--line); }
.cart-item__image { display: grid; width: 75px; height: 83px; place-items: center; border-radius: 10px; background: var(--paper); }
.cart-item__image img { width: 85%; height: 85%; object-fit: contain; mix-blend-mode: multiply; }
.cart-item h4 { margin: 4px 0; font: 700 11px/1.3 var(--heading); }
.cart-item p { margin: 0; color: var(--muted); font-size: 8px; }
.cart-item__quantity { display: flex; width: fit-content; align-items: center; gap: 9px; margin-top: 9px; padding: 3px; border: 1px solid var(--line); border-radius: 100px; font-size: 8px; }
.cart-item__quantity button { display: grid; width: 19px; height: 19px; border: 0; border-radius: 50%; place-items: center; background: var(--paper); }
.cart-item__price { margin-top: 4px; font: 800 10px/1 var(--heading); }
.drawer__empty { display: flex; flex: 1; flex-direction: column; align-items: center; justify-content: center; padding: 30px; text-align: center; }
.drawer__empty > span { display: grid; width: 64px; height: 64px; place-items: center; border-radius: 50%; color: #858d89; background: var(--paper); font: 700 23px/1 var(--heading); }
.drawer__empty h3 { margin: 18px 0 6px; font: 700 19px/1.2 var(--heading); letter-spacing: -.04em; }
.drawer__empty p { max-width: 270px; margin: 0 0 20px; color: var(--muted); font-size: 9px; line-height: 1.6; }
.drawer__panel > footer { margin-top: auto; padding: 20px 24px; border-top: 1px solid var(--line); }
.drawer__panel > footer > div { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; font-size: 10px; }
.drawer__panel > footer strong { font: 800 17px/1 var(--heading); }
.drawer__panel > footer .button { width: 100%; }
.drawer__panel > footer small { display: block; margin-top: 9px; color: var(--muted); font-size: 7px; text-align: center; }

#wishlistItems { overflow-y: auto; padding: 12px 24px; }
.wishlist-item { display: grid; grid-template-columns: 68px 1fr auto; gap: 12px; align-items: center; padding: 12px 0; border-bottom: 1px solid var(--line); }
.wishlist-item img { width: 68px; height: 75px; object-fit: contain; border-radius: 8px; background: var(--paper); mix-blend-mode: multiply; }
.wishlist-item h4 { margin: 0 0 4px; font: 700 11px/1.3 var(--heading); }
.wishlist-item p { margin: 0; color: var(--muted); font-size: 8px; }
.wishlist-item button { width: 30px; height: 30px; border: 1px solid var(--line); border-radius: 50%; background: transparent; }
.wishlist-empty { padding: 70px 20px; color: var(--muted); font-size: 10px; text-align: center; }

.quick-view { display: grid; padding: 22px; place-items: center; }
.quick-view__dialog {
  position: relative;
  display: grid;
  width: min(930px,100%);
  max-height: min(720px,calc(100vh - 44px));
  overflow: auto;
  grid-template-columns: 1fr 1fr;
  transform: translateY(20px) scale(.98);
  border-radius: 22px;
  background: var(--white);
  box-shadow: 0 40px 90px rgba(0,0,0,.32);
  transition: transform .3s ease;
}
.quick-view.is-open .quick-view__dialog { transform: translateY(0) scale(1); }
.quick-view__media { position: relative; display: grid; min-height: 570px; overflow: hidden; place-items: center; background: var(--paper); }
.quick-view__media::before { position: absolute; width: 330px; height: 330px; border-radius: 50%; background: var(--card-glow); content: ""; filter: blur(35px); opacity: .65; }
.quick-view__media img { position: relative; width: 83%; height: 83%; object-fit: contain; mix-blend-mode: multiply; filter: drop-shadow(0 25px 20px rgba(0,0,0,.18)); }
.quick-view__content { position: relative; padding: 50px 42px 38px; }
.quick-view__close { position: absolute; z-index: 3; top: 16px; right: 16px; }
.quick-view__brand { color: var(--muted); font-size: 8px; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; }
.quick-view h2 { margin: 13px 0 10px; font: 700 38px/1.03 var(--heading); letter-spacing: -.07em; }
.quick-view__price { font: 800 19px/1 var(--heading); }
.quick-view__description { margin: 22px 0; color: var(--muted); font-size: 10px; line-height: 1.75; }
.quick-view__label { display: block; margin-bottom: 9px; font-size: 8px; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
.variant-list { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 24px; }
.variant-list button { min-height: 33px; padding: 0 11px; border: 1px solid var(--line); border-radius: 100px; background: white; font-size: 8px; font-weight: 700; }
.variant-list button.active { border-color: var(--ink); color: white; background: var(--ink); }
.quick-view__features { display: grid; grid-template-columns: repeat(3,1fr); gap: 6px; margin: 0 0 23px; padding: 0; list-style: none; }
.quick-view__features li { padding: 9px; border-radius: 9px; color: var(--muted); background: var(--paper); font-size: 7px; font-weight: 700; line-height: 1.35; }
.quick-view__buy { display: flex; gap: 7px; }
.quick-view__buy .button { flex: 1; }
.quick-view__buy .product-card__wishlist { position: static; width: 51px; height: 51px; flex: 0 0 auto; }

.search-overlay__panel { position: absolute; top: 0; right: 0; left: 0; max-height: 88vh; overflow: auto; transform: translateY(-100%); background: var(--white); transition: transform .35s ease; }
.search-overlay.is-open .search-overlay__panel { transform: translateY(0); }
.search-overlay__top { display: flex; align-items: center; justify-content: space-between; width: min(950px,calc(100% - 40px)); margin: 0 auto; padding: 22px 0 13px; }
.search-overlay__top p { margin: 0; font: 700 15px/1 var(--heading); }
.search-overlay__form { display: flex; width: min(950px,calc(100% - 40px)); margin: 0 auto; border-bottom: 2px solid var(--ink); }
.search-overlay__form input { min-width: 0; flex: 1; padding: 15px 0; border: 0; outline: 0; background: transparent; font: 700 clamp(22px,4vw,43px)/1 var(--heading); letter-spacing: -.05em; }
.search-overlay__form button { border: 0; background: transparent; font-size: 10px; font-weight: 800; }
.search-overlay__meta { display: flex; width: min(950px,calc(100% - 40px)); align-items: center; justify-content: space-between; margin: 19px auto 14px; color: var(--muted); font-size: 8px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.search-overlay__meta button { border: 0; background: transparent; font-size: 8px; font-weight: 800; text-transform: uppercase; }
.search-results { display: grid; width: min(950px,calc(100% - 40px)); grid-template-columns: repeat(4,1fr); gap: 10px; margin: 0 auto 30px; }
.search-result { display: grid; grid-template-columns: 75px 1fr; gap: 10px; align-items: center; padding: 8px; border: 1px solid var(--line); border-radius: 12px; background: white; }
.search-result img { width: 75px; height: 82px; object-fit: contain; border-radius: 8px; background: var(--paper); mix-blend-mode: multiply; }
.search-result strong { display: block; margin-bottom: 5px; font: 700 9px/1.3 var(--heading); }
.search-result span { color: var(--muted); font-size: 8px; }

.mobile-menu { position: fixed; z-index: 110; inset: 0; display: none; overflow-y: auto; padding: 20px; transform: translateX(-100%); background: var(--white); transition: transform .3s; }
.mobile-menu.is-open { transform: translateX(0); }
.mobile-menu header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; }
.mobile-menu header button { display: grid; width: 38px; height: 38px; border: 1px solid var(--line); border-radius: 50%; place-items: center; background: white; font-size: 22px; }
.mobile-menu .search-bar { margin-bottom: 20px; }
.mobile-menu nav { display: flex; flex-direction: column; }
.mobile-menu nav a { display: flex; align-items: center; justify-content: space-between; padding: 17px 0; border-bottom: 1px solid var(--line); font: 700 21px/1 var(--heading); letter-spacing: -.05em; }
.mobile-menu > p { margin-top: 24px; color: var(--muted); font-size: 8px; }
.menu-button { width: 35px; height: 35px; padding: 8px; border: 0; place-items: center; background: transparent; }
.menu-button span { width: 18px; height: 1px; background: var(--ink); }

.toast { position: fixed; z-index: 150; right: 20px; bottom: 20px; padding: 13px 17px; transform: translateY(30px); border-radius: 100px; color: white; background: var(--ink); box-shadow: 0 15px 30px rgba(0,0,0,.2); font-size: 9px; font-weight: 700; opacity: 0; pointer-events: none; transition: transform .25s, opacity .25s; }
.toast.is-visible { transform: translateY(0); opacity: 1; }

/* Motion */
.motion-enabled [data-motion-ready="true"] {
  opacity: 0;
  transform: translate3d(0, 24px, 0);
  transition-delay: var(--reveal-delay, 0ms);
  transition-duration: .72s;
  transition-property: opacity, transform;
  transition-timing-function: cubic-bezier(.16,1,.3,1);
}
.motion-enabled [data-motion-ready="true"].is-revealed {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}
.motion-enabled [data-motion-ready="true"].motion-settled {
  transition-delay: 0ms;
}
.motion-enabled .path-card[data-motion-ready="true"].is-revealed:hover { transform: translateY(-5px); }
.motion-enabled .brand-tile[data-motion-ready="true"].is-revealed:hover { transform: translateY(-4px); }
.motion-enabled .flavour-guide__grid button[data-motion-ready="true"].is-revealed:hover { transform: translateY(-5px); }
.motion-enabled .product-card[data-motion-ready="true"] {
  transform: perspective(900px) translate3d(0, 24px, 0) rotateX(var(--tilt-x)) rotateY(var(--tilt-y));
}
.motion-enabled .product-card[data-motion-ready="true"].is-revealed {
  transform: perspective(900px) translate3d(0, 0, 0) rotateX(var(--tilt-x)) rotateY(var(--tilt-y));
}
.motion-enabled .product-card[data-motion-ready="true"].is-revealed:hover {
  transform: perspective(900px) translate3d(0, -6px, 0) rotateX(var(--tilt-x)) rotateY(var(--tilt-y));
}
@keyframes ticker { to { transform: translateX(-50%); } }
@keyframes heroReveal { from { opacity: .45; filter: saturate(.65); } to { opacity: 1; filter: saturate(1); } }
@keyframes smokeDrift { 0%,100% { transform: translate(0,0) rotate(-8deg) scale(.8); opacity: .1; } 50% { transform: translate(-80px,-55px) rotate(12deg) scale(1.25); opacity: .7; } }
@keyframes particleFloat { 0%,100% { transform: translate(0,0) scale(.7); opacity: .2; } 50% { transform: translate(-30px,-55px) scale(1.15); opacity: .8; } }
@keyframes vapourRibbon {
  0%,100% { transform: translate3d(80px,35px,0) rotate(-8deg) scale(.75); opacity: .08; }
  45% { opacity: .48; }
  55% { transform: translate3d(-120px,-65px,0) rotate(10deg) scale(1.18); opacity: .36; }
}
@keyframes productHoverFloat {
  0%,100% { transform: rotate(var(--visual-turn)) translateY(0); }
  50% { transform: rotate(var(--visual-turn)) translateY(-5px); }
}
@keyframes pathOrbit {
  to { transform: rotate(360deg) scale(1.03); }
}

/* Responsive */
@media (max-width: 1080px) {
  .header-main { grid-template-columns: 190px 1fr auto; }
  .header-actions .desktop-only { display: none; }
  .category-nav .shell { gap: 25px; }
  .hero__deal { right: 24px; }
  .product-grid { grid-template-columns: repeat(3,1fr); }
  .brand-grid { grid-template-columns: repeat(3,1fr); }
  .benefit-grid { grid-template-columns: repeat(2,1fr); }
  .quick-view__dialog { width: min(850px,100%); }
}

@media (max-width: 760px) {
  .shell { width: min(100% - 30px,600px); }
  .section { padding: 74px 0; }
  .desktop-only, .desktop-search, .category-nav { display: none !important; }
  .mobile-only { display: grid; }
  .announcement__track { min-height: 30px; font-size: 7px; }
  .announcement__track span:not(:first-child), .announcement__track i { display: none; }
  .header-main { display: flex; min-height: 67px; justify-content: space-between; gap: 8px; }
  .header-main .brand__mark { width: 33px; height: 33px; font-size: 15px; }
  .header-main .brand b { font-size: 14px; }
  .header-main .brand small { display: none; }
  .header-actions { gap: 2px; }
  .header-action { min-height: 37px; padding: 0 5px; }
  .header-action b { min-width: 23px; height: 23px; }
  .hero { min-height: 740px; }
  .hero__background { background-image: linear-gradient(180deg,rgba(7,12,10,.96) 0%,rgba(7,12,10,.73) 48%,rgba(7,12,10,.05) 78%), url("../images/hero-devices-3d.png"); background-position: 61% center; }
  .hero__inner { min-height: 700px; align-items: flex-start; }
  .hero__copy { padding: 50px 0; }
  .hero h1 { font-size: clamp(58px,17vw,78px); }
  .hero__copy > p { max-width: 360px; margin: 20px 0 24px; font-size: 11px; }
  .hero__proof { gap: 19px; margin-top: 32px; }
  .hero__deal { right: 15px; bottom: 47px; left: 15px; width: auto; }
  .trust-row__grid { grid-template-columns: 1fr 1fr; }
  .trust-row article { min-height: 75px; padding: 12px; border-bottom: 1px solid var(--line); }
  .section-heading--split, .reviews__heading { align-items: flex-start; flex-direction: column; }
  .section-heading h2, .reviews h2, .newsletter h2 { font-size: 42px; }
  .shop-toolbar { align-items: flex-start; flex-direction: column; }
  .filter-tabs { max-width: 100%; overflow-x: auto; }
  .filter-tabs button { white-space: nowrap; }
  .shop-toolbar__right { width: 100%; justify-content: space-between; }
  .product-grid { grid-template-columns: repeat(2,minmax(0,1fr)); gap: 9px; }
  .product-card__visual { height: 205px; }
  .product-card__image { width: 88%; height: 88%; }
  .product-card__quick { display: none; }
  .product-card__info { padding: 12px; }
  .product-card h3 { min-height: 38px; font-size: 11px; }
  .product-card__meta { font-size: 6px; }
  .product-card__flavours { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .brand-grid { grid-template-columns: repeat(2,1fr); }
  .brand-tile { min-height: 125px; }
  .flavour-lab, .flavour-lab__inner { min-height: 680px; }
  .flavour-lab__background { background-image: linear-gradient(180deg,#050b09 0%,rgba(5,11,9,.88) 48%,rgba(5,11,9,.08) 83%), url("../images/flavour-spectrum-3d.png"); background-position: 67% center; }
  .flavour-lab__inner { align-items: flex-start; padding-top: 65px; }
  .flavour-lab h2 { font-size: 55px; }
  .bundles__grid { grid-template-columns: 1fr; }
  .bundle-card, .delivery-card { min-height: 420px; padding: 30px; }
  .bundle-stack { right: -20px; transform: scale(.78); transform-origin: bottom right; }
  .delivery-card form { flex-direction: column; }
  .delivery-card input { min-height: 50px; }
  .benefit-grid, .review-grid, .newsletter__inner, .footer__grid { grid-template-columns: 1fr; }
  .benefit-icon { margin-bottom: 28px; }
  .rating { text-align: left; }
  .review-grid article > p { min-height: 0; }
  .newsletter__inner { gap: 30px; }
  .newsletter form > div { flex-direction: column; }
  .newsletter input { min-height: 49px; }
  .footer__grid { gap: 32px; }
  .footer__bottom { min-height: 100px; flex-direction: column; align-items: flex-start; justify-content: center; }
  .page-hero { min-height: 430px; }
  .page-hero h1, .flavour-lab h1 { font-size: clamp(54px,16vw,72px); }
  .path-grid, .delivery-page__grid, .brand-story__grid { grid-template-columns: 1fr; }
  .path-card { min-height: 245px; }
  .catalogue-help__inner { align-items: flex-start; flex-direction: column; }
  .flavour-guide__grid { grid-template-columns: repeat(2,1fr); }
  .flavour-guide__grid button { min-height: 210px; }
  .flavour-guide__grid h3 { margin-top: 50px; }
  .brand-story__grid { gap: 25px; }
  .age-card { padding: 30px 21px; }
  .age-card h1 { font-size: 33px; }
  .age-card__actions { grid-template-columns: 1fr; }
  .mobile-menu { display: block; }
  .quick-view { padding: 10px; }
  .quick-view__dialog { display: block; max-height: calc(100vh - 20px); }
  .quick-view__media { min-height: 315px; }
  .quick-view__media img { width: 75%; height: 75%; }
  .quick-view__content { padding: 33px 20px 24px; }
  .quick-view h2 { font-size: 31px; }
  .quick-view__features { grid-template-columns: repeat(2,1fr); }
  .search-results { grid-template-columns: 1fr 1fr; }
  .search-result { display: block; }
  .search-result img { width: 100%; height: 100px; margin-bottom: 7px; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
}
