@font-face {
  font-family: "Gazpacho";
  src: url("./assets/gazpacho-bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Bricolage Grotesque";
  src: url("./assets/bricolage-grotesque.woff2") format("woff2");
  font-weight: 300 800;
  font-style: normal;
  font-display: swap;
}

:root {
  --green: #245835;
  --green-2: #20522e;
  --cta-green: #363;
  --copy-gray: #525252;
  --line-gray: #dedede;
  --cream: #fff9f0;
  --yellow: #ffd38c;
  --lime: #cdec89;
  --orange: #ffb237;
  --muted-track: #efead6;
  --muted-text: #a8ada9;
  --font-body: "Bricolage Grotesque", Arial, sans-serif;
  --font-display: "Gazpacho", Georgia, serif;
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-snap: cubic-bezier(0.2, 1.4, 0.28, 1);
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
  background: #f6f6f4;
  scroll-behavior: smooth;
}

body {
  color: var(--green-2);
  font-family: var(--font-body);
}

img {
  display: block;
}

button,
a {
  font: inherit;
}

button {
  border: 0;
  cursor: pointer;
}

a {
  color: inherit;
  text-decoration: none;
}

.figma-frame {
  position: relative;
  width: 1450px;
  height: 2615px;
  margin: 0 auto;
  overflow: hidden;
  background: #fff;
}

.page-bg {
  position: absolute;
  inset: 0;
  width: 1450px;
  height: 2615px;
  border: 1px solid #eaeaea;
  background: #fff;
}

.top-header {
  position: absolute;
  left: 0;
  top: 0;
  width: 1450px;
  height: 70px;
  border: 1px solid #fff;
  background: #edffea;
  animation: header-drop 620ms var(--ease-out) both;
}

.brand-logo {
  position: absolute;
  left: 660px;
  top: 19.13px;
  width: 116.45px;
  height: 31.87px;
  animation: logo-settle 780ms 120ms var(--ease-snap) both;
}

.brand-registered {
  position: absolute;
  left: 778.9px;
  top: 13px;
  width: 11px;
  color: var(--green);
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 700;
  line-height: 29.42px;
  animation: fade-pop 520ms 260ms var(--ease-out) both;
}

.new-flavor-bar {
  position: absolute;
  left: 0;
  top: 70px;
  width: 1450px;
  height: 70px;
  background: linear-gradient(90deg, #e34040 0%, #cdec89 100%);
  animation: flavor-bar-reveal 760ms 110ms var(--ease-out) both;
}

.new-flavor-label {
  position: absolute;
  left: 149px;
  top: 20px;
  color: #fff;
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 800;
  line-height: 21.76px;
  white-space: nowrap;
  animation: text-rise 520ms 320ms var(--ease-out) both;
}

.flavor-heading {
  position: absolute;
  left: 593px;
  top: 17px;
  width: 265px;
  height: 36px;
}

.flavor-heading span {
  position: absolute;
  left: 71px;
  top: 5px;
  color: #fff;
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 700;
  line-height: 27.2px;
  white-space: nowrap;
  animation: text-rise 560ms 390ms var(--ease-out) both;
}

.fruit-lockup {
  position: absolute;
  left: 0;
  top: 0;
  width: 54px;
  height: 36px;
  transform-origin: 50% 60%;
  animation: fruit-pop 760ms 340ms var(--ease-snap) both;
}

.fruit-kiwi {
  position: absolute;
  left: 17.7px;
  top: 0;
  width: 36.3px;
  height: 33.81px;
}

.fruit-strawberry {
  position: absolute;
  left: 2.93px;
  top: 4.34px;
  width: 28.9px;
  height: 31.66px;
}

.fruit-leaf {
  position: absolute;
  left: 0;
  top: 1.07px;
  width: 23.28px;
  height: 15.72px;
}

.available-cta {
  position: absolute;
  left: 1094px;
  top: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 188px;
  height: 42px;
  padding: 10px;
  border-radius: 9px;
  background: #fff;
  color: var(--green-2);
  font-size: 16px;
  font-weight: 800;
  line-height: 21.76px;
  white-space: nowrap;
  transition:
    transform 220ms var(--ease-out),
    box-shadow 220ms var(--ease-out),
    background-color 220ms ease;
  animation: text-rise 560ms 450ms var(--ease-out) backwards;
}

.available-cta img {
  width: 19px;
  height: 19px;
  transition: transform 220ms var(--ease-out);
}

.available-cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 9px 22px rgb(32 82 46 / 18%);
}

.available-cta:hover img {
  transform: translateX(4px);
}

.hero-card {
  position: absolute;
  left: 182px;
  top: 121px;
  width: 500px;
  height: 380px;
  overflow: visible;
  border-radius: 46px;
  background: var(--green);
  animation: card-rise 820ms 260ms var(--ease-out) both;
}

.hero-slider {
  isolation: isolate;
}

.hero-slider-window {
  position: absolute;
  inset: 0;
  overflow: hidden;
  border-radius: inherit;
  background: var(--green);
  touch-action: pan-y;
}

.hero-slider-track {
  display: flex;
  width: 100%;
  height: 100%;
  transform: translateX(0);
  transition: transform 620ms cubic-bezier(0.2, 0.8, 0.2, 1);
  will-change: transform;
}

.hero-slide {
  display: block;
  width: 100%;
  height: 100%;
  flex: 0 0 100%;
}

.hero-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  user-select: none;
  -webkit-user-drag: none;
}

.hero-slide:first-child img {
  object-position: center center;
}

.slider-btn {
  position: absolute;
  z-index: 5;
  top: 50%;
  display: grid;
  place-items: center;
  width: 26px;
  height: 58px;
  border: 0;
  background: var(--cta-green);
  color: #fff;
  opacity: 0.96;
  transform: translateY(-50%);
  transition:
    opacity 180ms ease,
    transform 220ms var(--ease-out),
    background-color 180ms ease,
    box-shadow 220ms var(--ease-out);
  box-shadow: 0 10px 22px rgb(0 0 0 / 18%);
}

.slider-btn svg {
  width: 19px;
  height: 19px;
}

.slider-btn path {
  fill: none;
  stroke: currentColor;
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.slider-btn-prev {
  left: 0;
  border-radius: 0 999px 999px 0;
}

.slider-btn-next {
  right: 0;
  border-radius: 999px 0 0 999px;
}

.hero-slider:hover .slider-btn,
.slider-btn:focus-visible {
  opacity: 1;
  background: #2f672f;
  box-shadow: 0 12px 26px rgb(0 0 0 / 22%);
}

.slider-btn:hover {
  transform: translateY(-50%) scale(1.04);
}

.slider-btn:active {
  transform: translateY(-50%) scale(0.96);
}

.slider-btn.is-hidden,
.hero-slider:hover .slider-btn.is-hidden,
.slider-btn.is-hidden:focus-visible {
  opacity: 0;
  pointer-events: none;
  transform: translateY(-50%) scale(0.9);
}

.slider-dots {
  position: absolute;
  z-index: 5;
  left: 60px;
  top: 15px;
  display: flex;
  align-items: center;
  gap: 7px;
  height: 18px;
  padding: 5px 8px;
  border-radius: 999px;
  background: rgb(255 255 255 / 52%);
  transform: none;
  backdrop-filter: blur(8px);
}

.slider-dots button {
  width: 7px;
  height: 7px;
  padding: 0;
  border-radius: 999px;
  background: rgb(32 82 46 / 35%);
  transition:
    width 220ms var(--ease-out),
    background-color 220ms ease,
    transform 220ms var(--ease-out);
}

.slider-dots button.active {
  width: 20px;
  background: var(--green-2);
}

.slider-dots button:hover {
  transform: scale(1.18);
}

.slider-thumbs {
  position: absolute;
  z-index: 4;
  left: 6.6%;
  top: calc(100% + 30px);
  right: 6.6%;
  display: none;
  height: 20.8%;
  gap: 10px;
}

.slider-thumbs button {
  position: relative;
  flex: 1 1 0;
  min-width: 0;
  height: 100%;
  padding: 0;
  overflow: hidden;
  border: 0;
  border-radius: 7px;
  background: #f5f5f1;
  opacity: 0.76;
  transition:
    opacity 180ms ease,
    transform 220ms var(--ease-out),
    box-shadow 220ms var(--ease-out);
}

.slider-thumbs button::after {
  content: "";
  position: absolute;
  inset: 0;
  border: 3px solid transparent;
  border-radius: inherit;
  pointer-events: none;
  transition: border-color 180ms ease;
}

.slider-thumbs button:hover,
.slider-thumbs button.active {
  opacity: 1;
  transform: translateY(-1px);
}

.slider-thumbs button.active {
  box-shadow: 0 10px 18px rgb(36 88 53 / 14%);
}

.slider-thumbs button.active::after {
  border-color: var(--green-2);
}

.slider-thumbs img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  user-select: none;
  -webkit-user-drag: none;
}

.hero-slider.is-changing .hero-slide {
  animation: slider-image-settle 520ms var(--ease-out) both;
}

@media (min-width: 1080px) {
  .slider-dots {
    display: none;
  }

  .slider-thumbs {
    display: flex;
  }
}

.hero-green {
  position: absolute;
  inset: 0;
  background: var(--green);
}

.hero-photo-mask {
  position: absolute;
  right: -42px;
  bottom: -32px;
  width: 314px;
  height: 314px;
  overflow: hidden;
  border-radius: 50%;
  background: #f6d151;
}

.hero-photo-mask img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 51% 50%;
  transform: scale(1.36);
  transition: transform 700ms var(--ease-out);
}

.hero-card:hover .hero-photo-mask img {
  transform: scale(1.42);
}

.hero-rating {
  position: absolute;
  z-index: 3;
  right: 29px;
  top: 61px;
  display: flex;
  align-items: center;
  gap: 7px;
  width: 140.06px;
  height: 27.52px;
  padding: 0 13px;
  border-radius: 59px;
  background: #f9d05c;
  color: var(--green-2);
  transform: rotate(-5deg);
  transform-origin: 50% 50%;
  animation: rating-pop 700ms 780ms var(--ease-snap) both;
}

.hero-rating strong {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 800;
}

.hero-rating img {
  width: 80px;
  height: 12px;
}

.hero-big-copy {
  position: absolute;
  z-index: 2;
  left: 29px;
  top: 68px;
  display: flex;
  flex-direction: column;
  width: 319px;
  color: #f9d05c;
  font-family: var(--font-display);
  font-size: 52px;
  font-weight: 700;
  line-height: 0.93;
  transform: rotate(-5.02deg);
  transform-origin: left top;
  animation: hero-copy-in 760ms 520ms var(--ease-out) both;
}

.hero-big-copy span {
  display: block;
}

.hero-big-copy .cream {
  color: #ffeebe;
}

.hero-seal {
  position: absolute;
  left: 44px;
  top: 280px;
  width: 56.92px;
  height: 59.55px;
  transform-origin: 50% 50%;
  animation: seal-stamp 640ms 920ms var(--ease-snap) both;
}

.nutrition-link {
  position: absolute;
  left: 336px;
  top: 635px;
  display: flex;
  align-items: center;
  gap: 13px;
  height: 22px;
  color: #000;
  font-size: 16px;
  font-weight: 500;
  line-height: 21.76px;
  animation: text-rise 520ms 900ms var(--ease-out) backwards;
  transition: transform 200ms var(--ease-out), color 200ms ease;
}

.nutrition-link img {
  width: 18px;
  height: 14px;
  transition: transform 200ms var(--ease-out);
}

.nutrition-link:hover {
  transform: translateY(-1px);
  color: var(--green-2);
}

.nutrition-link:hover img {
  transform: translateX(5px);
}

.story-strip {
  position: absolute;
  left: 777px;
  top: 121px;
  width: 440px;
  height: 80px;
  animation: story-in 700ms 360ms var(--ease-out) both;
}

.story-desktop-art {
  position: absolute;
  left: -2.5px;
  top: -1.5px;
  width: 445px;
  height: 85px;
  display: none;
  transition: transform 260ms var(--ease-out), filter 260ms ease;
}

.story-mobile-list {
  display: flex;
  width: 440px;
  align-items: center;
  justify-content: space-between;
}

.story-mobile-list img {
  width: 80px;
  height: 80px;
  border-radius: 999px;
  object-fit: cover;
}

.story-strip:hover .story-desktop-art {
  filter: saturate(1.08);
  transform: translateY(-2px);
}

.intro-copy {
  position: absolute;
  left: 775px;
  top: 232px;
  width: 468px;
  height: 186px;
  animation: copy-rise 720ms 470ms var(--ease-out) both;
}

.authority-line {
  position: absolute;
  left: 0;
  top: 0;
  display: flex;
  align-items: center;
  gap: 16px;
  height: 14px;
}

.authority-line img {
  width: 76px;
  height: 12px;
}

.authority-line span {
  color: #477247;
  font-size: 12px;
  font-weight: 400;
  line-height: 14.46px;
  white-space: nowrap;
}

.authority-line b {
  font-weight: 700;
}

.intro-copy h1 {
  position: absolute;
  left: 0;
  top: 33px;
  width: 463px;
  margin: 0;
  color: var(--green);
  font-family: var(--font-display);
  font-size: 25px;
  font-weight: 700;
  line-height: normal;
}

.intro-copy sup {
  font-size: 13px;
}

.intro-copy p {
  position: absolute;
  left: 0;
  top: 142px;
  width: 468px;
  margin: 0;
  color: var(--copy-gray);
  font-size: 16px;
  font-weight: 400;
  line-height: 21.76px;
}

.discount-callout {
  position: absolute;
  left: 784px;
  top: 441px;
  width: 469px;
  height: 25px;
  animation: text-rise 540ms 650ms var(--ease-out) both;
}

.discount-callout strong {
  position: absolute;
  left: 0;
  top: 5px;
  color: var(--green-2);
  font-size: 12px;
  font-weight: 800;
  line-height: 16.32px;
  white-space: nowrap;
}

.discount-callout span {
  position: absolute;
  left: 146px;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 323px;
  height: 25px;
  border-radius: 58px;
  background: var(--yellow);
  color: var(--green-2);
  font-size: 11px;
  font-weight: 400;
  line-height: 16.32px;
  white-space: nowrap;
  transform-origin: left center;
  transition: transform 220ms var(--ease-out), box-shadow 220ms var(--ease-out);
}

.discount-callout span:hover {
  transform: scale(1.012);
  box-shadow: 0 7px 14px rgb(255 178 55 / 18%);
}

.discount-callout b {
  font-weight: 800;
}

.mobile-bundle-progress {
  display: none;
}

.progress-card {
  position: absolute;
  left: 782px;
  top: 491px;
  width: 472px;
  height: 85px;
  animation: progress-rise 680ms 720ms var(--ease-out) both;
}

.progress-shell {
  position: absolute;
  left: 0;
  top: 37px;
  width: 100%;
  height: 48px;
  border: 1px solid #ffd008;
  border-radius: 94px;
  background: var(--cream);
  transition: box-shadow 260ms var(--ease-out), border-color 260ms ease;
}

.progress-label {
  position: absolute;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 59px;
  height: 19px;
  border-radius: 5px;
  background: var(--yellow);
  color: var(--green);
  font-size: 10px;
  font-weight: 800;
  line-height: normal;
  text-align: center;
  white-space: nowrap;
  transition:
    background-color 260ms ease,
    color 260ms ease,
    transform 260ms var(--ease-out);
  animation: badge-pop 420ms var(--ease-snap) both;
}

.progress-label-5 {
  left: 28px;
  animation-delay: 960ms;
}

.progress-label-14 {
  left: calc(50% - 47px);
  animation-delay: 1040ms;
}

.progress-label-25 {
  right: 30px;
  animation-delay: 1120ms;
}

.progress-label.muted {
  background: var(--muted-track);
  color: var(--muted-text);
}

.progress-track,
.progress-fill {
  position: absolute;
  top: 33px;
  height: 7px;
  border-radius: 67px;
}

.progress-track {
  left: 27px;
  width: calc(100% - 62px);
  background: var(--muted-track);
}

.progress-fill {
  left: 26px;
  width: 270px;
  background: var(--orange);
  transform-origin: left center;
  animation: progress-fill-in 920ms 900ms var(--ease-out) both;
  transition: width 520ms var(--ease-out);
}

.dot {
  position: absolute;
  width: 19px;
  height: 19px;
  border-radius: 999px;
  background: var(--yellow);
  transition:
    left 520ms var(--ease-out),
    background-color 260ms ease,
    transform 260ms var(--ease-out),
    opacity 260ms ease;
}

.dot-ring {
  position: absolute;
  width: 27px;
  height: 27px;
  border: 1px solid #ffd008;
  border-radius: 999px;
  background: transparent;
  transition: left 520ms var(--ease-out), transform 360ms var(--ease-snap), opacity 260ms ease;
  animation: ring-pulse 1200ms 1280ms ease-out 2 both;
}

.dot-center {
  position: absolute;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #817323;
  transition: left 520ms var(--ease-out), background-color 260ms ease, transform 260ms var(--ease-out);
}

.dot-first {
  left: 26px;
  top: 28px;
}

.center-first {
  left: 32px;
  top: 34px;
}

.dot-current-base {
  left: 209px;
  top: 28px;
}

.dot-current-ring {
  left: 205px;
  top: 24px;
}

.center-current {
  left: 215px;
  top: 34px;
}

.dot-last {
  right: 33px;
  top: 28px;
  background: var(--muted-track);
}

.center-last {
  right: 39px;
  top: 34px;
  background: var(--muted-text);
}

.progress-card[data-qty="3"] .dot-last {
  background: var(--yellow);
}

.progress-card[data-qty="3"] .center-last {
  background: #817323;
}

.shipping-label {
  position: absolute;
  top: 56px;
  display: flex;
  align-items: center;
  gap: 4px;
  width: 84px;
  height: 16px;
  font-size: 12px;
  font-weight: 650;
  line-height: 16.32px;
  text-align: center;
  white-space: nowrap;
  transition: color 260ms ease, opacity 260ms ease, transform 260ms var(--ease-out);
  animation: text-rise 500ms 1180ms var(--ease-out) both;
}

.shipping-label img {
  width: 14px;
  height: 10px;
}

.shipping-active {
  left: calc(50% - 59px);
  color: var(--muted-text);
}

.shipping-active.is-earned {
  color: var(--green-2);
}

.shipping-muted {
  right: 33px;
  color: var(--muted-text);
}

.shipping-muted.is-earned {
  color: var(--green-2);
}

.quantity-title {
  position: absolute;
  left: 776px;
  top: 600px;
  display: block;
  margin: 0;
  padding-left: 24px;
  color: var(--green-2);
  font-size: 16px;
  font-weight: 650;
  line-height: 21.76px;
  white-space: nowrap;
  animation: text-rise 520ms 820ms var(--ease-out) both;
}

.quantity-title li {
  padding-left: 0;
}

.quantity-selector {
  position: absolute;
  left: 782px;
  top: 635px;
  width: 472px;
  height: 253px;
  animation: stack-rise 760ms 880ms var(--ease-out) both;
}

.qty-card {
  position: absolute;
  left: 0;
  width: 472px;
  height: 77px;
  padding: 0;
  border: 1px solid var(--line-gray);
  border-radius: 15px;
  background: #fafafa;
  color: var(--green-2);
  text-align: left;
  transform-origin: center;
  transition:
    transform 260ms var(--ease-out),
    border-color 260ms ease,
    background-color 260ms ease,
    box-shadow 260ms var(--ease-out);
}

.qty-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 20px rgb(36 88 53 / 8%);
}

.qty-card[data-qty="3"] {
  top: 0;
}

.qty-card[data-qty="2"] {
  top: 88px;
}

.qty-card[data-qty="1"] {
  top: 176px;
}

.qty-card.active {
  border-color: #ffd008;
  background: var(--cream);
  box-shadow: 0 8px 22px rgb(255 208 8 / 12%);
}

.qty-card.just-selected {
  animation: qty-select 440ms var(--ease-snap) both;
}

.qty-state {
  position: absolute;
  left: 22px;
  top: 28px;
  width: 22px;
  height: 22px;
  transition: transform 280ms var(--ease-snap), opacity 180ms ease;
}

.qty-card.active .qty-state {
  transform: scale(1.08);
}

.qty-label.single {
  position: absolute;
  left: 65px;
  top: 28px;
  color: var(--green-2);
  font-size: 16px;
  font-weight: 650;
  line-height: 21.76px;
  white-space: nowrap;
}

.qty-copy {
  position: absolute;
  left: 65px;
  top: 19px;
  display: flex;
  flex-direction: column;
  gap: 1px;
  width: 63px;
  line-height: 21.76px;
}

.qty-copy b {
  color: var(--green-2);
  font-size: 16px;
  font-weight: 650;
}

.qty-copy small {
  color: #868686;
  font-size: 12px;
  font-weight: 400;
  line-height: 16.32px;
}

.free-pill {
  position: absolute;
  left: 147px;
  top: 27px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3px;
  width: 83px;
  height: 23px;
  border: 1px solid #b7b7b7;
  border-radius: 102px;
  background: #fff;
  color: #b7b7b7;
  font-size: 10px;
  font-weight: 400;
  line-height: 13.6px;
  white-space: nowrap;
  transition:
    border-color 220ms ease,
    background-color 220ms ease,
    color 220ms ease,
    transform 220ms var(--ease-out),
    box-shadow 220ms var(--ease-out);
}

.free-pill.active {
  border-color: #ffd008;
  background: var(--yellow);
  color: var(--green-2);
  font-weight: 650;
  box-shadow: 0 5px 12px rgb(255 208 8 / 13%);
  transform: translateX(1px);
}

.free-pill img {
  width: 12px;
  height: 9px;
}

.card-badge {
  position: absolute;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 19px;
  border-radius: 0 0 5px 5px;
  color: var(--green);
  font-size: 10px;
  font-weight: 650;
  line-height: normal;
  text-align: center;
  white-space: nowrap;
  transition: transform 220ms var(--ease-out), opacity 220ms ease;
}

.qty-card:hover .card-badge {
  transform: translateY(-1px);
}

.card-badge.discount {
  left: 324px;
  width: 49px;
  background: var(--lime);
}

.card-badge.best {
  left: 381px;
  width: 75px;
  background: var(--yellow);
}

.qty-card[data-qty="2"] .card-badge.best {
  height: 22px;
}

.qty-price {
  position: absolute;
  left: 369px;
  top: 29px;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 6px;
  color: #000;
}

.qty-price strong {
  font-size: 14px;
  font-weight: 650;
  line-height: 19.04px;
  white-space: nowrap;
}

.qty-price del {
  width: 35px;
  color: #909090;
  font-size: 12px;
  font-weight: 400;
  line-height: 16.32px;
  text-align: center;
  text-decoration: line-through;
}

.qty-card[data-qty="2"] .qty-price,
.qty-card[data-qty="3"] .qty-price {
  left: 369px;
  top: 33px;
}

.qty-card[data-qty="2"] .qty-price del {
  width: 29px;
}

.order-line {
  position: absolute;
  left: 786px;
  top: 906px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 466px;
  height: 29px;
  animation: text-rise 520ms 1020ms var(--ease-out) both;
}

.order-chips {
  display: flex;
  align-items: center;
  gap: 6px;
}

.order-chips span {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 29px;
  padding: 0 10px;
  border-radius: 10px;
  color: #000;
  font-size: 12px;
  font-weight: 500;
  line-height: normal;
  text-align: center;
  white-space: nowrap;
  animation: chip-in 260ms var(--ease-out) both;
}

.order-chips span:first-child {
  background: var(--lime);
}

.order-chips span:last-child {
  background: var(--yellow);
}

.order-total {
  display: flex;
  align-items: center;
  gap: 3px;
  text-align: center;
  white-space: nowrap;
  transition: transform 220ms var(--ease-out);
}

.order-line.price-flash .order-total {
  animation: price-flash 480ms var(--ease-out) both;
}

.order-total del {
  color: #7f7f7f;
  font-size: 14px;
  font-weight: 400;
  line-height: 16.87px;
  text-decoration: line-through;
}

.order-total strong {
  color: #000;
  font-size: 16px;
  font-weight: 800;
  line-height: normal;
}

.main-cta {
  position: absolute;
  left: 784px;
  top: 953px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 17px;
  width: 468px;
  height: 80px;
  border-radius: 78px;
  background: var(--cta-green);
  color: #fff;
  animation: cta-rise 680ms 1100ms var(--ease-out) backwards;
  transition:
    transform 220ms var(--ease-out),
    box-shadow 220ms var(--ease-out),
    background-color 220ms ease;
}

.main-cta span {
  font-size: 18px;
  font-weight: 650;
  line-height: 21.69px;
  white-space: nowrap;
}

.main-cta img {
  width: 18px;
  height: 15px;
  filter: brightness(0) invert(1);
  transition: transform 220ms var(--ease-out);
}

.main-cta:hover {
  transform: translateY(-3px);
  background: #2f672f;
  box-shadow: 0 18px 30px rgb(51 102 51 / 22%);
}

.main-cta:hover img {
  transform: translateX(6px);
}

.main-cta:active {
  transform: translateY(-1px) scale(0.992);
}

.main-cta.is-open {
  background: #2f672f;
  box-shadow: 0 14px 28px rgb(51 102 51 / 18%);
}

.main-cta.is-open img {
  transform: rotate(90deg);
}

.flavor-panel {
  position: absolute;
  z-index: 8;
  left: 784px;
  top: 1118px;
  display: block;
  width: 468px;
  padding: 18px;
  border: 1px solid #ffd008;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 14px 40px rgb(0 0 0 / 8%);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-10px) scale(0.985);
  transform-origin: top center;
  visibility: hidden;
  transition:
    opacity 260ms ease,
    transform 320ms var(--ease-out),
    visibility 0s linear 320ms;
}

.flavor-panel.is-open {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0) scale(1);
  visibility: visible;
  transition-delay: 0s;
}

.flavor-panel h2 {
  margin: 0 0 12px;
  color: var(--green-2);
  font-size: 16px;
  font-weight: 800;
}

.flavor-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.flavor-grid button {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-height: 74px;
  padding: 12px;
  border: 1px solid #dedede;
  border-radius: 10px;
  background: #fafafa;
  color: var(--green-2);
  font-size: 14px;
  font-weight: 700;
  text-align: left;
  transition:
    transform 200ms var(--ease-out),
    border-color 200ms ease,
    background-color 200ms ease,
    box-shadow 200ms var(--ease-out);
}

.flavor-grid button:hover {
  border-color: #ffd008;
  background: #fffdf7;
  box-shadow: 0 8px 18px rgb(36 88 53 / 8%);
  transform: translateY(-2px);
}

.flavor-panel.is-open .flavor-grid button {
  animation: flavor-option-in 280ms var(--ease-out) backwards;
}

.flavor-panel.is-open .flavor-grid button:nth-child(1) {
  animation-delay: 70ms;
}

.flavor-panel.is-open .flavor-grid button:nth-child(2) {
  animation-delay: 115ms;
}

.flavor-panel.is-open .flavor-grid button:nth-child(3) {
  animation-delay: 160ms;
}

.flavor-panel.is-open .flavor-grid button:nth-child(4) {
  animation-delay: 205ms;
}

.flavor-grid span {
  color: #ae9529;
  font-size: 12px;
  font-weight: 600;
}

.guarantee-box {
  position: absolute;
  left: 786px;
  top: 1065px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 13px;
  width: 459px;
  height: 125px;
  padding: 17px 18px;
  border: 2px dashed var(--yellow);
  border-radius: 20px;
  background: #fff;
  animation: card-rise 700ms 1240ms var(--ease-out) both;
}

.guarantee-icon {
  position: relative;
  width: 78.13px;
  height: 79.4px;
  flex: 0 0 auto;
  animation: guarantee-settle 820ms 1440ms var(--ease-snap) both;
}

.guarantee-icon .badge {
  position: absolute;
  left: 0;
  top: 2.6px;
  width: 78.13px;
  height: 76.8px;
}

.guarantee-icon .coin-ring {
  position: absolute;
  left: 17.21px;
  top: 17.21px;
  width: 43.7px;
  height: 43.7px;
  animation: coin-spin 900ms 1520ms var(--ease-out) both;
}

.guarantee-icon .dollar {
  position: absolute;
  left: 33.6px;
  top: 29.2px;
  width: 11px;
  height: 24px;
}

.guarantee-box div:last-child {
  width: 290px;
}

.guarantee-box p,
.guarantee-box h2,
.guarantee-box span {
  margin: 0;
}

.guarantee-box p {
  color: #59774c;
  font-size: 14px;
  font-weight: 500;
  line-height: normal;
}

.guarantee-box h2 {
  margin-top: 5px;
  color: #3e6858;
  font-size: 16px;
  font-weight: 650;
  line-height: normal;
}

.guarantee-box span {
  display: block;
  margin-top: 5px;
  color: #758b6c;
  font-size: 14px;
  font-weight: 300;
  line-height: 18.06px;
}

.faq {
  position: absolute;
  left: 786px;
  top: 1222px;
  width: 461px;
  animation: faq-rise 760ms 1360ms var(--ease-out) both;
}

.faq-item {
  width: 461px;
  margin-top: 8px;
  border: 1px solid #e4e4e4;
  border-radius: 15px;
  background: #fefefe;
  overflow: hidden;
  transition: box-shadow 220ms var(--ease-out), border-color 220ms ease;
}

.faq-item:first-child {
  margin-top: 0;
  border-radius: 19px;
  background: #fbfbfb;
}

.faq-item:hover {
  border-color: #cfd9cf;
  box-shadow: 0 8px 22px rgb(36 88 53 / 7%);
}

.faq-title,
.faq-row {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 50px;
  margin: 0;
  padding: 0 21px 0 30px;
  background: transparent;
  color: var(--green-2);
  font-size: 16px;
  font-weight: 500;
  line-height: 19.28px;
  text-align: left;
}

.faq-title span {
  font-size: 16px;
  font-weight: 500;
  line-height: 19.28px;
}

.faq-title img {
  width: 20px;
  height: 20px;
  transition: transform 220ms var(--ease-out);
}

.faq-title.is-active img,
.faq-row.is-active img {
  transform: rotate(180deg);
}

.faq-title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 100%;
  height: 1px;
  background: #e4e4e4;
}

.faq-copy {
  width: auto;
  max-height: 0;
  margin: 0 26px;
  overflow: hidden;
  color: #616161;
  font-size: 14px;
  font-weight: 400;
  line-height: 17.5px;
  opacity: 0;
  transition:
    max-height 260ms var(--ease-out),
    margin 220ms var(--ease-out),
    opacity 180ms ease;
}

.faq-item.is-open .faq-copy {
  max-height: 780px;
  margin-top: 18px;
  margin-bottom: 24px;
  opacity: 1;
}

.faq-copy p {
  margin: 0 0 17.5px;
}

.faq-copy p:last-child {
  margin-bottom: 0;
}

.faq-copy ul,
.faq-copy ol {
  margin: 0 0 18px 18px;
  padding: 0;
}

.faq-copy li {
  margin-bottom: 7px;
}

.faq-copy strong {
  color: #3e6858;
}

.faq-row img {
  width: 20px;
  height: 20px;
  transition: transform 220ms var(--ease-out);
}

@keyframes header-drop {
  from {
    opacity: 0;
    transform: translateY(-18px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes logo-settle {
  from {
    opacity: 0;
    transform: translateY(-7px) scale(0.94);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes flavor-bar-reveal {
  from {
    opacity: 0;
    transform: translateY(-14px) scaleY(0.86);
    transform-origin: top;
  }
  to {
    opacity: 1;
    transform: translateY(0) scaleY(1);
    transform-origin: top;
  }
}

@keyframes text-rise {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fade-pop {
  from {
    opacity: 0;
    transform: scale(0.82);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes fruit-pop {
  0% {
    opacity: 0;
    transform: translateY(8px) rotate(-7deg) scale(0.72);
  }
  62% {
    opacity: 1;
    transform: translateY(-2px) rotate(3deg) scale(1.08);
  }
  100% {
    opacity: 1;
    transform: translateY(0) rotate(0deg) scale(1);
  }
}

@keyframes card-rise {
  from {
    opacity: 0;
    transform: translateY(20px) scale(0.985);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes slider-image-settle {
  from {
    filter: saturate(0.96);
    transform: scale(1.01);
  }
  to {
    filter: saturate(1);
    transform: scale(1);
  }
}

@keyframes story-in {
  from {
    opacity: 0;
    transform: translateY(16px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes copy-rise {
  from {
    opacity: 0;
    transform: translateY(14px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes hero-copy-in {
  from {
    opacity: 0;
    transform: translateY(18px) rotate(-5.02deg) scale(0.96);
  }
  to {
    opacity: 1;
    transform: translateY(0) rotate(-5.02deg) scale(1);
  }
}

@keyframes rating-pop {
  0% {
    opacity: 0;
    transform: rotate(-5deg) translateY(8px) scale(0.8);
  }
  70% {
    opacity: 1;
    transform: rotate(-5deg) translateY(-2px) scale(1.07);
  }
  100% {
    opacity: 1;
    transform: rotate(-5deg) translateY(0) scale(1);
  }
}

@keyframes seal-stamp {
  from {
    opacity: 0;
    transform: rotate(-18deg) scale(0.62);
  }
  to {
    opacity: 1;
    transform: rotate(0deg) scale(1);
  }
}

@keyframes progress-rise {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes progress-fill-in {
  from {
    transform: scaleX(0);
  }
  to {
    transform: scaleX(1);
  }
}

@keyframes badge-pop {
  from {
    opacity: 0;
    transform: translateY(6px) scale(0.88);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes ring-pulse {
  0% {
    transform: scale(0.72);
    opacity: 0.5;
  }
  45% {
    transform: scale(1.22);
    opacity: 1;
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}

@keyframes stack-rise {
  from {
    opacity: 0;
    transform: translateY(18px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes qty-select {
  0% {
    transform: scale(1);
  }
  48% {
    transform: scale(1.018);
  }
  100% {
    transform: scale(1);
  }
}

@keyframes chip-in {
  from {
    opacity: 0;
    transform: translateY(4px) scale(0.96);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes price-flash {
  0% {
    transform: translateY(0) scale(1);
  }
  45% {
    transform: translateY(-1px) scale(1.04);
  }
  100% {
    transform: translateY(0) scale(1);
  }
}

@keyframes cta-rise {
  from {
    opacity: 0;
    transform: translateY(18px) scale(0.985);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes guarantee-settle {
  from {
    opacity: 0;
    transform: rotate(-12deg) scale(0.82);
  }
  to {
    opacity: 1;
    transform: rotate(0deg) scale(1);
  }
}

@keyframes coin-spin {
  from {
    transform: rotate(-80deg) scale(0.88);
  }
  to {
    transform: rotate(0deg) scale(1);
  }
}

@keyframes faq-rise {
  from {
    opacity: 0;
    transform: translateY(18px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes flavor-option-in {
  from {
    opacity: 0;
    transform: translateY(8px) scale(0.985);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

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

@media (min-width: 1080px) and (max-width: 1449px) {
  body {
    overflow-x: hidden;
  }

  .figma-frame {
    --right-w: 472px;
    --gap-w: clamp(48px, 6vw, 95px);
    --available-w: calc(100vw - 64px);
    --left-w: min(500px, calc(var(--available-w) - var(--gap-w) - var(--right-w)));
    --page-w: calc(var(--left-w) + var(--gap-w) + var(--right-w));
    --left-x: calc((100vw - var(--page-w)) / 2);
    --right-x: calc(var(--left-x) + var(--left-w) + var(--gap-w));

    width: 100%;
    max-width: none;
    margin: 0;
    transform: none;
  }

  .page-bg,
  .top-header,
  .new-flavor-bar {
    width: 100%;
  }

  .brand-logo {
    left: calc(50% - 65px);
  }

  .brand-registered {
    left: calc(50% + 54px);
  }

  .new-flavor-label {
    left: var(--left-x);
  }

  .flavor-heading {
    left: 50%;
    transform: translateX(-50%);
  }

  .available-cta {
    left: auto;
    right: var(--left-x);
  }

  .hero-card {
    left: var(--left-x);
    width: var(--left-w);
    height: calc(var(--left-w) * 380 / 500);
  }

  .slider-btn-next {
    left: auto;
    right: 0;
  }

  .nutrition-link {
    left: calc(var(--left-x) + (var(--left-w) - 174px) / 2);
  }

  .story-strip {
    left: calc(var(--right-x) + (var(--right-w) - 440px) / 2);
  }

  .intro-copy,
  .discount-callout,
  .progress-card,
  .quantity-selector,
  .main-cta {
    left: var(--right-x);
    width: var(--right-w);
  }

  .intro-copy h1,
  .intro-copy p {
    width: 100%;
  }

  .quantity-title {
    left: var(--right-x);
  }

  .order-line {
    left: calc(var(--right-x) + 4px);
    width: calc(var(--right-w) - 6px);
  }

  .guarantee-box {
    left: calc(var(--right-x) + 2px);
    width: calc(var(--right-w) - 13px);
  }

  .faq {
    left: calc(var(--right-x) + 2px);
    width: calc(var(--right-w) - 11px);
  }

  .faq-item,
  .faq-row {
    width: 100%;
  }

  .faq-title {
    width: 100%;
  }

  .faq-title::after {
    width: 100%;
  }

  .qty-card {
    width: 100%;
  }

  .card-badge.discount {
    left: auto;
    right: 99px;
  }

  .card-badge.best {
    left: auto;
    right: 16px;
  }

  .qty-price,
  .qty-card[data-qty="2"] .qty-price,
  .qty-card[data-qty="3"] .qty-price {
    left: auto;
    right: 22px;
  }
}

@media (min-width: 1450px) {
  html,
  body {
    background: #fff;
  }

  .figma-frame {
    overflow: visible;
  }

  .page-bg,
  .top-header {
    left: calc((1450px - 100vw) / 2);
    width: 100vw;
  }

  .brand-logo {
    left: calc(50% - 65px);
  }

  .brand-registered {
    left: calc(50% + 54px);
  }
}

@media (min-width: 768px) and (max-width: 1079px) {
  html,
  body {
    background: #fff;
  }

  body {
    overflow-x: hidden;
  }

  .figma-frame {
    --content-w: min(760px, calc(100vw - 40px));
    --commerce-w: min(640px, var(--content-w));

    display: flex;
    width: 100%;
    max-width: none;
    height: auto;
    min-height: 100vh;
    margin: 0;
    padding: 0 0 88px;
    overflow: visible;
    flex-direction: column;
    align-items: center;
    background: #fff;
    transform: none;
  }

  .page-bg {
    display: none;
  }

  .top-header,
  .new-flavor-bar,
  .story-strip,
  .hero-card,
  .nutrition-link,
  .intro-copy,
  .discount-callout,
  .progress-card,
  .quantity-title,
  .quantity-selector,
  .order-line,
  .main-cta,
  .guarantee-box,
  .faq {
    position: relative;
    left: auto;
    top: auto;
    flex: 0 0 auto;
  }

  .top-header {
    order: 1;
    width: 100%;
    height: 70px;
  }

  .brand-logo {
    left: calc(50% - 65px);
  }

  .brand-registered {
    left: calc(50% + 54px);
  }

  .new-flavor-bar {
    order: 2;
    width: 100%;
    height: 70px;
  }

  .new-flavor-label {
    left: 32px;
  }

  .flavor-heading {
    left: 50%;
    transform: translateX(-50%);
  }

  .available-cta {
    left: auto;
    right: 32px;
    top: 14px;
  }

  .story-strip {
    order: 3;
    width: min(440px, var(--content-w));
    height: 80px;
    margin-top: 34px;
  }

  .story-desktop-art {
    left: 0;
    width: 100%;
    height: auto;
  }

  .hero-card {
    order: 4;
    width: min(680px, var(--content-w));
    height: auto;
    margin-top: 32px;
    aspect-ratio: 60 / 31;
  }

  .slider-dots {
    left: 50%;
    top: calc(100% + 14px);
    gap: 5px;
    height: 3px;
    padding: 0;
    background: transparent;
    backdrop-filter: none;
    transform: translateX(-50%);
  }

  .slider-dots button,
  .slider-dots button.active {
    width: 32px;
    height: 3px;
    border-radius: 0;
  }

  .slider-dots button {
    background: #d9d9d9;
  }

  .slider-dots button.active {
    background: var(--green-2);
  }

  .nutrition-link {
    order: 5;
    margin-top: 38px;
  }

  .intro-copy {
    order: 6;
    width: min(680px, var(--content-w));
    height: auto;
    margin-top: 42px;
  }

  .authority-line,
  .intro-copy h1,
  .intro-copy p {
    position: relative;
    left: auto;
    top: auto;
    width: 100%;
  }

  .intro-copy h1 {
    margin-top: 19px;
  }

  .intro-copy p {
    margin-top: 18px;
  }

  .discount-callout {
    order: 7;
    display: flex;
    align-items: center;
    gap: 12px;
    width: var(--commerce-w);
    height: auto;
    margin-top: 26px;
  }

  .discount-callout strong,
  .discount-callout span {
    position: relative;
    left: auto;
    top: auto;
  }

  .discount-callout span {
    flex: 1;
    width: auto;
  }

  .progress-card {
    order: 8;
    width: var(--commerce-w);
    height: 85px;
    margin-top: 26px;
  }

  .quantity-title {
    order: 9;
    width: var(--commerce-w);
    margin-top: 28px;
  }

  .quantity-selector {
    order: 10;
    width: var(--commerce-w);
    height: 253px;
    margin-top: 13px;
  }

  .qty-card {
    width: 100%;
  }

  .card-badge.discount {
    left: auto;
    right: 99px;
  }

  .card-badge.best {
    left: auto;
    right: 16px;
  }

  .qty-price,
  .qty-card[data-qty="2"] .qty-price,
  .qty-card[data-qty="3"] .qty-price {
    left: auto;
    right: 22px;
  }

  .order-line {
    order: 11;
    width: var(--commerce-w);
    margin-top: 18px;
  }

  .main-cta {
    order: 12;
    width: var(--commerce-w);
    margin-top: 18px;
  }

  .guarantee-box {
    order: 13;
    width: var(--commerce-w);
    margin-top: 32px;
  }

  .faq {
    order: 14;
    width: var(--commerce-w);
    margin-top: 32px;
  }

  .faq-item,
  .faq-row {
    width: 100%;
  }

  .faq-title {
    width: 100%;
  }

  .faq-title::after {
    width: 100%;
  }
}

@media (max-width: 767px) {
  html,
  body {
    background: #fff;
  }

  body {
    overflow-x: hidden;
  }

  .figma-frame {
    --content-w: min(640px, calc(100vw - 40px));

    position: relative;
    display: flex;
    width: 100%;
    max-width: none;
    height: auto;
    min-height: 1946px;
    margin: 0 auto;
    padding: 0 0 64px;
    overflow: visible;
    flex-direction: column;
    align-items: center;
  }

  .page-bg {
    display: none;
  }

  .top-header {
    position: relative;
    left: auto;
    top: auto;
    order: 1;
    width: 100%;
    height: 50px;
    flex: 0 0 auto;
  }

  .brand-logo {
    left: calc(50% - 53px);
    top: 10px;
    width: 95px;
    height: 26px;
    object-fit: contain;
  }

  .brand-registered {
    left: calc(50% + 44px);
    top: 7px;
    font-size: 20px;
    line-height: 24px;
  }

  .new-flavor-bar {
    position: relative;
    left: auto;
    top: auto;
    order: 2;
    width: 100%;
    height: 40px;
    flex: 0 0 auto;
    background: linear-gradient(261.9deg, #e34040 8.08%, #cdec89 169.99%);
  }

  .new-flavor-label {
    left: 22px;
    top: 12px;
    font-size: 12px;
    line-height: 16.32px;
  }

  .flavor-heading {
    left: auto;
    right: 16px;
    top: 12px;
    width: 143px;
    height: 16px;
  }

  .flavor-heading span {
    left: 22.5px;
    top: 0;
    font-size: 12px;
    line-height: 16.32px;
  }

  .fruit-lockup {
    left: 0;
    top: 1px;
    width: 54px;
    height: 36px;
    animation: none;
    transform: scale(0.381);
    transform-origin: left top;
  }

  .available-cta,
  .nutrition-link {
    display: none;
  }

  .story-strip {
    position: relative;
    left: auto;
    top: auto;
    order: 3;
    display: flex;
    width: 100%;
    height: 60px;
    margin-top: 20px;
    align-items: center;
    justify-content: center;
    animation: story-in 700ms 220ms var(--ease-out) both;
  }

  .story-desktop-art {
    display: none;
  }

  .story-mobile-list {
    width: min(440px, calc(100vw - 52px));
    align-items: center;
    justify-content: space-between;
  }

  .story-mobile-list img {
    width: clamp(52px, 15vw, 80px);
    height: clamp(52px, 15vw, 80px);
    border-radius: 999px;
    object-fit: cover;
  }

  .hero-card {
    position: relative;
    left: auto;
    top: auto;
    order: 4;
    width: var(--content-w);
    height: auto;
    margin-top: 22px;
    margin-bottom: 45px;
    aspect-ratio: 60 / 31;
    border-radius: 15px;
    background: transparent;
    animation: card-rise 700ms 260ms var(--ease-out) both;
  }

  .hero-slider-window {
    background: transparent;
  }

  .hero-slide img {
    transform: scale(1.006);
  }

  .slider-btn {
    display: grid;
    width: 24px;
    height: 50px;
  }

  .slider-dots {
    left: 50%;
    top: calc(100% + 14px);
    gap: 5px;
    height: 3px;
    padding: 0;
    background: transparent;
    backdrop-filter: none;
    transform: translateX(-50%);
  }

  .slider-dots button,
  .slider-dots button.active {
    width: 32px;
    height: 3px;
    border-radius: 0;
  }

  .slider-dots button {
    background: #d9d9d9;
  }

  .slider-dots button.active {
    background: var(--green-2);
  }

  .intro-copy {
    position: relative;
    left: auto;
    top: auto;
    order: 5;
    display: flex;
    width: var(--content-w);
    height: auto;
    flex-direction: column;
    align-items: flex-start;
    animation: copy-rise 680ms 340ms var(--ease-out) both;
  }

  .authority-line {
    position: relative;
    left: auto;
    top: auto;
    height: 12px;
    gap: 16px;
  }

  .authority-line img {
    width: 56px;
    height: 8px;
  }

  .authority-line span {
    font-size: 10px;
    line-height: 12.05px;
  }

  .intro-copy h1 {
    position: relative;
    left: auto;
    top: auto;
    width: 100%;
    margin: 9px 0 0;
    font-size: clamp(20px, 3.05vw, 22px);
    line-height: 1.32;
  }

  .intro-copy sup {
    font-size: 0.5em;
  }

  .intro-copy p {
    position: relative;
    left: auto;
    top: auto;
    width: 100%;
    margin: 9px 0 0;
    font-size: clamp(15px, 2.35vw, 17px);
    line-height: 1.36;
  }

  .discount-callout {
    display: none;
  }

  .progress-card {
    display: none;
  }

  .mobile-bundle-progress {
    position: relative;
    left: auto;
    top: auto;
    order: 6;
    display: flex;
    width: var(--content-w);
    max-width: 360px;
    margin-top: 15px;
    flex-direction: column;
    gap: 10px;
    animation: progress-rise 620ms 480ms var(--ease-out) both;
  }

  .mobile-combo-bar {
    position: relative;
    width: 100%;
    height: 84px;
  }

  .mobile-combo-shell {
    position: absolute;
    inset: 9px 0 0;
    border: 1px solid var(--orange);
    border-radius: 18px;
    background: var(--cream);
  }

  .mobile-combo-track,
  .mobile-shipping-row {
    position: absolute;
    left: clamp(10px, 4.44vw, 16px);
    right: clamp(10px, 3.89vw, 14px);
    display: grid;
    grid-template-columns:
      minmax(70px, 1fr)
      minmax(14px, 41px)
      minmax(70px, 1fr)
      minmax(14px, 41px)
      minmax(70px, 1fr);
    align-items: center;
  }

  .mobile-combo-track {
    top: 28px;
  }

  .mobile-combo-stage {
    position: relative;
    display: flex;
    justify-content: center;
    min-width: 0;
  }

  .mobile-price {
    display: flex;
    align-items: center;
    justify-content: center;
    width: min(100%, 84px);
    height: 26px;
    padding: 0 8px;
    border: 1px solid #efefef;
    border-radius: 58px;
    background: #fff;
    color: #959996;
    font-size: clamp(9px, 2.95vw, 12px);
    font-weight: 400;
    line-height: 1.36;
    white-space: nowrap;
    transition:
      background-color 220ms ease,
      border-color 220ms ease,
      color 220ms ease,
      transform 220ms var(--ease-out);
  }

  .mobile-price b {
    font-weight: 650;
  }

  .mobile-discount {
    position: absolute;
    left: 50%;
    top: -28px;
    display: grid;
    place-items: center;
    width: 53px;
    height: 17px;
    padding: 0 10px;
    border-radius: 39px;
    background: #e7e7e7;
    color: #828282;
    font-size: clamp(8px, 2.65vw, 10px);
    font-weight: 650;
    line-height: 1.36;
    text-transform: uppercase;
    white-space: nowrap;
    transform: translateX(-50%);
    transition:
      background-color 220ms ease,
      color 220ms ease,
      transform 220ms var(--ease-out);
  }

  .mobile-combo-stage[data-stage="1"] .mobile-discount {
    width: 49px;
  }

  .mobile-connector {
    height: 7px;
    background: #f3eee1;
    transition: background-color 220ms ease;
  }

  .mobile-shipping-row {
    top: 62px;
  }

  .mobile-shipping {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    color: #959996;
    font-size: clamp(8px, 2.65vw, 10px);
    font-weight: 650;
    line-height: 1.36;
    white-space: nowrap;
    transition: color 220ms ease;
  }

  .mobile-shipping img {
    width: 12px;
    height: 8px;
    object-fit: contain;
  }

  .shipping-stage-2 {
    grid-column: 3;
  }

  .shipping-stage-3 {
    grid-column: 5;
  }

  .mobile-bundle-progress[data-qty="1"] .mobile-combo-stage[data-stage="1"] .mobile-price,
  .mobile-bundle-progress[data-qty="2"] .mobile-combo-stage[data-stage="1"] .mobile-price,
  .mobile-bundle-progress[data-qty="2"] .mobile-combo-stage[data-stage="2"] .mobile-price,
  .mobile-bundle-progress[data-qty="3"] .mobile-combo-stage .mobile-price {
    border-color: transparent;
    background: var(--yellow);
    color: var(--green-2);
  }

  .mobile-bundle-progress[data-qty="1"] .mobile-combo-stage[data-stage="1"] .mobile-discount,
  .mobile-bundle-progress[data-qty="2"] .mobile-combo-stage[data-stage="1"] .mobile-discount,
  .mobile-bundle-progress[data-qty="2"] .mobile-combo-stage[data-stage="2"] .mobile-discount,
  .mobile-bundle-progress[data-qty="3"] .mobile-combo-stage .mobile-discount {
    background: var(--lime);
    color: var(--green-2);
  }

  .mobile-bundle-progress[data-qty="1"] .connector-one,
  .mobile-bundle-progress[data-qty="2"] .connector-one,
  .mobile-bundle-progress[data-qty="2"] .connector-two,
  .mobile-bundle-progress[data-qty="3"] .mobile-connector {
    background: var(--yellow);
  }

  .mobile-bundle-progress[data-qty="2"] .shipping-stage-2,
  .mobile-bundle-progress[data-qty="3"] .mobile-shipping {
    color: var(--green-2);
  }

  .mobile-upgrade-pill {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 37px;
    padding: 0 10px;
    border: 1px dashed var(--green-2);
    border-radius: 58px;
    background: #e4fcc0;
    color: var(--green-2);
    font-size: clamp(9px, 2.78vw, 11px);
    font-weight: 400;
    line-height: 1.36;
    text-align: center;
    white-space: nowrap;
  }

  .mobile-upgrade-pill b {
    font-weight: 800;
  }

  .quantity-title {
    position: relative;
    left: auto;
    top: auto;
    order: 8;
    width: var(--content-w);
    margin: 18px 0 0;
    padding-left: 22px;
    font-size: 14px;
    line-height: 19.04px;
    white-space: normal;
    animation: text-rise 520ms 540ms var(--ease-out) both;
  }

  .quantity-selector {
    position: relative;
    left: auto;
    top: auto;
    order: 9;
    width: var(--content-w);
    height: 253px;
    margin-top: 15px;
    animation: stack-rise 700ms 600ms var(--ease-out) both;
  }

  .qty-card {
    width: 100%;
    height: 77px;
  }

  .qty-state {
    left: 16px;
    top: 26px;
    width: 25px;
    height: 25px;
  }

  .qty-label.single {
    left: 51px;
    top: 27px;
  }

  .qty-copy {
    left: 51px;
    top: 19px;
  }

  .free-pill {
    left: 124px;
    top: 28px;
    width: 80px;
    height: 20px;
  }

  .card-badge.discount {
    left: auto;
    right: 87px;
  }

  .card-badge.best {
    left: auto;
    right: 11px;
  }

  .qty-price,
  .qty-card[data-qty="2"] .qty-price,
  .qty-card[data-qty="3"] .qty-price {
    left: auto;
    right: 16px;
    top: 29px;
    gap: 2px;
  }

  .qty-card[data-qty="2"] .qty-price,
  .qty-card[data-qty="3"] .qty-price {
    top: 33px;
  }

  .order-line {
    position: relative;
    left: auto;
    top: auto;
    order: 10;
    width: var(--content-w);
    height: 29px;
    margin-top: 15px;
    animation: text-rise 500ms 680ms var(--ease-out) both;
  }

  .main-cta {
    position: relative;
    left: auto;
    top: auto;
    order: 11;
    width: var(--content-w);
    height: 73px;
    margin-top: 16px;
    animation: cta-rise 620ms 760ms var(--ease-out) backwards;
  }

  .main-cta span {
    font-size: 18px;
    line-height: 21.69px;
  }

  .flavor-panel {
    position: relative;
    left: auto;
    top: auto;
    order: 12;
    width: var(--content-w);
    max-height: 0;
    margin-top: 0;
    padding-top: 0;
    padding-bottom: 0;
    overflow: hidden;
    border-width: 0;
  }

  .flavor-panel.is-open {
    max-height: 260px;
    margin-top: 12px;
    padding: 18px;
    border-width: 1px;
  }

  .guarantee-box {
    position: relative;
    left: auto;
    top: auto;
    order: 13;
    width: var(--content-w);
    height: 112px;
    margin-top: 17px;
    padding: 17px 18px;
    border-radius: 15px;
    gap: 13px;
    animation: card-rise 660ms 860ms var(--ease-out) both;
  }

  .guarantee-icon {
    width: 72px;
    height: 70.78px;
  }

  .guarantee-icon .badge {
    top: 0;
    width: 72px;
    height: 70.78px;
  }

  .guarantee-icon .coin-ring {
    left: 15.86px;
    top: 15.86px;
    width: 40.27px;
    height: 40.27px;
  }

  .guarantee-icon .dollar {
    left: 31px;
    top: 26px;
    width: 10px;
    height: 22px;
  }

  .guarantee-box div:last-child {
    width: auto;
    flex: 1 1 auto;
  }

  .guarantee-box p {
    font-size: 12px;
  }

  .guarantee-box h2 {
    font-size: 14px;
  }

  .guarantee-box span {
    font-size: 12px;
    line-height: 15.48px;
  }

  .faq {
    position: relative;
    left: auto;
    top: auto;
    order: 14;
    width: var(--content-w);
    margin-top: 10px;
    animation: faq-rise 700ms 940ms var(--ease-out) both;
  }

  .faq-item,
  .faq-row {
    width: 100%;
  }

  .faq-title {
    width: 100%;
  }

  .faq-title::after {
    left: 0;
    width: 100%;
  }

  .faq-copy {
    width: auto;
    margin-right: 20px;
    margin-left: 20px;
  }

  .faq-row {
    margin-top: 8px;
  }
}

@media (min-width: 600px) and (max-width: 767px) {
  .discount-callout {
    position: relative;
    left: auto;
    top: auto;
    order: 6;
    display: flex;
    align-items: center;
    gap: 12px;
    width: var(--content-w);
    height: auto;
    margin-top: 18px;
    animation: text-rise 520ms 480ms var(--ease-out) both;
  }

  .discount-callout strong,
  .discount-callout span {
    position: relative;
    left: auto;
    top: auto;
  }

  .discount-callout strong {
    flex: 0 0 auto;
  }

  .discount-callout span {
    flex: 1 1 auto;
    width: auto;
    min-width: 0;
  }

  .progress-card {
    position: relative;
    left: auto;
    top: auto;
    order: 7;
    display: block;
    width: var(--content-w);
    height: 85px;
    margin-top: 20px;
    animation: progress-rise 620ms 540ms var(--ease-out) both;
  }

  .mobile-bundle-progress {
    display: none;
  }
}

@media (max-width: 374px) {
  .figma-frame {
    --content-w: calc(100vw - 24px);
  }

  .new-flavor-label {
    left: 12px;
  }

  .flavor-heading {
    right: 10px;
  }

  .story-mobile-list {
    width: calc(100vw - 32px);
  }

  .free-pill {
    left: 118px;
  }

  .qty-price,
  .qty-card[data-qty="2"] .qty-price,
  .qty-card[data-qty="3"] .qty-price {
    right: 10px;
  }

  .card-badge.discount {
    right: 82px;
  }

  .card-badge.best {
    right: 6px;
  }

  .order-chips span {
    padding: 0 8px;
    font-size: 11px;
  }

  .order-total del {
    font-size: 12px;
  }

  .order-total strong {
    font-size: 14px;
  }

  .main-cta {
    gap: 12px;
  }

  .main-cta span {
    font-size: 16px;
  }
}

.figma-frame *,
.figma-frame *::before,
.figma-frame *::after {
  animation-duration: 180ms !important;
  animation-delay: 0ms !important;
}
