/* ═══════════════════════════════════════════════════════════════════════
   Fresh Doze RU — preview rebuild
   ═══════════════════════════════════════════════════════════════════════ */

:root {
  /* брендовые цвета */
  --fd-purple:        #C1A7E2;
  --fd-purple-deep:   #8B5DBF;
  --fd-purple-soft:   #E5D6F5;
  --fd-pink:          #F2B7C9;
  --fd-pink-deep:     #E94B7C;
  --fd-green:         #A6D49F;
  --fd-green-deep:    #5DAA52;
  --fd-punch:         #F4A09A;
  --fd-punch-deep:    #E84A3B;
  --fd-blue:          #6FCBE7;
  --fd-orange:        #F9A03F;
  --fd-red:           #E23744;
  --fd-line:          #06C755;

  --fd-ink:           #1F1F1F;
  --fd-ink-soft:      #4C4C4C;
  --fd-ink-muted:     #828588;
  --fd-bg:            #F5EEFB;
  --fd-bg-soft:       #FBF5FF;
  --fd-white:         #fff;

  --fd-shadow:        0 18px 48px -20px rgba(115, 84, 162, .35);
  --fd-shadow-soft:   0 6px 24px -8px rgba(115, 84, 162, .22);
  --fd-shadow-cap:    0 30px 50px -8px rgba(115, 84, 162, .35);

  --fd-display:       'Roboto Condensed', 'Roboto', system-ui, sans-serif;
  --fd-body:          'Roboto', system-ui, sans-serif;
  --fd-italic:        'Yeseva One', 'Cormorant Garamond', serif;
  /* Брендовый скрипт под лого «Fresh Doze» — каллиграфия */
  --fd-script:        'Allura', 'Great Vibes', 'Pinyon Script', cursive;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

body {
  font-family: var(--fd-body);
  font-size: 16px;
  line-height: 1.5;
  color: var(--fd-ink);
  background:
    radial-gradient(60% 50% at 70% -10%,  rgba(193,167,226,.45), transparent 60%),
    radial-gradient(50% 60% at -10% 30%,  rgba(166,212,159,.25), transparent 65%),
    radial-gradient(50% 50% at 110% 80%,  rgba(242,183,201,.30), transparent 65%),
    var(--fd-bg);
  min-height: 100vh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; display: block; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; padding: 0; }
a { color: inherit; text-decoration: none; }

/* ═══════════════════════════════════════════════════════════════════════
   ATOMIC: BUTTONS, PILLS, CHIPS
   ═══════════════════════════════════════════════════════════════════════ */
.fd-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px;
  padding: 14px 28px;
  border-radius: 10px;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 1.2px;
  transition: transform .25s, background .25s, color .25s, box-shadow .25s;
  border: 1px solid transparent;
  white-space: nowrap;
  text-transform: uppercase;
}
.fd-btn--lg { padding: 16px 32px; font-size: 14px; }
.fd-btn--dark { background: var(--fd-ink); color: white; }
.fd-btn--dark:hover { transform: translateY(-2px); box-shadow: 0 16px 32px -10px rgba(31,31,31,.5); }
.fd-btn--ghost {
  background: rgba(255,255,255,.6);
  border-color: var(--fd-purple);
  color: var(--fd-ink);
}
.fd-btn--ghost:hover { background: white; }
.fd-btn--ghost-dark {
  background: white; border-color: var(--fd-ink);
  color: var(--fd-ink);
}
.fd-btn--ghost-dark:hover { background: var(--fd-ink); color: white; }
.fd-btn--ghost-light {
  background: rgba(255,255,255,.85); border-color: white;
  color: var(--fd-ink); border-radius: 9999px;
  padding: 12px 22px; letter-spacing: .5px;
  text-transform: none;
}
.fd-btn--ghost-light:hover { background: white; transform: translateY(-2px); }

.fd-pill {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.6);
  border: 1px solid var(--fd-purple);
  border-radius: 12px;
  padding: 10px 16px;
  color: var(--fd-ink-soft);
  font-weight: 700;
  font-size: 14px;
  transition: background .2s, transform .2s;
}
.fd-pill:hover { background: rgba(255,255,255,.85); transform: translateY(-1px); }
.fd-pill--icon {
  width: 48px; height: 48px;
  padding: 0;
  border-radius: 9999px;
  justify-content: center;
  position: relative;
  font-size: 18px;
}
.fd-cart-count {
  position: absolute;
  top: -4px; right: -4px;
  background: var(--fd-pink-deep);
  color: white;
  font-size: 11px;
  width: 20px; height: 20px;
  border-radius: 9999px;
  display: grid; place-items: center;
  font-weight: 700;
}
.fd-lang { font-weight: 700; font-size: 16px; }
.fd-lang i { font-size: 11px; opacity: .7; }

.fd-chips { display: flex; gap: 10px; }
.fd-chip {
  padding: 10px 18px;
  border-radius: 10px;
  border: 1px solid rgba(128,130,133,.2);
  background: rgba(128,130,133,.10);
  color: var(--fd-ink-soft);
  font-weight: 600;
  font-size: 14px;
  transition: background .2s, border-color .2s, color .2s;
}
.fd-chip.is-active {
  border-color: var(--fd-purple);
  background: rgba(193,167,226,.18);
  color: var(--fd-ink);
}

/* стрелки слайдера */
.fd-arrow {
  width: 64px; height: 64px;
  border-radius: 16px;
  background: white;
  border: 2px solid var(--fd-purple-deep);
  color: var(--fd-purple-deep);
  display: grid; place-items: center;
  font-size: 22px;
  font-weight: 800;
  transition: background .25s, transform .25s, box-shadow .25s, color .25s;
  position: absolute;
  top: 50%;
  z-index: 30;
  box-shadow: 0 10px 24px -4px rgba(115,84,162,.35);
  cursor: pointer;
  animation: fd-arrow-pulse 2.4s ease-in-out infinite;
}
.fd-arrow:hover {
  background: var(--fd-purple-deep);
  color: white;
  transform: translateY(-50%) scale(1.1);
  box-shadow: 0 14px 30px -6px rgba(115,84,162,.5);
}
.fd-arrow--left  { left: 32px; transform: translateY(-50%); }
.fd-arrow--right { right: 32px; transform: translateY(-50%); animation-delay: -1.2s; }

@keyframes fd-arrow-pulse {
  0%, 100% { transform: translateY(-50%) scale(1); }
  50%      { transform: translateY(-50%) scale(1.08); }
}

/* ═══════════════════════════════════════════════════════════════════════
   HEADER
   ═══════════════════════════════════════════════════════════════════════ */
.fd-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 24px 56px;
  background: rgba(255,255,255,0);
  transition: padding .3s, background .3s, box-shadow .3s;
  backdrop-filter: blur(0);
  -webkit-backdrop-filter: blur(0);
}
.fd-header.is-shrunk {
  padding: 14px 56px;
  background: rgba(255,255,255,.7);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 4px 20px -10px rgba(115, 84, 162, .15);
}

.fd-logo {
  display: flex; flex-direction: column;
  line-height: 1;
  text-decoration: none;
  margin-right: 8px;
  position: relative;
}
.fd-logo__mark {
  display: inline-flex;
  align-items: flex-end;
  gap: 8px;
  position: relative;
}
.fd-logo__brand {
  font-family: var(--fd-italic);
  font-style: italic;
  font-weight: 400;
  font-size: 38px;
  color: var(--fd-ink);
  letter-spacing: -1px;
  line-height: 1;
}
.fd-logo__th { display: none; }
.fd-logo__sub {
  font-family: var(--fd-display);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 4px;
  color: var(--fd-ink);
  margin-top: 4px;
}

/* PRESS MENU pill */
.fd-press-menu {
  display: inline-flex; align-items: center; gap: 12px;
  background: rgba(255,255,255,.7);
  border: 1px solid var(--fd-purple);
  border-radius: 14px;
  padding: 8px 14px;
  margin-right: auto;
  transition: background .2s, transform .2s;
}
.fd-press-menu:hover { background: white; transform: translateY(-1px); }
.fd-press-menu__label {
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 14px;
  color: var(--fd-ink);
  letter-spacing: 2px;
}
.fd-press-menu__cursor {
  width: 28px; height: 28px;
  border-radius: 9999px;
  background: var(--fd-purple-soft);
  display: grid; place-items: center;
  color: var(--fd-purple-deep);
  font-size: 13px;
}

.fd-nav { display: flex; align-items: center; gap: 10px; }

/* выпадающее меню */
.fd-menu[hidden] { display: none !important; }
.fd-menu {
  position: fixed;
  top: 100px; left: 56px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(16px);
  border: 1px solid var(--fd-purple);
  border-radius: 16px;
  padding: 12px;
  display: flex; flex-direction: column;
  gap: 4px;
  min-width: 240px;
  box-shadow: var(--fd-shadow);
  z-index: 220;
}
.fd-menu a {
  padding: 12px 16px;
  border-radius: 10px;
  color: var(--fd-ink-soft);
  font-weight: 600;
  transition: background .15s, color .15s;
}
.fd-menu a:hover { background: var(--fd-purple-soft); color: var(--fd-purple-deep); }

/* ═══════════════════════════════════════════════════════════════════════
   GLOWS, PEARLS, SPARKLES — общие декорации
   ═══════════════════════════════════════════════════════════════════════ */

.fd-glow {
  position: absolute;
  border-radius: 9999px;
  filter: blur(60px);
  pointer-events: none;
  z-index: 1;
  opacity: .65;
}
.fd-glow--g1 { width: 420px; height: 420px; background: radial-gradient(circle, var(--fd-green) 0%, transparent 70%); top: 10%; left: -10%; }
.fd-glow--g2 { width: 520px; height: 520px; background: radial-gradient(circle, var(--fd-purple) 0%, transparent 70%); top: -5%; right: 15%; }
.fd-glow--g3 { width: 380px; height: 380px; background: radial-gradient(circle, var(--fd-pink) 0%, transparent 70%); bottom: 5%; right: -5%; }
.fd-glow--small { width: 260px; height: 260px; opacity: .5; }

.fd-pearl {
  position: absolute;
  border-radius: 9999px;
  pointer-events: none;
  z-index: 2;
  background:
    radial-gradient(circle at 30% 25%, rgba(255,255,255,.95), rgba(255,255,255,0) 40%),
    radial-gradient(circle at 70% 75%, rgba(193,167,226,.55), rgba(193,167,226,0) 65%),
    linear-gradient(135deg, rgba(242,183,201,.5), rgba(193,167,226,.7));
  box-shadow:
    inset -10px -12px 22px rgba(155,120,204,.25),
    inset 6px 8px 16px rgba(255,255,255,.4);
  filter: blur(.5px);
}
.fd-pearl--p1 { width: 80px; height: 80px;  top: 18%; left: 10%; }
.fd-pearl--p2 { width: 110px; height: 110px; top: 28%; right: 14%; }
.fd-pearl--p3 { width: 60px; height: 60px;  bottom: 30%; left: 22%; opacity: .7; }
.fd-pearl--p4 { width: 90px; height: 90px;  bottom: 18%; right: 30%; opacity: .8; }

.fd-pearl--t1 { width: 130px; height: 130px; top: 18%; left: 8%; }
.fd-pearl--t2 { width: 70px; height: 70px;  top: 30%; right: 18%; }
.fd-pearl--t3 { width: 95px; height: 95px; bottom: 18%; right: 8%; opacity: .7; }
.fd-pearl--t4 { width: 55px; height: 55px;  bottom: 30%; left: 30%; opacity: .6; }

.fd-pearl--f1 { width: 90px; height: 90px; top: 18%; left: 6%; }
.fd-pearl--f2 { width: 130px; height: 130px; bottom: 12%; right: 8%; opacity: .7; }
.fd-pearl--f3 { width: 80px; height: 80px; top: 30%; left: 18%; opacity: .6; }
.fd-pearl--f4 { width: 110px; height: 110px; bottom: 22%; right: 24%; }

.fd-pearl--fl1 { width: 120px; height: 120px; top: 14%; left: 4%; }
.fd-pearl--fl2 { width: 90px; height: 90px;  bottom: 16%; right: 12%; opacity: .7; }

@keyframes fd-float {
  0%,100% { transform: translateY(0) rotate(0); }
  50%     { transform: translateY(-22px) rotate(8deg); }
}
.fd-pearl { animation: fd-float 9s ease-in-out infinite; }
.fd-pearl--p2, .fd-pearl--p4, .fd-pearl--t2, .fd-pearl--t4, .fd-pearl--f2, .fd-pearl--fl2 {
  animation: fd-float 11s ease-in-out -3s infinite reverse;
}

.fd-spark {
  position: absolute;
  font-family: var(--fd-display);
  color: var(--fd-purple);
  font-size: 22px;
  pointer-events: none;
  z-index: 4;
  filter: drop-shadow(0 2px 6px rgba(155,120,204,.5));
  animation: fd-twinkle 3s ease-in-out infinite;
}
.fd-spark--s1 { top: 12%; left: 18%; }
.fd-spark--s2 { top: 28%; right: 26%; font-size: 28px; animation-delay: -1s; }
.fd-spark--s3 { bottom: 30%; left: 8%; font-size: 18px; animation-delay: -1.6s; }
.fd-spark--s4 { bottom: 14%; right: 14%; animation-delay: -2.2s; }
.fd-spark--s5 { top: 18%; left: 12%; }
.fd-spark--s6 { top: 22%; right: 18%; font-size: 26px; animation-delay: -1.4s; }
.fd-spark--s7 { bottom: 24%; right: 32%; animation-delay: -2s; }

@keyframes fd-twinkle {
  0%,100% { opacity: .35; transform: scale(.85) rotate(0); }
  50%     { opacity: 1; transform: scale(1.15) rotate(20deg); }
}

/* ═══════════════════════════════════════════════════════════════════════
   INTRO  — статичный hero c курсивом и 4 продуктами
   ═══════════════════════════════════════════════════════════════════════ */
.fd-intro {
  position: relative;
  min-height: 100vh;
  padding: 140px 56px 60px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  isolation: isolate;
  background:
    radial-gradient(50% 50% at 12% 30%, rgba(166,212,159,.35), transparent 60%),
    radial-gradient(60% 60% at 50% 0%,  rgba(193,167,226,.35), transparent 60%),
    radial-gradient(50% 50% at 90% 80%, rgba(242,183,201,.35), transparent 60%),
    var(--fd-bg-soft);
}

.fd-pearl--i1 { width: 110px; height: 110px; top: 20%; left: 8%; }
.fd-pearl--i2 { width: 70px;  height: 70px;  top: 30%; right: 14%; }
.fd-pearl--i3 { width: 90px;  height: 90px;  bottom: 18%; left: 20%; opacity: .7; }
.fd-pearl--i4 { width: 130px; height: 130px; bottom: 12%; right: 22%; opacity: .8; }

.fd-intro__inner {
  position: relative;
  z-index: 5;
  width: 100%;
  max-width: 1280px;
  display: flex; flex-direction: column;
  align-items: center;
  gap: 30px;
}

.fd-intro__title {
  position: relative;
  text-align: center;
  width: 100%;
  max-width: 100%;
  overflow: visible;
  padding: 0 30px;
}
.fd-intro__tm { display: none; }
.fd-intro__brand {
  font-family: var(--fd-script) !important;
  font-style: normal;
  font-weight: 400;
  /* «Fresh Doze» — брендовая каллиграфия (Allura), как в логотипе.
     Чуть крупнее чем Yeseva, т.к. Allura заметно уже по глифам. */
  font-size: clamp(64px, 10vw, 156px);
  line-height: 1;
  margin: 0;
  letter-spacing: 0;
  background: linear-gradient(180deg, #2a2a2a 0%, #5a4574 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  /* Доп. padding под длинные каллиграфические хвосты (F слева, e/z справа) */
  padding: 0.12em 0.18em 0.18em 0.18em;
  white-space: nowrap;
  display: inline-block;
  max-width: 100%;
}
.fd-intro__sub {
  font-family: var(--fd-display);
  font-size: clamp(14px, 1.4vw, 20px);
  letter-spacing: 12px;
  font-weight: 700;
  color: var(--fd-purple-deep);
  margin-top: 12px;
}

.fd-intro__row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(8px, 2vw, 24px);
  margin-top: 30px;
  width: 100%;
}
.fd-intro__pkg {
  position: relative;
  width: clamp(160px, 16vw, 240px);
  aspect-ratio: 4/5;
  border-radius: 16px;
  box-shadow: var(--fd-shadow);
  isolation: isolate;
  display: grid; place-items: center;
  padding: 22px 18px;
  font-family: var(--fd-display);
  font-weight: 800;
  text-align: center;
  transform: rotate(var(--rot, 0)) translateY(var(--y, 0));
  animation: fd-intro-float 8s ease-in-out infinite;
  animation-delay: var(--d, 0s);
  transition: transform .35s ease;
}
.fd-intro__pkg:hover { transform: rotate(0) translateY(-12px) scale(1.04); }
@keyframes fd-intro-float {
  0%,100% { transform: rotate(var(--rot, 0)) translateY(var(--y, 0)); }
  50%     { transform: rotate(var(--rot, 0)) translateY(calc(var(--y, 0) - 14px)); }
}
.fd-intro__pkg::before {
  content: "";
  position: absolute;
  inset: 14% 12% 8%;
  background:
    linear-gradient(180deg, rgba(255,255,255,.65), rgba(255,255,255,0) 45%),
    radial-gradient(ellipse at 80% 70%, rgba(255,255,255,.5), transparent 60%);
  border-radius: 8px;
  z-index: 1;
}
.fd-intro__pkg::after {
  content: "OPEN";
  position: absolute; top: 14px; left: 50%;
  transform: translateX(-50%);
  background: rgba(255,255,255,.95);
  padding: 5px 16px;
  border-radius: 9999px;
  font-size: 10px;
  letter-spacing: 2px;
  z-index: 3;
  box-shadow: 0 4px 8px rgba(0,0,0,.08);
}
.fd-intro__pkg--green  { background: linear-gradient(160deg, #c1e0b8 0%, #79b873 60%, #5daa52 100%); }
.fd-intro__pkg--green::after  { color: var(--fd-green-deep); }
.fd-intro__pkg--purple { background: linear-gradient(160deg, #d4b6ec 0%, #a385c8 60%, #8b5dbf 100%); }
.fd-intro__pkg--purple::after { color: var(--fd-purple-deep); }
.fd-intro__pkg--punch  { background: linear-gradient(160deg, #f7b8b1 0%, #ed7e75 60%, #e84a3b 100%); }
.fd-intro__pkg--punch::after  { color: var(--fd-punch-deep); }
.fd-intro__pkg--pink   { background: linear-gradient(160deg, #f7c5d3 0%, #e88fa8 60%, #e94b7c 100%); }
.fd-intro__pkg--pink::after   { color: var(--fd-pink-deep); }

.fd-intro__pkg-label {
  position: relative;
  z-index: 2;
  color: white;
  font-size: 14px;
  line-height: 1.25;
  text-shadow: 0 2px 6px rgba(0,0,0,.15);
}
.fd-intro__pkg-label b {
  display: block;
  font-size: clamp(28px, 3vw, 40px);
  margin: 6px 0 4px;
}
.fd-intro__pkg-label span {
  display: block;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: .5px;
  opacity: .95;
}

@media (max-width: 1024px) {
  .fd-intro { padding: 120px 28px 40px; }
  .fd-intro__row { flex-wrap: wrap; gap: 16px; }
  .fd-intro__pkg { width: calc(50% - 16px); }
}
@media (max-width: 480px) {
  .fd-intro__pkg { width: calc(50% - 8px); }
  .fd-intro__row { gap: 8px; }
}

/* ═══════════════════════════════════════════════════════════════════════
   HERO SLIDER
   ═══════════════════════════════════════════════════════════════════════ */
.fd-hero {
  position: relative;
  min-height: 100vh;
  padding: 130px 56px 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  overflow: hidden;
  isolation: isolate;
}

/* watermark на фоне */
.fd-wm {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  display: flex; flex-direction: column;
  justify-content: center;
  gap: 14px;
  overflow: hidden;
  padding: 40px 0;
  opacity: .22;
}
.fd-wm__row {
  width: 100%;
  overflow: hidden;
}
.fd-wm__line {
  font-family: var(--fd-display);
  font-weight: 900;
  font-size: clamp(56px, 8vw, 100px);
  letter-spacing: -2px;
  white-space: nowrap;
  color: transparent;
  -webkit-text-stroke: 1.5px var(--fd-purple-deep);
  line-height: 1;
  display: inline-block;
  width: max-content;
  will-change: transform;
}
.fd-wm__line--ps { animation: fd-wm-l 80s linear infinite; }
.fd-wm__line--fd {
  -webkit-text-stroke-color: var(--fd-pink-deep);
  animation: fd-wm-r 100s linear infinite;
}
.fd-wm__row:nth-child(2) .fd-wm__line { animation-duration: 95s; }
.fd-wm__row:nth-child(3) .fd-wm__line { animation-duration: 70s; }
.fd-wm__row:nth-child(4) .fd-wm__line { animation-duration: 110s; }
.fd-wm__row:nth-child(5) .fd-wm__line { animation-duration: 90s; }
.fd-wm__row:nth-child(6) .fd-wm__line { animation-duration: 75s; }

@keyframes fd-wm-l {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@keyframes fd-wm-r {
  from { transform: translateX(-50%); }
  to   { transform: translateX(0); }
}

/* центральная сцена */
.fd-hero__stage {
  position: relative;
  z-index: 5;
  width: 100%;
  max-width: 1280px;
  min-height: 600px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 60px 0 40px;
}

/* центральный кластер: cloud + active product + cap */
.fd-hero__center {
  position: relative;
  width: clamp(280px, 32vw, 460px);
  height: clamp(360px, 38vw, 540px);
  display: flex; align-items: center; justify-content: center;
  z-index: 5;
}

/* PRESS · SHAKE split outline */
.fd-hero__split {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -55%);
  z-index: 2;
  display: flex;
  align-items: center;
  gap: clamp(280px, 34vw, 520px);
  pointer-events: none;
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: clamp(90px, 14vw, 220px);
  line-height: 1;
  letter-spacing: -4px;
  width: 100%;
  justify-content: center;
}
.fd-hero__split-l, .fd-hero__split-r {
  color: transparent;
  -webkit-text-stroke: 3px var(--flavor-deep, var(--fd-purple-deep));
  transition: -webkit-text-stroke-color .8s ease, transform .6s ease, opacity .6s ease;
}
.fd-hero.is-changing .fd-hero__split-l { transform: translateX(-30px); opacity: .4; }
.fd-hero.is-changing .fd-hero__split-r { transform: translateX(30px);  opacity: .4; }

/* powder cloud (внутри fd-hero__center) */
.fd-cloud {
  position: absolute;
  inset: -10% -20% -20%;
  background:
    radial-gradient(ellipse at 50% 30%, var(--flavor, var(--fd-purple)) 0%, transparent 55%),
    radial-gradient(ellipse at 30% 70%, var(--flavor, var(--fd-purple)) 0%, transparent 50%),
    radial-gradient(ellipse at 70% 75%, var(--flavor, var(--fd-purple)) 0%, transparent 55%);
  filter: blur(36px);
  opacity: .65;
  z-index: 1;
  pointer-events: none;
  transition: opacity .8s ease, filter .8s ease, background .8s ease;
  animation: fd-cloud-pulse 6s ease-in-out infinite;
}
@keyframes fd-cloud-pulse {
  0%,100% { transform: scale(1); }
  50%     { transform: scale(1.06); }
}
.fd-hero.is-changing .fd-cloud { opacity: 1; filter: blur(28px); }

/* активная упаковка ПОД крышкой (не перекрывая) */
.fd-hero__active {
  position: absolute;
  top: 48%; left: 50%;
  transform: translate(-50%, 0);
  z-index: 3;
  pointer-events: none;
  width: 78%;
  display: flex; justify-content: center;
}
.fd-pkg--active {
  width: 100%;
  max-width: 240px;
  aspect-ratio: 4/5;
  border-radius: 16px;
  box-shadow: 0 26px 50px -10px rgba(31, 31, 31, .35);
  position: relative;
  isolation: isolate;
  transition: background .7s ease, transform .55s cubic-bezier(.34,1.56,.64,1), opacity .4s ease;
  animation: fd-active-float 7s ease-in-out infinite;
}
@keyframes fd-active-float {
  0%,100% { transform: translateY(0) rotate(-1deg); }
  50%     { transform: translateY(-10px) rotate(1.5deg); }
}
.fd-pkg--active::before {
  content: "";
  position: absolute;
  inset: 14% 12% 8%;
  background:
    linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,255,255,0) 45%),
    radial-gradient(ellipse at 80% 70%, rgba(255,255,255,.4), transparent 60%);
  border-radius: 8px;
  z-index: 1;
}
.fd-pkg--active::after {
  content: "OPEN";
  position: absolute; top: 12px; left: 50%;
  transform: translateX(-50%);
  background: rgba(255,255,255,.95);
  padding: 5px 18px;
  border-radius: 9999px;
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--flavor-deep);
  z-index: 3;
  box-shadow: 0 4px 8px rgba(0,0,0,.08);
}

.fd-hero.is-changing .fd-pkg--active { transform: translateY(20px) scale(.92); opacity: .5; }

/* частицы порошка вокруг крышки */
.fd-particle {
  position: absolute;
  width: 8px; height: 8px;
  border-radius: 9999px;
  background: var(--flavor-deep, var(--fd-purple-deep));
  filter: blur(.5px);
  opacity: .55;
  z-index: 4;
  pointer-events: none;
  transition: background .6s ease;
}
.fd-particle--1 { top: 18%; left: 12%; animation: fd-part 4s ease-in-out infinite; }
.fd-particle--2 { top: 28%; right: 18%; width: 6px; height: 6px; animation: fd-part 5s ease-in-out -1s infinite; }
.fd-particle--3 { top: 50%; left: 4%;  width: 5px; height: 5px; animation: fd-part 6s ease-in-out -2s infinite; }
.fd-particle--4 { top: 40%; right: 6%; animation: fd-part 5.5s ease-in-out -3s infinite; }
.fd-particle--5 { bottom: 24%; left: 20%; width: 7px; height: 7px; animation: fd-part 4.5s ease-in-out -1.5s infinite; }
.fd-particle--6 { bottom: 14%; right: 22%; width: 5px; height: 5px; animation: fd-part 5s ease-in-out -2.5s infinite; }
@keyframes fd-part {
  0%,100% { transform: translate(0,0) scale(.85); opacity: .35; }
  50%     { transform: translate(8px,-14px) scale(1.2); opacity: .9; }
}

/* крышка — над продуктом */
.fd-cap {
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: clamp(160px, 18vw, 240px);
  aspect-ratio: 1/1;
  z-index: 6;
  filter: drop-shadow(var(--fd-shadow-cap));
  animation: fd-cap-float 6s ease-in-out infinite;
  transition: transform .55s cubic-bezier(.34,1.56,.64,1);
}
@keyframes fd-cap-float {
  0%,100% { transform: translateX(-50%) translateY(0) rotate(-1deg); }
  50%     { transform: translateX(-50%) translateY(-12px) rotate(2deg); }
}
.fd-hero.is-changing .fd-cap { animation: fd-cap-press .55s cubic-bezier(.34,1.56,.64,1); }
@keyframes fd-cap-press {
  0%   { transform: translateX(-50%) translateY(0) scale(1); }
  35%  { transform: translateX(-50%) translateY(20px) scale(.92); }
  70%  { transform: translateX(-50%) translateY(-8px) scale(1.05); }
  100% { transform: translateX(-50%) translateY(0) scale(1); }
}
.fd-cap__top {
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: 86%; height: 26%;
  background: radial-gradient(ellipse at 50% 20%, #fff 0%, #f3eafa 60%, #d8c3ec 100%);
  border-radius: 50% 50% 8px 8px / 90% 90% 8px 8px;
  box-shadow: inset 0 -8px 14px rgba(155,120,204,.18);
}
.fd-cap__ridge {
  position: absolute;
  top: 22%; left: 50%;
  transform: translateX(-50%);
  width: 78%; height: 18%;
  background:
    repeating-linear-gradient(90deg,
      #f3eafa 0%, #d8c3ec 1.6%,
      #f3eafa 3.2%, #d8c3ec 4.8%,
      #f3eafa 6.4%);
  border-radius: 4px;
}
.fd-cap__neck {
  position: absolute;
  top: 38%; left: 50%;
  transform: translateX(-50%);
  width: 70%; height: 62%;
  background: linear-gradient(180deg, #ffffff 0%, #f7f0fb 50%, #d9c8ec 100%);
  border-radius: 0 0 12px 12px;
  box-shadow:
    inset 0 8px 14px rgba(155,120,204,.2),
    inset -10px -10px 18px rgba(155,120,204,.18);
}
.fd-cap__sparkle {
  position: absolute;
  color: white;
  filter: drop-shadow(0 2px 8px rgba(155,120,204,.6));
  font-size: 22px;
  font-family: var(--fd-display);
  animation: fd-twinkle 3s ease-in-out infinite;
}
.fd-cap__sparkle--1 { top: -8%; right: -10%; font-size: 28px; }
.fd-cap__sparkle--2 { top: 30%; left: -12%; animation-delay: -1s; }
.fd-cap__sparkle--3 { bottom: 12%; right: -6%; font-size: 18px; animation-delay: -2s; }

/* боковые упаковки */
.fd-hero__sides {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  pointer-events: none;
  z-index: 2;
}
.fd-hero__side {
  display: grid;
  place-items: center;
  opacity: .55;
  filter: blur(1px) saturate(.85);
  transition: opacity .6s ease, transform .6s ease;
}
.fd-hero__side--prev { justify-content: start; padding-left: 4%; }
.fd-hero__side--next { justify-content: end;   padding-right: 4%; }

.fd-hero__sides .fd-pkg {
  width: clamp(140px, 13vw, 200px);
  aspect-ratio: 4/5;
  border-radius: 14px;
  box-shadow: var(--fd-shadow);
  position: relative;
  isolation: isolate;
  transform: rotate(-8deg);
  animation: fd-pkg-float 8s ease-in-out infinite;
}
.fd-hero__sides .fd-pkg::before {
  content: "";
  position: absolute;
  inset: 14% 12% 8%;
  background: linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,255,255,0) 45%);
  border-radius: 8px;
  z-index: 1;
}
.fd-hero__sides .fd-pkg::after {
  content: "OPEN";
  position: absolute; top: 12px; left: 50%;
  transform: translateX(-50%);
  background: rgba(255,255,255,.85);
  padding: 4px 14px;
  border-radius: 9999px;
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 9px;
  letter-spacing: 1.5px;
  z-index: 2;
}
.fd-hero__side--next .fd-pkg { transform: rotate(10deg); animation-delay: -2s; }
@keyframes fd-pkg-float {
  0%,100% { transform: rotate(var(--rot, -8deg)) translateY(0); }
  50%     { transform: rotate(var(--rot, -8deg)) translateY(-12px); }
}
.fd-hero.is-changing .fd-hero__side--prev { transform: translateX(-30px); opacity: .2; }
.fd-hero.is-changing .fd-hero__side--next { transform: translateX(30px);  opacity: .2; }

/* цвета упаковок (плейсхолдеры под фото) */
.fd-pkg--purple { background: linear-gradient(160deg, #f0e3fa 0%, #c1a7e2 100%); }
.fd-pkg--green  { background: linear-gradient(160deg, #e2f0dd 0%, #a6d49f 100%); }
.fd-pkg--punch  { background: linear-gradient(160deg, #fde2dc 0%, #f4a09a 100%); }
.fd-pkg--pink   { background: linear-gradient(160deg, #fde2eb 0%, #f2b7c9 100%); }
.fd-pkg::after {
  content: "OPEN";
  position: absolute; top: 14px; left: 50%;
  transform: translateX(-50%);
  background: rgba(255,255,255,.9);
  padding: 4px 14px;
  border-radius: 9999px;
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 10px;
  letter-spacing: 1.5px;
  color: var(--flavor-deep, var(--fd-purple-deep));
}
.fd-pkg--green::after  { color: var(--fd-green-deep); }
.fd-pkg--punch::after  { color: var(--fd-punch-deep); }
.fd-pkg--pink::after   { color: var(--fd-pink-deep); }

/* инфо-карточка справа */
.fd-hero__info {
  position: absolute;
  right: 4%;
  bottom: 12%;
  z-index: 7;
  text-align: left;
  max-width: 300px;
  transition: opacity .5s, transform .5s;
}
.fd-hero__info-flavor {
  font-family: var(--fd-display);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 1.5px;
  color: var(--flavor-deep, var(--fd-purple-deep));
  margin-bottom: 10px;
  text-transform: uppercase;
  transition: color .6s ease, opacity .3s ease;
}
.fd-hero__info-title {
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 32px;
  line-height: 1.05;
  margin: 0 0 16px;
  color: var(--fd-ink);
}
.fd-hero__info-bullets {
  display: flex; flex-direction: column;
  gap: 8px;
  margin: 0 0 22px;
}
.fd-hero__info-bullets span {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 14px;
  color: var(--fd-ink-soft);
  font-weight: 500;
}
.fd-hero__info-bullets i {
  width: 20px; height: 20px;
  border-radius: 9999px;
  background: var(--flavor-deep, var(--fd-purple-deep));
  color: white;
  display: grid; place-items: center;
  font-size: 9px;
  transition: background .6s ease;
}

.fd-hero.is-changing .fd-hero__info-flavor,
.fd-hero.is-changing .fd-hero__info-title { opacity: .3; }

/* DISCOVER */
.fd-discover {
  display: inline-flex; align-items: center; flex-direction: column; gap: 4px;
  margin-top: 24px;
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 13px;
  letter-spacing: 2px;
  color: var(--fd-ink);
  z-index: 5;
}
.fd-discover i { font-size: 12px; animation: fd-bounce 2s ease-in-out infinite; }
@keyframes fd-bounce {
  0%,100% { transform: translateY(0); opacity: .6; }
  50%     { transform: translateY(6px); opacity: 1; }
}

/* ═══════════════════════════════════════════════════════════════════════
   PACK SIZE SELECTOR — пилюли «12 шт / 24 шт» в карточках товара
   ═══════════════════════════════════════════════════════════════════════ */

.fd-pack-sel {
  display: flex;
  gap: 8px;
  margin: 12px 0 0;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}
.fd-pack-sel--sm { margin: 8px 0 0; }

.fd-pack-sel__pill {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 34px;
  padding: 0 18px;
  border-radius: 10px;
  border: 1.5px solid rgba(255,255,255,.18);
  background: var(--fd-ink);
  color: rgba(255,255,255,.75);
  font-family: var(--fd-display) !important;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .22s, color .22s, border-color .22s,
              transform .22s, box-shadow .22s;
  white-space: nowrap;
  user-select: none;
}
.fd-pack-sel__pill:hover {
  background: #333;
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 6px 20px -6px rgba(0,0,0,.4);
}
.fd-pack-sel__pill--active,
[data-flavor="green"] .fd-pack-sel__pill--active,
[data-flavor="punch"] .fd-pack-sel__pill--active,
[data-flavor="pink"]  .fd-pack-sel__pill--active {
  background: #EDE1F9;
  color: var(--fd-ink);
  border-color: #EDE1F9;
  box-shadow: 0 4px 16px -6px rgba(139,93,191,.35);
  transform: translateY(-1px);
}

/* Неактивные пилюли по вкусу — чёрные */
[data-flavor="green"] .fd-pack-sel__pill:not(.fd-pack-sel__pill--active),
[data-flavor="punch"] .fd-pack-sel__pill:not(.fd-pack-sel__pill--active),
[data-flavor="pink"]  .fd-pack-sel__pill:not(.fd-pack-sel__pill--active) {
  border-color: rgba(255,255,255,.18); color: rgba(255,255,255,.75);
}

/* Плавная смена фото в карточке */
.fd-prod__photo,
.fd-prod__box { transition: opacity .28s ease; }
.fd-prod__photo.is-switching { opacity: 0; }

/* Состояние «добавлено» */
.fd-pack-add.is-added {
  background: var(--fd-green-deep) !important;
  border-color: var(--fd-green-deep) !important;
  color: #fff !important;
}

/* нижняя цветная полоса — без своих границ/фона, чтобы не было seam'а с hero */
.fd-strip {
  width: 100%;
  margin: 0;
  padding: 14px 0;
  border: 0;
  overflow: hidden;
  position: relative;
  z-index: 5;
  background: transparent;
}
.fd-strip__track {
  display: flex; align-items: center; gap: 60px;
  width: max-content;
  animation: fd-scroll-l 32s linear infinite;
  white-space: nowrap;
}
@keyframes fd-scroll-l {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.fd-strip__word {
  font-family: var(--fd-display);
  font-weight: 900;
  font-size: clamp(36px, 5vw, 64px);
  letter-spacing: 1px;
  line-height: 1;
}
.fd-strip__word--green   { color: var(--fd-green-deep); }
.fd-strip__word--pink    { color: var(--fd-pink-deep); opacity: .7; }
.fd-strip__word--purple  { color: var(--fd-purple-deep); }
.fd-strip__word--punch   { color: var(--fd-punch-deep); opacity: .8; }

/* === цвет флейвора hero === */
.fd-hero[data-flavor="purple"] { --flavor: var(--fd-purple); --flavor-deep: var(--fd-purple-deep); }
.fd-hero[data-flavor="green"]  { --flavor: var(--fd-green);  --flavor-deep: var(--fd-green-deep); }
.fd-hero[data-flavor="punch"]  { --flavor: var(--fd-punch);  --flavor-deep: var(--fd-punch-deep); }
.fd-hero[data-flavor="pink"]   { --flavor: var(--fd-pink);   --flavor-deep: var(--fd-pink-deep); }

/* ═══════════════════════════════════════════════════════════════════════
   PRODUCTS
   ═══════════════════════════════════════════════════════════════════════ */
.fd-products {
  background: white;
  position: relative;
  padding: 120px 0;
}
.fd-products__head {
  text-align: center;
  margin-bottom: 80px;
}
.fd-display {
  font-family: var(--fd-display);
  font-weight: 900;
  font-size: clamp(56px, 8vw, 120px);
  line-height: 1;
  letter-spacing: -3px;
  margin: 0;
}
.fd-display--outlined {
  color: transparent;
  -webkit-text-stroke: 2px var(--fd-purple);
}
.fd-products__all {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 16px;
  font-family: var(--fd-display);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 2px;
  color: var(--fd-purple-deep);
  border-bottom: 1.5px solid var(--fd-purple-deep);
  padding-bottom: 4px;
  text-transform: uppercase;
}
.fd-products__all:hover { color: var(--fd-ink); border-color: var(--fd-ink); }

.fd-products__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 100px 80px;
  max-width: none;
  margin: 0;
  padding: 0 40px;
  width: 100%;
}

.fd-prod {
  display: flex; flex-direction: column;
  transition: transform .35s ease;
}
.fd-prod:hover { transform: translateY(-6px); }

.fd-prod__art {
  position: relative;
  height: 380px;
  display: block;
  overflow: hidden;
  isolation: isolate;
}

/* дуга-бейдж: за центральной композицией */
.fd-prod__arc {
  position: absolute;
  top: 8%;
  left: 240px;
  right: auto;
  transform: none;
  width: 230px;
  height: 230px;
  border-radius: 9999px;
  background: linear-gradient(135deg, var(--flavor) 0%, var(--flavor-deep) 100%);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 0 18px 0 70px;
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 12px;
  letter-spacing: .3px;
  text-align: right;
  color: white;
  line-height: 1.3;
  z-index: 1;
  box-shadow: 0 14px 30px -6px var(--flavor-deep);
  text-transform: lowercase;
}
.fd-prod__arc::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1.5px dashed rgba(255,255,255,.5);
  border-radius: 9999px;
  pointer-events: none;
}

/* подиумы — выровнены с текстом + сдвинуты к центру для широких карточек */
.fd-prod__podium {
  position: absolute;
  border-radius: 50%;
}
.fd-prod__podium--back {
  width: 240px; height: 58px;
  background:
    radial-gradient(ellipse at 50% 30%, #fff 0%, #e7e9ed 50%, #c9cdd4 100%);
  left: 40px;
  bottom: 50px;
  z-index: 2;
  box-shadow:
    0 4px 0 0 #b2b6bf,
    0 8px 0 0 #9ea2ab,
    0 14px 18px -8px rgba(60,60,80,.4);
}
.fd-prod__podium--front {
  width: 290px; height: 64px;
  left: 150px;
  bottom: 22px;
  z-index: 4;
  background:
    radial-gradient(ellipse at 50% 30%, color-mix(in srgb, var(--flavor) 50%, white) 0%, var(--flavor) 60%, var(--flavor-deep) 100%);
  box-shadow:
    0 4px 0 0 var(--flavor-deep),
    0 8px 0 0 color-mix(in srgb, var(--flavor-deep) 80%, black),
    0 16px 22px -6px var(--flavor-deep);
}

/* коробка — на сером подиуме */
.fd-prod__box {
  position: absolute;
  bottom: 90px;
  left: 60px;
  transform: rotate(-4deg);
  width: 155px;
  height: 200px;
  border-radius: 4px;
  z-index: 3;
  box-shadow:
    inset -10px 0 16px -2px rgba(0,0,0,.18),
    inset 10px 0 16px -2px rgba(255,255,255,.25),
    0 18px 30px -10px rgba(0,0,0,.25);
  isolation: isolate;
}
.fd-prod__box--purple { background: linear-gradient(180deg, #f0e3fa 0%, #c1a7e2 50%, #8b5dbf 100%); }
.fd-prod__box--green  { background: linear-gradient(180deg, #e2f0dd 0%, #a6d49f 50%, #5daa52 100%); }
.fd-prod__box--punch  { background: linear-gradient(180deg, #fde2dc 0%, #f4a09a 50%, #e84a3b 100%); }
.fd-prod__box--pink   { background: linear-gradient(180deg, #fde2eb 0%, #f2b7c9 50%, #e94b7c 100%); }

/* OPEN-стикер на коробке */
.fd-prod__box::before {
  content: "OPEN";
  position: absolute;
  top: 12px; left: 50%;
  transform: translateX(-50%);
  background: white;
  padding: 4px 14px;
  border-radius: 9999px;
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--flavor-deep);
  box-shadow: 0 2px 4px rgba(0,0,0,.1);
  z-index: 2;
}
/* «контентная зона» коробки — белая полоса с микро-табличкой */
.fd-prod__box::after {
  content: "";
  position: absolute;
  inset: 36% 12% 18% 12%;
  background:
    linear-gradient(180deg, rgba(255,255,255,.85) 0%, rgba(255,255,255,.6) 100%),
    repeating-linear-gradient(180deg, transparent 0 6px, rgba(0,0,0,.06) 6px 7px);
  border-radius: 4px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.5);
}

/* SVG-крышка — на цветном подиуме, спереди-центр */
.fd-prod__cap {
  position: absolute;
  bottom: 60px;
  left: 215px;
  width: 110px;
  height: 130px;
  z-index: 5;
  filter: drop-shadow(0 18px 24px rgba(115,84,162,.35));
  background:
    /* шапка-купол */
    radial-gradient(ellipse at 50% 18%, #fff 0%, #fff 30%, #ece3f5 60%, #c8b3e2 100%);
  border-radius: 50% 50% 16% 16% / 70% 70% 12% 12%;
}
.fd-prod__cap::before {
  /* резьба */
  content: "";
  position: absolute;
  top: 32%;
  left: 8%; right: 8%;
  height: 22%;
  background:
    repeating-linear-gradient(90deg,
      #ece3f5 0 5%,
      #c8b3e2 5% 6%);
  border-radius: 4px;
  box-shadow:
    inset 0 4px 4px -2px rgba(155,120,204,.3),
    inset 0 -4px 4px -2px rgba(155,120,204,.25);
}
.fd-prod__cap::after {
  /* «горло» */
  content: "";
  position: absolute;
  top: 56%;
  left: 16%; right: 16%;
  bottom: 0;
  background: linear-gradient(180deg, #fff 0%, #efe6f8 50%, #c8b3e2 100%);
  border-radius: 6px 6px 50% 50% / 6px 6px 100% 100%;
  box-shadow:
    inset 8px 0 14px -6px rgba(255,255,255,.7),
    inset -8px 0 14px -6px rgba(155,120,204,.3);
}

/* Фрукты: layered-шар сбоку от крышки, ближе к центру */
.fd-prod__fruit {
  position: absolute;
  bottom: 90px;
  left: 320px;
  width: 130px;
  height: 130px;
  z-index: 4;
  display: block;
}
.fd-prod__fruit i {
  position: absolute;
  filter: drop-shadow(0 6px 10px rgba(0,0,0,.18));
}
.fd-prod__fruit i:nth-child(1) { font-size: 56px; top: 0;  left: 18%; color: var(--flavor-deep); }
.fd-prod__fruit i:nth-child(2) { font-size: 48px; top: 30%; left: 50%; color: color-mix(in srgb, var(--flavor-deep) 80%, black); }
.fd-prod__fruit i:nth-child(3) { font-size: 44px; top: 8%; left: 56%; color: color-mix(in srgb, var(--flavor-deep) 70%, white); }
.fd-prod__fruit i:nth-child(4) { font-size: 28px; top: -8%; left: 34%; color: var(--fd-green-deep); transform: rotate(-25deg); }

/* per-flavor color */
.fd-prod[data-flavor="purple"] { --flavor: var(--fd-purple); --flavor-deep: var(--fd-purple-deep); }
.fd-prod[data-flavor="green"]  { --flavor: var(--fd-green);  --flavor-deep: var(--fd-green-deep); }
.fd-prod[data-flavor="punch"]  { --flavor: var(--fd-punch);  --flavor-deep: var(--fd-punch-deep); }
.fd-prod[data-flavor="pink"]   { --flavor: var(--fd-pink);   --flavor-deep: var(--fd-pink-deep); }

.fd-prod__info {
  padding: 24px 8px 0;
  display: flex; flex-direction: column;
  align-items: center !important;
  gap: 14px;
  text-align: center !important;
}
.fd-prod__info > *{ text-align: center !important; width: 100%; }
.fd-prod__flavor {
  font-family: var(--fd-body);
  font-weight: 700;
  font-size: 16px;
  color: var(--flavor-deep);
  text-align: center !important;
}
.fd-prod__title {
  font-family: var(--fd-display);
  font-weight: 700;
  font-size: 26px;
  margin: 0;
  color: var(--fd-ink);
  line-height: 1.2;
  text-align: center !important;
}
.fd-prod__title a{ color: inherit; text-decoration: none; }
.fd-prod__price-row {
  display: flex;
  align-items: baseline;
  justify-content: center !important;
  gap: 14px;
  flex-wrap: wrap;
}
.fd-prod__price {
  font-family: var(--fd-display);
  font-weight: 900;
  font-size: 36px;
  color: var(--fd-red);
  text-align: center !important;
}
.fd-prod__price-old {
  color: var(--fd-ink-soft);
  font-size: 14px;
  font-weight: 600;
}
.fd-prod__price-old s { color: var(--fd-ink); margin-left: 6px; }
.fd-prod__sizes { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.fd-prod__sizes-label {
  font-size: 14px; color: var(--fd-ink-soft);
}
.fd-prod__cta {
  display: flex;
  gap: 12px;
  margin-top: 8px;
  flex-wrap: wrap;
  justify-content: center !important;
}
.fd-prod__cta .fd-btn { padding: 12px 22px; font-size: 13px; flex: 0 0 auto; }

/* Скрываем USP-«круглешок» (.fd-prod__arc) — пользователю он мешал.
   USP-текст (badge) рендерится в info через _fo_badge если нужно. */
.fd-prod__arc{ display: none !important; }

/* ═══════════════════════════════════════════════════════════════════════
   TAGLINE
   ═══════════════════════════════════════════════════════════════════════ */
.fd-tagline {
  position: relative;
  background:
    radial-gradient(80% 70% at 50% 100%, rgba(193,167,226,.4), transparent 70%),
    linear-gradient(180deg, white 0%, var(--fd-bg-soft) 100%);
  padding: 140px 56px 100px;
  text-align: center;
  overflow: hidden;
}
.fd-tagline__inner { position: relative; z-index: 5; max-width: 800px; margin: 0 auto; }

.fd-sticker {
  display: inline-flex; align-items: center; gap: 12px;
  background: linear-gradient(135deg, #ff85a8 0%, #e94b7c 100%);
  color: white;
  padding: 12px 26px;
  border-radius: 9999px;
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 16px;
  letter-spacing: 1px;
  transform: rotate(-3deg);
  box-shadow: 0 12px 24px -6px rgba(233,75,124,.5);
  text-transform: uppercase;
}
.fd-sticker i { font-size: 14px; }

.fd-tagline__title {
  font-family: var(--fd-italic);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(48px, 7vw, 96px);
  line-height: 1.05;
  margin: 36px 0 24px;
  color: var(--fd-purple-deep);
  letter-spacing: -1px;
}
.fd-tagline__desc {
  max-width: 620px; margin: 0 auto;
  color: var(--fd-ink-soft);
  font-size: 17px;
  line-height: 1.6;
}

/* ═══════════════════════════════════════════════════════════════════════
   FAN SHOWCASE
   ═══════════════════════════════════════════════════════════════════════ */
.fd-fan {
  position: relative;
  padding: 80px 56px 80px;
  overflow: hidden;
  background: linear-gradient(180deg, var(--fd-bg-soft) 0%, white 100%);
}
.fd-fan--final {
  background: linear-gradient(180deg, white 0%, var(--fd-bg-soft) 100%);
  padding: 80px 56px 120px;
}
.fd-fan__row {
  position: relative;
  z-index: 5;
  display: flex; align-items: center; justify-content: center;
  gap: 0;
  max-width: 1100px;
  margin: 0 auto;
}
.fd-fan__pkg {
  width: clamp(180px, 16vw, 260px);
  aspect-ratio: 4/5;
  border-radius: 14px;
  box-shadow: var(--fd-shadow);
  position: relative;
  margin-left: -40px;
  transform: rotate(var(--rot, 0)) translateY(calc(var(--i) * 6px));
  animation: fd-fan-float 7s ease-in-out infinite;
  animation-delay: calc(var(--i) * -1.5s);
  isolation: isolate;
  will-change: transform, opacity;
}

/* финальный fan — статичная композиция 4 упаковок с лёгким float + sparkles */
.fd-fan--final {
  padding: 80px 56px 120px;
  min-height: 480px;
  overflow: hidden;
}
.fd-fan--final .fd-fan__row {
  position: relative;
  height: 380px;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  display: block;
}
.fd-fan--final .fd-fan__pkg {
  position: absolute;
  margin: 0;
  width: clamp(160px, 14vw, 220px);
  animation: fd-static-float 8s ease-in-out infinite;
  transform-origin: 50% 50%;
}
.fd-fan--final .fd-fan__pkg:nth-child(1) {
  left: 6%;  top: 20%;
  --rot: -12deg;
  animation-delay: 0s;
}
.fd-fan--final .fd-fan__pkg:nth-child(2) {
  left: 28%; top: 8%;
  --rot: -3deg;
  animation-delay: -2s;
  z-index: 2;
}
.fd-fan--final .fd-fan__pkg:nth-child(3) {
  left: 50%; top: 14%;
  --rot: 4deg;
  animation-delay: -4s;
  z-index: 3;
}
.fd-fan--final .fd-fan__pkg:nth-child(4) {
  left: 72%; top: 24%;
  --rot: 12deg;
  animation-delay: -6s;
}
@keyframes fd-static-float {
  0%, 100% { transform: rotate(var(--rot)) translateY(0); }
  50%      { transform: rotate(var(--rot)) translateY(-14px); }
}
@media (max-width: 1024px) {
  .fd-fan--final .fd-fan__row { height: 340px; }
  .fd-fan--final .fd-fan__pkg:nth-child(1) { left: 2%;  }
  .fd-fan--final .fd-fan__pkg:nth-child(4) { left: 70%; }
}
@media (max-width: 640px) {
  .fd-fan--final .fd-fan__row { height: 280px; }
  .fd-fan--final .fd-fan__pkg { width: 120px; }
  .fd-fan--final .fd-fan__pkg:nth-child(1) { left: 0;   top: 30%; }
  .fd-fan--final .fd-fan__pkg:nth-child(2) { left: 22%; top: 10%; }
  .fd-fan--final .fd-fan__pkg:nth-child(3) { left: 48%; top: 18%; }
  .fd-fan--final .fd-fan__pkg:nth-child(4) { left: 70%; top: 32%; }
}
.fd-fan__pkg:first-child { margin-left: 0; }
.fd-fan__pkg::before {
  content: "";
  position: absolute;
  inset: 14% 12% 8%;
  background:
    linear-gradient(180deg, rgba(255,255,255,.65), rgba(255,255,255,0) 45%),
    radial-gradient(ellipse at 80% 70%, rgba(255,255,255,.5), transparent 60%);
  border-radius: 6px;
  z-index: 1;
}
.fd-fan__pkg::after {
  content: "OPEN";
  position: absolute; top: 14px; left: 50%;
  transform: translateX(-50%);
  background: rgba(255,255,255,.95);
  padding: 5px 16px;
  border-radius: 9999px;
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 10px;
  letter-spacing: 2px;
  z-index: 2;
  box-shadow: 0 4px 8px rgba(0,0,0,.08);
}
.fd-fan__pkg--purple { background: linear-gradient(160deg, #d4b6ec 0%, #a385c8 60%, #8b5dbf 100%); }
.fd-fan__pkg--green  { background: linear-gradient(160deg, #c1e0b8 0%, #79b873 60%, #5daa52 100%); }
.fd-fan__pkg--punch  { background: linear-gradient(160deg, #f7b8b1 0%, #ed7e75 60%, #e84a3b 100%); }
.fd-fan__pkg--pink   { background: linear-gradient(160deg, #f7c5d3 0%, #e88fa8 60%, #e94b7c 100%); }
.fd-fan__pkg--purple::after { color: var(--fd-purple-deep); }
.fd-fan__pkg--green::after  { color: var(--fd-green-deep); }
.fd-fan__pkg--punch::after  { color: var(--fd-punch-deep); }
.fd-fan__pkg--pink::after   { color: var(--fd-pink-deep); }

@keyframes fd-fan-float {
  0%,100% { transform: rotate(var(--rot, 0)) translateY(calc(var(--i) * 4px)); }
  50%     { transform: rotate(var(--rot, 0)) translateY(calc(var(--i) * 4px - 16px)); }
}

/* ═══════════════════════════════════════════════════════════════════════
   FLAVOR SHOWCASE CAROUSEL
   ═══════════════════════════════════════════════════════════════════════ */
.fd-flavor {
  position: relative;
  background:
    radial-gradient(60% 60% at 50% 0%, var(--fl-glow, rgba(193,167,226,.35)), transparent 70%),
    var(--fd-bg-soft);
  padding: 100px 0 60px;
  overflow: hidden;
  transition: background .8s ease;
}
.fd-flavor[data-active="purple"] { --fl-glow: rgba(193,167,226,.45); background-color: #f5edfa; }
.fd-flavor[data-active="green"]  { --fl-glow: rgba(166,212,159,.45); background-color: #eef7ec; }
.fd-flavor[data-active="punch"]  { --fl-glow: rgba(244,160,154,.45); background-color: #fceceb; }
.fd-flavor[data-active="pink"]   { --fl-glow: rgba(242,183,201,.5);  background-color: #fceaf0; }

.fd-flavor__viewport { overflow: hidden; }
.fd-flavor__track {
  display: flex;
  width: 100%;
  transition: transform .7s cubic-bezier(.6,.05,.01,.99);
}
.fd-flavor__slide {
  flex: 0 0 100%;
  padding: 0 56px;
  text-align: center;
  position: relative;
}
.fd-flavor__head { margin-bottom: 30px; }
.fd-flavor__kicker {
  font-family: var(--fd-body);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 2px;
  color: var(--fd-ink-soft);
  text-transform: uppercase;
  display: block;
  margin-bottom: 8px;
}
.fd-flavor__title {
  font-family: var(--fd-display);
  font-weight: 900;
  font-size: clamp(54px, 8vw, 120px);
  margin: 0 0 12px;
  letter-spacing: -2px;
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 2px var(--flavor-deep);
}
.fd-flavor__sub {
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: clamp(22px, 2.5vw, 36px);
  color: var(--flavor-deep);
  margin: 0;
}

.fd-flavor__art {
  position: relative;
  height: 460px;
  margin: 30px auto 20px;
  max-width: 900px;
}
.fd-flavor__podium {
  position: absolute;
  bottom: 60px;
  border-radius: 50%;
}
.fd-flavor__podium--back {
  width: 280px; height: 70px;
  background: radial-gradient(ellipse at 50% 50%, #e9eaee 0%, #c8cbd1 100%);
  left: calc(50% - 170px);
  z-index: 1;
  box-shadow: 0 18px 30px -10px rgba(60,60,80,.25);
}
.fd-flavor__podium--front {
  width: 260px; height: 64px;
  background: radial-gradient(ellipse at 50% 50%, var(--flavor) 0%, var(--flavor-deep) 100%);
  left: calc(50% - 70px);
  z-index: 2;
  box-shadow: 0 14px 26px -8px var(--flavor-deep);
}
.fd-flavor__box {
  position: absolute;
  bottom: 100px;
  left: calc(50% - 200px);
  width: 160px; height: 200px;
  border-radius: 8px;
  z-index: 3;
  transform: rotate(-4deg);
  box-shadow: var(--fd-shadow);
}
.fd-flavor__box--purple { background: linear-gradient(180deg, #f0e3fa 0%, #c1a7e2 50%, #a385c8 100%); }
.fd-flavor__box--green  { background: linear-gradient(180deg, #e2f0dd 0%, #a6d49f 50%, #79b873 100%); }
.fd-flavor__box--punch  { background: linear-gradient(180deg, #fde2dc 0%, #f4a09a 50%, #e87c74 100%); }
.fd-flavor__box--pink   { background: linear-gradient(180deg, #fde2eb 0%, #f2b7c9 50%, #e88fa8 100%); }

.fd-flavor__cap {
  position: absolute;
  bottom: 90px;
  left: calc(50% - 50px);
  width: 110px; height: 130px;
  background:
    radial-gradient(ellipse at 50% 20%, #fff 0%, #f3eafa 60%, #d8c3ec 100%);
  border-radius: 28px 28px 8px 8px / 36px 36px 8px 8px;
  box-shadow:
    inset 0 -8px 14px rgba(155,120,204,.2),
    0 14px 22px -6px rgba(115,84,162,.4);
  z-index: 4;
}
.fd-flavor__fruit {
  position: absolute;
  bottom: 110px;
  right: calc(50% - 220px);
  display: flex; flex-direction: column; gap: 6px;
  font-size: 36px;
  color: var(--flavor-deep);
  z-index: 4;
}
.fd-flavor__fruit i { filter: drop-shadow(0 6px 10px rgba(0,0,0,.15)); }

.fd-flavor__bullets {
  position: absolute;
  top: 30px;
  right: 6%;
  display: flex; flex-direction: column;
  gap: 12px;
  z-index: 5;
}
.fd-bullet {
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 16px;
  color: var(--fd-ink);
  background: white;
  padding: 8px 16px;
  border-radius: 9999px;
  box-shadow: var(--fd-shadow-soft);
  position: relative;
  white-space: nowrap;
}
.fd-bullet::before {
  content: "";
  position: absolute;
  left: -14px; top: 50%;
  transform: translateY(-50%);
  width: 8px; height: 8px;
  border-radius: 9999px;
  background: var(--flavor-deep);
}

.fd-flavor__badge {
  position: absolute;
  width: 110px; height: 110px;
  border-radius: 9999px;
  display: grid; place-items: center;
  text-align: center;
  font-family: var(--fd-display);
  font-weight: 900;
  font-size: 26px;
  color: white;
  line-height: 1;
  box-shadow: var(--fd-shadow);
  z-index: 6;
  animation: fd-cap-float 5s ease-in-out infinite;
}
.fd-flavor__badge span {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .5px;
  text-transform: uppercase;
}
.fd-flavor__badge--blue   { background: radial-gradient(circle at 30% 30%, #9ad7ec 0%, #4ba7c7 100%); top: 50%; left: 8%; animation-delay: -1s; }
.fd-flavor__badge--orange { background: radial-gradient(circle at 30% 30%, #ffc080 0%, #ec8a2e 100%); top: 60%; right: 10%; animation-delay: -2s; }

.fd-flavor__fine {
  font-size: 12px;
  color: var(--fd-ink-muted);
  margin: 30px auto 0;
}

.fd-flavor[data-active="purple"] { --flavor: var(--fd-purple); --flavor-deep: var(--fd-purple-deep); }
.fd-flavor[data-active="green"]  { --flavor: var(--fd-green);  --flavor-deep: var(--fd-green-deep); }
.fd-flavor[data-active="punch"]  { --flavor: var(--fd-punch);  --flavor-deep: var(--fd-punch-deep); }
.fd-flavor[data-active="pink"]   { --flavor: var(--fd-pink);   --flavor-deep: var(--fd-pink-deep); }

.fd-flavor__dots {
  display: flex; justify-content: center;
  gap: 12px;
  margin-top: 40px;
  position: relative;
  z-index: 5;
}
.fd-flavor__dots button {
  width: 12px; height: 12px;
  border-radius: 9999px;
  background: rgba(31,31,31,.2);
  transition: width .3s, background .3s;
}
.fd-flavor__dots button.is-active {
  width: 36px;
  background: var(--fd-ink);
}

/* ═══════════════════════════════════════════════════════════════════════
   LIFESTYLE GALLERY
   ═══════════════════════════════════════════════════════════════════════ */
.fd-life {
  position: relative;
  padding: 60px 80px 100px;
  background: linear-gradient(180deg, var(--fd-bg-soft) 0%, white 100%);
}
.fd-life__viewport {
  overflow: hidden;
  border-radius: 24px;
  max-width: 1280px;
  margin: 0 auto;
}
.fd-life__track {
  display: flex;
  gap: 24px;
  transition: transform .6s cubic-bezier(.6,.05,.01,.99);
}
.fd-life__card {
  flex: 0 0 calc((100% - 48px) / 3);
  border-radius: 22px;
  overflow: hidden;
  position: relative;
  /* height убрана — карточка тянется по содержимому (фото + текст) */
  display: flex; flex-direction: column;
  justify-content: flex-end;
  padding: 30px;
  color: white;
  box-shadow: var(--fd-shadow-soft);
}
.fd-life__card--punch  { background: linear-gradient(160deg, #f5a09a 0%, #e84a3b 100%); }
.fd-life__card--purple { background: linear-gradient(160deg, #c1a7e2 0%, #8b5dbf 100%); }
.fd-life__card--green  { background: linear-gradient(160deg, #a6d49f 0%, #5daa52 100%); }
.fd-life__card--pink   { background: linear-gradient(160deg, #f2b7c9 0%, #d23463 100%); }

.fd-life__photo {
  position: absolute;
  inset: 0;
  display: grid; place-items: center;
  font-size: 240px;
  color: rgba(255,255,255,.25);
  filter: blur(.5px);
}
.fd-life__copy { position: relative; z-index: 2; }
.fd-life__copy h3 {
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 22px;
  line-height: 1.25;
  margin: 0 0 18px;
}
.fd-life__copy h3 span {
  font-family: var(--fd-italic);
  font-style: italic;
  font-weight: 400;
  font-size: 32px;
  color: rgba(255,255,255,.95);
  display: block;
  margin-top: 6px;
}

/* lifestyle gallery arrows — компактные, всегда внутри секции */
.fd-arrow--life {
  top: 50%;
  width: 48px; height: 48px;
  border-radius: 12px;
  font-size: 16px;
  border-width: 1.5px;
  animation: none;
  z-index: 30;
}
.fd-arrow--life.fd-arrow--left  { left: 24px; }
.fd-arrow--life.fd-arrow--right { right: 24px; }
.fd-arrow--life:hover { transform: translateY(-50%) scale(1.06); }
@media (max-width: 768px) {
  .fd-arrow--life { width: 40px; height: 40px; }
  .fd-arrow--life.fd-arrow--left  { left: 8px; }
  .fd-arrow--life.fd-arrow--right { right: 8px; }
}

/* ═══════════════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════════════ */
.fd-footer {
  background:
    radial-gradient(60% 70% at 80% 20%, rgba(193,167,226,.3), transparent 70%),
    radial-gradient(50% 60% at 10% 80%, rgba(242,183,201,.3), transparent 70%),
    linear-gradient(180deg, var(--fd-bg-soft) 0%, var(--fd-purple-soft) 100%);
  padding: 80px 80px 0;
  position: relative;
  overflow: hidden;
  margin-top: 0;
}
.fd-footer__inner {
  display: grid;
  grid-template-columns: 1.2fr 1.6fr;
  gap: 60px;
  max-width: 1280px;
  margin: 0 auto;
  padding-bottom: 70px;
}
.fd-footer__brand { display: flex; flex-direction: column; }
.fd-logo__mark--big { display: inline-flex; align-items: flex-start; }
.fd-logo__mark--big .fd-logo__brand {
  font-size: clamp(60px, 7vw, 110px);
  line-height: .95;
}
.fd-logo__mark--big .fd-logo__th { display: none; }
.fd-logo__sub--big { font-size: 16px; letter-spacing: 7px; margin-top: 8px; }

.fd-footer__cols {
  display: grid;
  grid-template-rows: auto auto;
  gap: 50px;
}
.fd-footer__col h4 {
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 18px;
  letter-spacing: 1px;
  color: var(--fd-ink);
  margin: 0 0 22px;
  text-transform: uppercase;
}

.fd-partners { display: flex; flex-wrap: wrap; gap: 14px; }
.fd-partner {
  width: 50px; height: 50px;
  border-radius: 9999px;
  background: white;
  display: grid; place-items: center;
  font-size: 20px;
  color: var(--fd-ink);
  box-shadow: var(--fd-shadow-soft);
  transition: transform .2s;
  position: relative;
  overflow: hidden;
}
.fd-partner:hover { transform: translateY(-4px); }
.fd-partner--fb { color: #1877F2; }
.fd-partner--ig {
  background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
  color: white;
}
.fd-partner--tt { color: var(--fd-ink); }
.fd-partner--tg { background: #229ED9; color: white; }
.fd-partner--yt { color: #FF0000; }
.fd-partner--wa { background: #25D366; color: white; }

.fd-contact-line {
  display: flex; align-items: center; gap: 14px;
  margin: 0 0 14px;
  color: var(--fd-ink);
  font-weight: 600;
  font-size: 16px;
}
.fd-contact-line__icon {
  width: 36px; height: 36px;
  border-radius: 9999px;
  background: var(--fd-ink);
  color: white;
  display: grid; place-items: center;
  font-size: 13px;
  flex-shrink: 0;
}
.fd-contact-line--addr {
  align-items: flex-start;
  font-weight: 500;
  color: var(--fd-ink-soft);
  line-height: 1.6;
}

.fd-footer__copy {
  background: var(--fd-purple);
  color: var(--fd-ink);
  text-align: center;
  padding: 18px 20px;
  font-size: 13px;
  font-weight: 600;
  margin: 0 -80px;
}

/* ═══════════════════════════════════════════════════════════════════════
   FLOATING LINE CHAT
   ═══════════════════════════════════════════════════════════════════════ */
.fd-line-chat {
  position: fixed;
  right: 28px; bottom: 28px;
  width: 60px; height: 60px;
  border-radius: 9999px;
  background: white;
  display: grid; place-items: center;
  font-family: var(--fd-display);
  font-weight: 900;
  font-size: 13px;
  letter-spacing: 1px;
  color: var(--fd-line);
  box-shadow: 0 14px 28px -8px rgba(6,199,85,.5);
  z-index: 150;
  border: 3px solid var(--fd-line);
  transition: transform .25s;
}
.fd-line-chat:hover { transform: scale(1.08); }

/* ═══════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════ */
@media (max-width: 1200px) {
  .fd-products { padding: 100px 40px; }
  .fd-products__grid { gap: 40px; }
  .fd-flavor__bullets { right: 4%; }
}
@media (max-width: 1024px) {
  .fd-header { padding: 18px 28px; }
  .fd-header.is-shrunk { padding: 12px 28px; }
  .fd-products { padding: 80px 28px; }
  .fd-products__grid { grid-template-columns: 1fr; gap: 60px; }
  .fd-products__head { margin-bottom: 50px; }
  .fd-life { padding: 50px 28px 80px; }
  .fd-life__card { flex: 0 0 calc((100% - 24px) / 2); }
  .fd-tagline, .fd-flavor { padding-left: 28px; padding-right: 28px; }
  .fd-fan { padding: 60px 28px; }
  .fd-hero { padding: 110px 28px 0; }
  .fd-footer { padding: 60px 28px 0; }
  .fd-footer__copy { margin: 0 -28px; }
  .fd-footer__inner { grid-template-columns: 1fr; gap: 40px; }
  .fd-arrow--left  { left: 12px; }
  .fd-arrow--right { right: 12px; }
}
@media (max-width: 900px) {
  /* hero становится вертикальным стеком */
  .fd-hero__stage {
    flex-direction: column;
    min-height: auto;
    gap: 20px;
  }
  .fd-hero__sides { display: none; } /* убираем боковые упаковки на узком */
  .fd-hero__split { font-size: clamp(60px, 18vw, 110px); gap: clamp(140px, 35vw, 220px); top: 30%; transform: translate(-50%, -50%); }
  .fd-hero__center { width: 70vw; height: auto; aspect-ratio: 1/1.3; }
  .fd-cap { width: 38vw; }
  .fd-pkg--active { max-width: 50vw; }
  .fd-hero__info {
    position: static;
    max-width: none;
    width: 100%;
    text-align: center;
    margin-top: 30px;
    transform: none;
  }
  .fd-hero__info-bullets { align-items: center; }
  .fd-hero__info-bullets span { justify-content: center; }
  .fd-hero__info-title { font-size: 26px; }
  .fd-arrow { width: 44px; height: 44px; font-size: 14px; top: 38%; }
}
@media (max-width: 768px) {
  .fd-press-menu { padding: 6px 10px; }
  .fd-press-menu__cursor { width: 22px; height: 22px; font-size: 11px; }
  .fd-btn--ghost { display: none; }
  .fd-logo__brand { font-size: 30px; }
  .fd-logo__th { font-size: 8px; top: -6px; }
  .fd-logo__sub { font-size: 9px; letter-spacing: 3px; }
  .fd-products__grid { grid-template-columns: 1fr; gap: 60px; padding: 0 16px; }
  .fd-prod__art { height: 320px; }
  /* product card art — масштаб под планшет/мобайл */
  .fd-prod__arc      { width: 170px; height: 170px; left: 110px; top: 12%; font-size: 11px; padding: 0 16px 0 60px; }
  .fd-prod__box      { width: 110px; height: 145px; bottom: 80px; left: 0; }
  .fd-prod__cap      { width: 78px;  height: 90px;  bottom: 60px; left: 86px; }
  .fd-prod__fruit    { width: 90px;  height: 90px;  bottom: 70px; left: 160px; }
  .fd-prod__podium--back  { width: 190px; height: 46px; left: -8px; bottom: 46px; }
  .fd-prod__podium--front { width: 220px; height: 50px; left: 60px; bottom: 22px; }
  .fd-prod__title { font-size: 22px; }
  .fd-prod__price { font-size: 30px; }
  .fd-life__card { flex: 0 0 100%; }
  .fd-flavor__art { height: 380px; }
  .fd-flavor__bullets { position: static; flex-direction: row; flex-wrap: wrap; justify-content: center; margin-top: 30px; }
  .fd-flavor__badge { width: 80px; height: 80px; font-size: 18px; }
  .fd-flavor__badge span { font-size: 10px; }
  .fd-fan__pkg { margin-left: -20px; }
  .fd-life__copy h3 { font-size: 18px; }
  .fd-life__copy h3 span { font-size: 24px; }
  .fd-display { font-size: 56px; }
  .fd-tagline__title { font-size: 48px; }
  .fd-strip__word { font-size: 36px; }
  .fd-wm__line { font-size: 42px; }
  .fd-hero__split { gap: 100px; font-size: 70px; }
}
@media (max-width: 480px) {
  .fd-prod__art { height: 280px; }
  /* мобильные: ещё компактнее */
  .fd-prod__arc      { width: 140px; height: 140px; left: 90px; top: 10%; font-size: 10px; padding: 0 12px 0 50px; }
  .fd-prod__box      { width: 90px;  height: 120px; bottom: 80px; left: 0; }
  .fd-prod__cap      { width: 64px;  height: 75px;  bottom: 60px; left: 70px; }
  .fd-prod__fruit    { width: 75px;  height: 75px;  bottom: 70px; left: 130px; }
  .fd-prod__podium--back  { width: 160px; height: 40px; left: -8px; bottom: 44px; }
  .fd-prod__podium--front { width: 180px; height: 44px; left: 50px; bottom: 22px; }
  .fd-prod__cta { display: flex; gap: 8px; flex-wrap: wrap; }
  .fd-prod__cta .fd-btn { flex: 1 1 auto; padding: 10px 14px; font-size: 12px; }
  .fd-fan__row { flex-wrap: wrap; gap: 16px; justify-content: center; }
  .fd-fan__pkg { margin-left: 0; }
  .fd-flavor__title { font-size: 44px; }
  .fd-flavor__sub { font-size: 18px; }
  .fd-flavor__art { height: 320px; }
  .fd-flavor__box { width: 130px; height: 160px; left: calc(50% - 150px); }
  .fd-flavor__cap { width: 80px; height: 100px; left: calc(50% - 40px); }
}

/* ═══════════════════════════════════════════════════════════════════════
   FIXES — клиентские правки
   ═══════════════════════════════════════════════════════════════════════ */

/* ---------- 1. Прячем плавающую LINE на всякий случай ---------- */
.fd-line-chat,
[class*="fd-line-chat"]{
  display: none !important;
}

/* ---------- 2 + 6. Перебиваем розовый ховер от Hello/Elementor на ВСЕХ кнопках ---------- */
.elementor-button,
.elementor-button-link,
button.elementor-button,
a.elementor-button{
  background-color: var(--fd-purple-deep) !important;
  color: white !important;
  border: none !important;
}
.elementor-button:hover,
.elementor-button:focus,
.elementor-button-link:hover,
button.elementor-button:hover,
a.elementor-button:hover{
  background-color: var(--fd-ink) !important;
  color: white !important;
  border: none !important;
}

/* Кнопка МЕНЮ — фиксируем фон в любом состоянии (Hello даёт розовый при hover/focus/aria-expanded) */
.fd-press-menu,
.fd-press-menu:hover,
.fd-press-menu:focus,
.fd-press-menu:active,
.fd-press-menu[aria-expanded="true"]{
  background: rgba(255,255,255,.7) !important;
  color: var(--fd-ink) !important;
  border: 1px solid var(--fd-purple) !important;
  box-shadow: none !important;
}
.fd-press-menu:hover{
  background: white !important;
  transform: translateY(-1px);
}
.fd-press-menu__label{ color: var(--fd-ink) !important; }
.fd-press-menu__cursor{
  background: var(--fd-purple-soft) !important;
  color: var(--fd-purple-deep) !important;
}

/* ── fd-btn в любом контексте (в т.ч. submit-кнопки в формах) ──
   Hello/Elementor подкрашивает все <button> розовым — жёстко переопределяем
   для основных вариантов .fd-btn--primary / --ghost / --dark в любом теге */
.fd-btn,
button.fd-btn,
input[type="submit"].fd-btn,
a.fd-btn{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  font-family: var(--fd-display) !important;
  font-weight: 800 !important;
  font-size: 13px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  padding: 14px 26px !important;
  border-radius: 14px !important;
  border: 1.5px solid transparent !important;
  cursor: pointer !important;
  text-decoration: none !important;
  line-height: 1.2 !important;
  transition: background .2s, color .2s, border-color .2s, transform .2s !important;
}

.fd-btn--primary,
button.fd-btn--primary,
input[type="submit"].fd-btn--primary,
a.fd-btn--primary,
.fd-btn--primary:visited{
  background: var(--fd-ink) !important;
  color: white !important;
  border-color: var(--fd-ink) !important;
}
.fd-btn--primary:hover,
button.fd-btn--primary:hover,
input[type="submit"].fd-btn--primary:hover,
a.fd-btn--primary:hover,
.fd-btn--primary:focus,
.fd-btn--primary:active{
  background: var(--fd-purple-deep) !important;
  color: white !important;
  border-color: var(--fd-purple-deep) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 14px 28px -10px rgba(115,84,162,.45) !important;
  outline: none !important;
}

.fd-btn--ghost,
button.fd-btn--ghost,
input[type="submit"].fd-btn--ghost,
a.fd-btn--ghost,
.fd-btn--ghost:visited{
  background: white !important;
  color: var(--fd-ink) !important;
  border-color: var(--fd-ink) !important;
}
.fd-btn--ghost:hover,
button.fd-btn--ghost:hover,
input[type="submit"].fd-btn--ghost:hover,
a.fd-btn--ghost:hover,
.fd-btn--ghost:focus,
.fd-btn--ghost:active{
  background: var(--fd-ink) !important;
  color: white !important;
  border-color: var(--fd-ink) !important;
  outline: none !important;
}

.fd-btn--dark,
button.fd-btn--dark,
a.fd-btn--dark{
  background: var(--fd-ink) !important;
  color: white !important;
  border-color: var(--fd-ink) !important;
}
.fd-btn--dark:hover{
  background: var(--fd-purple-deep) !important;
  border-color: var(--fd-purple-deep) !important;
  color: white !important;
}

/* Кнопки внутри .fd-contact-form — дополнительная страховка
   Elementor накладывает свои стили именно на submit в формах */
.fd-contact-form button[type="submit"],
.fd-contact-form input[type="submit"],
.fd-contact-form .fd-btn{
  background: var(--fd-ink) !important;
  color: white !important;
  border: 1.5px solid var(--fd-ink) !important;
}
.fd-contact-form button[type="submit"]:hover,
.fd-contact-form input[type="submit"]:hover,
.fd-contact-form .fd-btn:hover{
  background: var(--fd-purple-deep) !important;
  border-color: var(--fd-purple-deep) !important;
  color: white !important;
  transform: translateY(-2px) !important;
}

/* fd-pill (корзина, RU lang) и fd-btn--ghost (Войти) — стабильные ховеры */
.fd-pill,
.fd-pill:hover,
.fd-pill:focus{
  background: white !important;
  color: var(--fd-ink) !important;
  border: 1px solid var(--fd-purple) !important;
}
.fd-pill:hover{ transform: translateY(-1px); box-shadow: var(--fd-shadow-soft) !important; }

.fd-btn--ghost,
.fd-btn--ghost:hover,
.fd-btn--ghost:focus{
  background: white !important;
  color: var(--fd-ink) !important;
  border: 1px solid var(--fd-ink) !important;
}
.fd-btn--ghost:hover{
  background: var(--fd-ink) !important;
  color: white !important;
}

/* Кнопки в карточках товаров — В КОРЗИНУ / КУПИТЬ */
.fd-prod__cta .fd-btn,
.fd-prod__cta button,
.fd-prod__cta a{
  transition: background .2s, color .2s, transform .15s !important;
}
.fd-prod__cta .fd-btn:hover,
.fd-prod__cta button:hover{
  background-color: var(--fd-ink) !important;
  color: white !important;
  border-color: var(--fd-ink) !important;
}

/* Стрелки навигации (.fd-arrow и .fd-arrow--life) — после клика становились розовыми
   из-за :focus/:active от Hello/Elementor. Жёстко фиксируем все состояния */
.fd-arrow,
.fd-arrow:visited,
.fd-arrow:focus,
.fd-arrow:focus-visible,
.fd-arrow:active{
  background: white !important;
  color: var(--fd-purple-deep) !important;
  border: 2px solid var(--fd-purple-deep) !important;
  outline: none !important;
  box-shadow: 0 10px 24px -4px rgba(115,84,162,.35) !important;
}
.fd-arrow:hover{
  background: var(--fd-purple-deep) !important;
  color: white !important;
  border-color: var(--fd-purple-deep) !important;
  box-shadow: 0 14px 30px -6px rgba(115,84,162,.5) !important;
}
.fd-arrow--life,
.fd-arrow--life:visited,
.fd-arrow--life:focus,
.fd-arrow--life:focus-visible,
.fd-arrow--life:active{
  background: white !important;
  color: var(--fd-purple-deep) !important;
  border: 1.5px solid var(--fd-purple-deep) !important;
  outline: none !important;
}
.fd-arrow--life:hover{
  background: var(--fd-purple-deep) !important;
  color: white !important;
}

/* ---------- 3. Меню в шапке — убираем буллеты, ровные ссылки ---------- */
.fd-menu ul,
.fd-menu ol,
.fd-menu li{
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block;
}
.fd-menu{ gap: 2px; }
.fd-menu a{
  display: block;
  text-decoration: none;
  width: 100%;
}
.fd-menu li + li a{ margin-top: 2px; }

/* ---------- 4. Подвал — убираем буллеты, ровная сетка под несколько колонок ---------- */
/* Даём правой части больше места + расширяем максимум, чтобы 3 блока в ряд влезли */
.fd-footer__inner{
  grid-template-columns: 1fr 2.4fr !important;
  max-width: 1400px !important;
  gap: 50px !important;
}
.fd-footer__cols{
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  grid-template-rows: auto !important;
  gap: 30px 40px !important;
  align-items: start;
}
/* Если блоков 2 (нет меню или нет соц сетей) — две колонки */
.fd-footer__cols:has(> .fd-footer__col:nth-child(2):last-child){
  grid-template-columns: repeat(2, 1fr) !important;
}
.fd-footer__nav,
.fd-footer__nav-list,
.fd-footer__nav ul,
.fd-footer__nav li{
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
.fd-footer__nav-list li{ margin-bottom: 8px !important; }
.fd-footer__nav-list a{
  color: var(--fd-ink-soft);
  font-weight: 600;
  font-size: 15px;
  text-decoration: none;
  transition: color .2s;
}
.fd-footer__nav-list a:hover{ color: var(--fd-purple-deep); }

/* На планшете и ниже — бренд в подвале занимает всю ширину, cols одной строкой */
@media (max-width: 1024px){
  .fd-footer__inner{ grid-template-columns: 1fr !important; }
  .fd-footer__brand{ text-align: center; align-items: center; }
  .fd-footer__cols{ grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)) !important; }
}

/* ---------- 5. Планшетная вёрстка — товары и секции по центру ---------- */
@media (max-width: 1024px) and (min-width: 769px){
  /* карточка товара — центрируем, не растягиваем на всю ширину */
  .fd-products__grid{
    grid-template-columns: 1fr !important;
    max-width: 640px !important;
    margin: 0 auto !important;
    padding: 0 28px !important;
    gap: 80px !important;
  }
  .fd-prod{
    max-width: 540px;
    margin: 0 auto;
    width: 100%;
    text-align: center;
  }
  .fd-prod__art{
    max-width: 420px;
    margin: 0 auto 20px;
  }
  .fd-prod__info{ text-align: center; align-items: center; }
  .fd-prod__price-row{ justify-content: center; }
  .fd-prod__cta{ justify-content: center; }

  /* Hero/intro/секции — ограничиваем ширину контента */
  .fd-intro__inner,
  .fd-tagline,
  .fd-fan__row,
  .fd-flavor__inner{ max-width: 760px; margin-left: auto; margin-right: auto; }

  /* Подвал на планшете — бренд + 2 колонки в строку под ним */
  .fd-footer__inner{
    grid-template-columns: 1fr !important;
    text-align: center;
  }
  .fd-footer__brand{ align-items: center; text-align: center; }
  .fd-footer__cols{
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
    justify-items: center;
  }
  .fd-footer__col{ text-align: left; }
}

/* На узких планшетах и мобиле — карточка товара тоже по центру */
@media (max-width: 768px){
  .fd-prod{ max-width: 480px; margin: 0 auto; width: 100%; text-align: center; }
  .fd-prod__art{ max-width: 380px; margin: 0 auto; }
  .fd-prod__info{ text-align: center; align-items: center; }
  .fd-prod__price-row{ justify-content: center; }
  .fd-prod__cta{ justify-content: center; }
}

/* ---------- 7. HERO на мобилке — текст налазил на упаковку ---------- */
@media (max-width: 900px){
  /* Контейнер упаковки повыше + достаточный gap под info */
  .fd-hero__stage{
    gap: 50px !important;
    padding: 80px 0 40px !important;
  }
  .fd-hero__center{
    width: clamp(220px, 64vw, 360px) !important;
    aspect-ratio: 1/1.5 !important;
    height: auto !important;
    margin-bottom: 20px;
  }
  .fd-pkg--active{
    max-width: clamp(160px, 50vw, 240px) !important;
  }
  /* Крышка чуть выше, чтобы не давила на упаковку */
  .fd-cap{
    width: clamp(120px, 36vw, 200px) !important;
  }
  /* Info — больше отступ сверху, чтобы не наезжать на упаковку */
  .fd-hero__info{
    position: static !important;
    margin-top: 40px !important;
    padding: 0 20px;
  }
  .fd-hero__info-flavor{
    margin-bottom: 14px;
    font-size: 12px;
  }
  /* PRESS · SHAKE буквы не должны налазить на текст */
  .fd-hero__split{
    top: 28% !important;
  }
}
@media (max-width: 480px){
  .fd-hero__stage{ gap: 36px !important; padding: 70px 0 30px !important; }
  .fd-hero__center{ width: 70vw !important; aspect-ratio: 1/1.55 !important; }
  .fd-hero__info{ margin-top: 30px !important; }
  .fd-hero__info-title{ font-size: 22px !important; }
}

/* ───────────────────────────────────────────────────────────────────────
   МОБИЛКА: сетка 2×2 для плавающих упаковок (intro / mid-fan / final-fan).
   Анимация floating сохраняется — упаковки покачиваются прямо в ячейках грида.
   ─────────────────────────────────────────────────────────────────────── */
@media (max-width: 768px){

  /* ── INTRO 4 пачки → 2×2 ── */
  .fd-intro__row{
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    grid-template-rows: auto auto;
    gap: 18px !important;
    justify-items: center;
    align-items: center;
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
  }
  .fd-intro__pkg{
    width: 100% !important;
    max-width: 220px !important;
  }
  /* Photo-режим (когда реальный баннер) — тоже подчиняется сетке */
  .fd-intro__pkg--photo{
    width: 100% !important;
    max-width: 200px !important;
    aspect-ratio: 1/1 !important;
  }

  /* ── MID FAN (4 в ряд с наездом) → 2×2 без наезда ── */
  .fd-fan__row{
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    grid-template-rows: auto auto;
    gap: 20px !important;
    justify-items: center;
    align-items: center;
    max-width: 460px;
    margin-left: auto;
    margin-right: auto;
  }
  .fd-fan__pkg{
    width: 100% !important;
    max-width: 200px !important;
    margin-left: 0 !important;   /* убираем наезд */
  }
  .fd-fan__pkg--photo{
    width: 100% !important;
    max-width: 200px !important;
    aspect-ratio: 1/1 !important;
  }

  /* ── FINAL FAN (был absolute) → тоже 2×2 ── */
  .fd-fan--final{
    padding: 60px 24px 80px;
    min-height: auto;
    overflow: visible;
  }
  .fd-fan--final .fd-fan__row{
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    grid-template-rows: auto auto;
    gap: 24px !important;
    height: auto !important;
    width: 100% !important;
    max-width: 460px;
    margin-left: auto !important;
    margin-right: auto !important;
    justify-items: center;
    align-items: center;
    position: static !important;
  }
  .fd-fan--final .fd-fan__pkg{
    position: relative !important;
    left: auto !important;
    top: auto !important;
    width: 100% !important;
    max-width: 200px !important;
    margin: 0 !important;
  }
  /* Отключаем индивидуальное абсолютное позиционирование для каждого nth-child */
  .fd-fan--final .fd-fan__pkg:nth-child(1),
  .fd-fan--final .fd-fan__pkg:nth-child(2),
  .fd-fan--final .fd-fan__pkg:nth-child(3),
  .fd-fan--final .fd-fan__pkg:nth-child(4){
    left: auto !important;
    top: auto !important;
    position: relative !important;
  }
}

@media (max-width: 420px){
  /* На совсем узких — компактнее, без max-width ограничений */
  .fd-intro__row,
  .fd-fan__row,
  .fd-fan--final .fd-fan__row{
    gap: 14px !important;
  }
  .fd-intro__pkg,
  .fd-intro__pkg--photo,
  .fd-fan__pkg,
  .fd-fan__pkg--photo,
  .fd-fan--final .fd-fan__pkg{
    max-width: 170px !important;
  }
}

/* ═══════════════════════════════════════════════════════════════════════
   CUSTOM LOGO — размер в шапке и подвале
   Когда клиент загрузил лого через Customizer → показываем <img> с фикс.
   max-height (чтобы лого не растягивало шапку).
   ═══════════════════════════════════════════════════════════════════════ */

/* Шапка — лого высотой до 50px на десктопе */
.fd-logo--img{
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  height: 50px;
}
.fd-logo__img{
  display: block;
  height: 100%;
  width: auto;
  max-width: 200px;
  max-height: 50px;
  object-fit: contain;
}
@media (max-width: 768px){
  .fd-logo--img{ height: 40px; }
  .fd-logo__img{ max-height: 40px; max-width: 160px; }
}

/* Подвал — лого крупнее, но всё ещё ограничено */
.fd-footer__brand--img{
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.fd-footer__logo-link{
  display: inline-block;
  max-width: 280px;
}
.fd-footer__logo-img{
  display: block;
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 90px;
  object-fit: contain;
}
@media (max-width: 768px){
  .fd-footer__brand--img{ align-items: center; }
  .fd-footer__logo-img{ max-height: 70px; max-width: 220px; }
}

/* ═══════════════════════════════════════════════════════════════════════
   PAGES — Общие стили доп страниц (404, contacts, about)
   ═══════════════════════════════════════════════════════════════════════ */

.fd-tag{
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 12px;
  letter-spacing: 3px;
  color: var(--fd-purple-deep);
  text-transform: uppercase;
  margin-bottom: 16px;
}
.fd-tag::before{
  content: ''; width: 26px; height: 2px;
  background: var(--fd-purple-deep);
  border-radius: 2px;
}
.fd-section-title{
  font-family: var(--fd-display);
  font-weight: 900;
  font-size: clamp(32px, 4.5vw, 56px);
  line-height: 1.05;
  margin: 0 0 18px;
  color: var(--fd-ink);
  letter-spacing: -1.5px;
}
.fd-section-title em{
  font-family: var(--fd-italic, 'Cormorant Garamond', serif);
  font-style: italic;
  font-weight: 600;
  color: var(--fd-purple-deep);
}
.fd-section-subtitle{
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: clamp(20px, 2.4vw, 28px);
  color: var(--fd-ink);
  margin: 0 0 18px;
}

/* ── Intro блок (используется на всех доп страницах) ── */
.fd-page-intro{
  position: relative;
  padding: 160px 40px 100px;
  overflow: hidden;
  background:
    radial-gradient(60% 80% at 20% 30%, rgba(193,167,226,.25), transparent 70%),
    radial-gradient(50% 70% at 80% 60%, rgba(242,183,201,.22), transparent 75%),
    linear-gradient(180deg, var(--fd-bg-soft, #faf7ff) 0%, white 100%);
}
.fd-page-intro__inner{
  position: relative; z-index: 5;
  max-width: 1080px; margin: 0 auto;
  text-align: center;
}
.fd-page-intro__tag{
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 13px;
  letter-spacing: 4px;
  color: var(--fd-purple-deep);
  margin-bottom: 24px;
  text-transform: uppercase;
}
.fd-page-intro__title{
  font-family: var(--fd-display);
  font-weight: 900;
  font-size: clamp(44px, 7vw, 96px);
  line-height: 1;
  margin: 0 0 28px;
  color: var(--fd-ink);
  letter-spacing: -2.5px;
}
.fd-page-intro__title em{
  font-family: var(--fd-italic, 'Cormorant Garamond', serif);
  font-style: italic;
  font-weight: 600;
  color: var(--fd-purple-deep);
}
.fd-page-intro__lead{
  font-size: clamp(15px, 1.4vw, 18px);
  line-height: 1.65;
  color: var(--fd-ink-soft);
  max-width: 640px;
  margin: 0 auto;
}

/* Декоративные фото-баннеры по углам интро-секции на доп страницах */
.fd-page-intro{ overflow: hidden; }
.fd-page-intro__decor{
  position: absolute;
  z-index: 2;
  width: clamp(280px, 32vw, 520px);
  height: auto;
  pointer-events: none;
  filter: drop-shadow(0 30px 60px rgba(115,84,162,.3));
  opacity: .95;
  animation: fd-active-float 9s ease-in-out infinite;
}
.fd-page-intro__decor--right{
  right: -80px; top: 12%;
  transform: rotate(8deg);
  animation-delay: -3s;
}
.fd-page-intro__decor--left{
  left: -80px; bottom: -40px;
  transform: rotate(-12deg);
  animation-delay: -6s;
}
@media (max-width: 1100px){
  .fd-page-intro__decor{
    width: clamp(220px, 36vw, 320px);
    opacity: .55;
  }
  .fd-page-intro__decor--right{ right: -100px; top: 4%; }
  .fd-page-intro__decor--left{ display: none; }
}
@media (max-width: 720px){
  .fd-page-intro__decor{ display: none; }
}

/* Hero/intro/fan на главной — режим с реальным фото вместо CSS-арта.
   Фото — главный акцент, поэтому увеличиваем контейнер ~1.6× */
.fd-intro__pkg--photo{
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  overflow: visible;
  width: clamp(220px, 22vw, 360px) !important;
  aspect-ratio: 1/1 !important;
  padding: 0 !important;
}
.fd-intro__pkg--photo::before,
.fd-intro__pkg--photo::after{ display: none !important; }
.fd-intro__pkg--photo .fd-intro__pkg-label{ display: none; }
.fd-intro__pkg-img{
  width: 100%; height: 100%;
  max-width: 100%;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 30px 60px rgba(31,31,31,.22));
}

.fd-fan__pkg--photo{
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  overflow: visible;
  width: clamp(240px, 22vw, 380px) !important;
  aspect-ratio: 1/1 !important;
}
.fd-fan--final .fd-fan__pkg--photo{
  width: clamp(220px, 20vw, 340px) !important;
  aspect-ratio: 1/1 !important;
}
.fd-fan__pkg--photo::before,
.fd-fan__pkg--photo::after{ display: none !important; }
.fd-fan__pkg-img{
  width: 100%; height: 100%;
  max-width: 100%;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 32px 60px rgba(31,31,31,.25));
}

/* Hero — реальные товары вместо CSS-арта упаковки.
   .fd-pkg--link делает упаковку кликабельной (a-тег), .fd-pkg__img рендерит фото. */
.fd-pkg--link{
  display: block;
  text-decoration: none;
  cursor: pointer;
  transition: transform .35s cubic-bezier(.34,1.56,.64,1);
  position: relative;
}
.fd-pkg--active.fd-pkg--link:hover{ transform: translateY(-8px) scale(1.04); }
.fd-pkg__img{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: drop-shadow(0 32px 60px rgba(31,31,31,.32));
  z-index: 5;
  pointer-events: none;
}
/* Когда есть photo — убираем CSS-фон и доп. псевдо-элементы упаковки */
.fd-pkg--link:has(.fd-pkg__img:not([hidden])){
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}
.fd-pkg--link:has(.fd-pkg__img:not([hidden]))::before,
.fd-pkg--link:has(.fd-pkg__img:not([hidden]))::after{
  display: none !important;
}
/* Центральная упаковка крупнее в hero — фото это акцент.
   ВАЖНО: max-width:none перебивает старое .fd-pkg--active { max-width: 240px }
   (max-width capает наш width даже с !important). */
.fd-hero__active .fd-pkg--active.fd-pkg--link{
  width: clamp(360px, 42vw, 580px) !important;
  height: clamp(360px, 42vw, 580px) !important;
  max-width: none !important;
  max-height: none !important;
  aspect-ratio: 1/1 !important;
  flex-shrink: 0 !important;
}
.fd-hero__active{
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

/* Когда в hero реальное фото (.fd-pkg__img не скрыт) — отменяем старое
   позиционирование .fd-hero__active (top:48%, width:78%, pointer-events:none),
   которое было оптимизировано под узкую CSS-арт упаковку, и центрируем
   квадратное фото по вертикали родителя. */
.fd-hero__active:has(.fd-pkg__img:not([hidden])){
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  width: 100% !important;
  max-width: 580px !important;
  pointer-events: auto !important;
}
.fd-hero__center{
  width: clamp(360px, 42vw, 580px) !important;
  height: clamp(360px, 42vw, 580px) !important;
  max-width: none !important;
  max-height: none !important;
}
/* Боковые упаковки чуть меньше, кликабельны */
.fd-hero__side .fd-pkg--link{
  cursor: pointer;
  width: clamp(140px, 16vw, 220px) !important;
  height: clamp(140px, 16vw, 220px) !important;
  max-width: none !important;
  max-height: none !important;
  aspect-ratio: 1/1 !important;
}
.fd-hero__side .fd-pkg--link:hover{ transform: scale(1.08); }

/* Скрываем декоративную крышку .fd-cap когда центральная упаковка показывает реальное фото */
.fd-hero__center:has(.fd-pkg__img:not([hidden])) .fd-cap{ display: none; }

/* Flavor showcase в фото-режиме — простой вертикальный layout
   (заголовок сверху, фото в центре, кнопка снизу — без CSS-арта и круглых бейджей) */
.fd-flavor__slide--photo{
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  padding: 50px 30px !important;
  gap: 30px;
}
.fd-flavor__slide--photo .fd-flavor__head{
  position: static !important;
  max-width: 100% !important;
  width: 100% !important;
  text-align: center !important;
  margin: 0 !important;
}
.fd-flavor__slide--photo .fd-flavor__kicker{
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--fd-purple-deep);
  margin-bottom: 14px;
}
.fd-flavor__slide--photo .fd-flavor__title{
  font-family: var(--fd-italic, 'Cormorant Garamond', serif);
  font-style: italic;
  font-weight: 600;
  font-size: clamp(40px, 5.5vw, 72px) !important;
  line-height: 1 !important;
  color: var(--fd-ink) !important;
  margin: 0 0 14px !important;
}
.fd-flavor__slide--photo .fd-flavor__sub{
  font-family: var(--fd-display);
  font-weight: 600;
  font-size: clamp(15px, 1.5vw, 18px) !important;
  color: var(--fd-ink-soft) !important;
  margin: 0 !important;
  max-width: 520px;
  margin-left: auto !important;
  margin-right: auto !important;
}

.fd-flavor__photo-link{
  display: block;
  width: clamp(260px, 36vw, 460px);
  height: auto;
  text-decoration: none;
  transition: transform .35s ease;
}
.fd-flavor__photo-link:hover{ transform: translateY(-8px) scale(1.03); }
.fd-flavor__photo{
  display: block;
  width: 100%;
  height: auto;
  max-height: 50vh;
  object-fit: contain;
  filter: drop-shadow(0 30px 60px rgba(31,31,31,.22));
}

.fd-flavor__cta{
  display: inline-flex !important;
  align-self: center !important;
  margin: 0 !important;
}

/* Универсально: скрываем все старые CSS-арт элементы внутри photo-режима */
.fd-flavor__slide--photo .fd-flavor__art,
.fd-flavor__slide--photo .fd-flavor__bullets,
.fd-flavor__slide--photo .fd-flavor__badge,
.fd-flavor__slide--photo .fd-flavor__fine{
  display: none !important;
}

/* Lifestyle-карточка как ссылка — фото в верхней части, текст в нижней (НЕ overlay) */
a.fd-life__card{
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  display: flex !important;
  flex-direction: column !important;
  justify-content: stretch !important;
  padding: 0 !important;
  overflow: hidden;
  transition: transform .35s ease, box-shadow .35s ease;
}
a.fd-life__card:hover{
  transform: translateY(-8px);
  box-shadow: 0 32px 60px -20px rgba(31,31,31,.35);
}

/* Фото — в верхней зоне, не absolute */
.fd-life__card .fd-life__photo,
a.fd-life__card .fd-life__photo{
  position: relative !important;
  inset: auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 1 1 auto;
  min-height: 280px;
  padding: 24px;
  overflow: hidden;
  font-size: 200px;
  color: rgba(255,255,255,.25);
}
.fd-life__photo-img{
  max-width: 80%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 24px 48px rgba(31,31,31,.3));
  transition: transform .35s ease;
}
a.fd-life__card:hover .fd-life__photo-img{ transform: scale(1.06); }
.fd-life__photo:has(.fd-life__photo-img) > i{ display: none; }

/* Текстовый блок — отдельная нижняя плашка с тёмной полупрозрачной подложкой.
   Снизу больше воздуха чтобы кнопка не прилипала ко дну карточки. */
.fd-life__card .fd-life__copy,
a.fd-life__card .fd-life__copy{
  position: relative !important;
  z-index: 2;
  flex: 0 0 auto;
  padding: 24px 28px 40px !important;
  background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,.18) 30%, rgba(0,0,0,.45) 100%);
  text-align: center;
}
.fd-life__copy h3{
  margin: 0 0 14px !important;
  text-align: center !important;
}
.fd-life__copy h3 .fd-life__kick{
  display: block;
  font-family: var(--fd-display);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  opacity: .9;
  margin-bottom: 6px;
}
.fd-life__copy h3 .fd-life__name{
  display: block;
  font-family: var(--fd-italic, 'Cormorant Garamond', serif);
  font-style: italic;
  font-weight: 600;
  font-size: clamp(22px, 2.4vw, 30px);
  line-height: 1.1;
}
/* Кнопка тоже центруем */
.fd-life__copy .fd-btn{
  display: inline-flex !important;
  margin: 0 auto !important;
}

/* Реальное фото товара в .fd-prod (на главной в блоке «Наша продукция»).
   Контейнер __art переключается в flex-center когда фото есть — это надёжнее
   absolute+inset (не зависит от padding/высоты). */
.fd-prod__art:has(.fd-prod__photo){
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 16px;
  overflow: hidden;
}
.fd-prod__photo{
  position: relative !important;
  inset: auto !important;
  display: block !important;
  width: auto !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  z-index: 5;
  filter: drop-shadow(0 26px 50px rgba(31,31,31,.25));
  transition: transform .4s ease;
}
.fd-prod:hover .fd-prod__photo{ transform: translateY(-6px) scale(1.04); }
/* Скрываем CSS-арт когда есть фото (двойная страховка через :has() + display:none) */
.fd-prod__art:has(.fd-prod__photo) .fd-prod__box,
.fd-prod__art:has(.fd-prod__photo) .fd-prod__cap,
.fd-prod__art:has(.fd-prod__photo) .fd-prod__fruit,
.fd-prod__art:has(.fd-prod__photo) .fd-prod__podium,
.fd-prod__art:has(.fd-prod__photo) .fd-prod__arc{
  display: none !important;
}

/* ═══════════════════════════════════════════════════════════════════════
   404
   ═══════════════════════════════════════════════════════════════════════ */
.fd-404{
  position: relative;
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  padding: 140px 40px 80px;
  overflow: hidden;
  background:
    radial-gradient(60% 80% at 30% 40%, rgba(193,167,226,.3), transparent 70%),
    radial-gradient(50% 70% at 70% 70%, rgba(242,183,201,.25), transparent 75%),
    linear-gradient(180deg, var(--fd-bg-soft, #faf7ff) 0%, white 100%);
}
.fd-404__inner{
  position: relative; z-index: 5;
  text-align: center;
  max-width: 720px;
}
.fd-404__num{
  display: flex; align-items: center; justify-content: center; gap: 20px;
  margin-bottom: 40px;
  filter: drop-shadow(0 20px 40px rgba(115,84,162,.25));
}
.fd-404__digit{
  font-family: var(--fd-display);
  font-weight: 900;
  font-size: clamp(120px, 22vw, 280px);
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 4px var(--fd-purple-deep);
  letter-spacing: -8px;
}
.fd-404__digit--c{
  position: relative;
  width: clamp(100px, 18vw, 220px);
  height: clamp(140px, 24vw, 300px);
  display: inline-flex; align-items: center; justify-content: center;
}
.fd-404__pkg{
  position: relative;
  width: 80%; height: 80%;
  background: linear-gradient(160deg, #f0e3fa 0%, #c1a7e2 100%);
  border-radius: 16px;
  box-shadow: 0 26px 50px -10px rgba(115,84,162,.4);
  animation: fd-active-float 7s ease-in-out infinite;
  display: block;
}
.fd-404__pkg::before{
  content: 'OPEN';
  position: absolute; top: 10px; left: 50%;
  transform: translateX(-50%);
  background: rgba(255,255,255,.95);
  padding: 4px 14px;
  border-radius: 9999px;
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--fd-purple-deep);
}
.fd-404__pkg-cap{
  position: absolute;
  top: -16%; left: 50%;
  transform: translateX(-50%);
  width: 65%; aspect-ratio: 1/1;
  background: radial-gradient(circle at 30% 30%, #fff, var(--fd-purple) 80%);
  border-radius: 50% 50% 30% 30%;
  animation: fd-cap-float 6s ease-in-out infinite;
}
.fd-404__pkg-img{
  max-width: 80%; max-height: 90%;
  object-fit: contain;
  filter: drop-shadow(0 26px 50px rgba(115,84,162,.4));
  animation: fd-active-float 7s ease-in-out infinite;
  display: block;
  margin: 0 auto;
}

/* Универсальный плейсхолдер для fo_render_media() когда фото ещё не загружено */
.fd-img-placeholder{
  background: linear-gradient(160deg, var(--fd-purple-soft) 0%, white 100%);
  border: 1.5px dashed var(--fd-purple);
  border-radius: 12px;
  min-height: 200px;
  display: grid; place-items: center;
  position: relative;
}
.fd-img-placeholder::after{
  content: attr(data-slug);
  font-family: var(--fd-display);
  font-size: 11px;
  letter-spacing: 1.5px;
  color: var(--fd-ink-soft);
  text-transform: uppercase;
  text-align: center;
  padding: 0 12px;
}
.fd-404__title{
  font-family: var(--fd-display);
  font-weight: 900;
  font-size: clamp(24px, 3.6vw, 42px);
  letter-spacing: 4px;
  margin: 0 0 16px;
  color: var(--fd-ink);
  text-transform: uppercase;
}
.fd-404__lead{
  font-size: clamp(15px, 1.4vw, 17px);
  line-height: 1.65;
  color: var(--fd-ink-soft);
  margin: 0 0 36px;
}
.fd-404__actions{
  display: flex; gap: 14px; justify-content: center; flex-wrap: wrap;
  margin-bottom: 36px;
}
.fd-404__search{ max-width: 480px; margin: 0 auto; }
@media (max-width: 640px){
  .fd-404__num{ gap: 8px; }
  .fd-404__actions .fd-btn{ width: 100%; justify-content: center; }
}

/* ═══════════════════════════════════════════════════════════════════════
   CONTACTS
   ═══════════════════════════════════════════════════════════════════════ */
.fd-contacts-grid{
  padding: 0 40px 80px;
  background: white;
}
.fd-contacts-grid__inner{
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: -60px;
  position: relative; z-index: 10;
}
.fd-contact-card{
  background: white;
  border-radius: 22px;
  padding: 32px 28px;
  text-align: center;
  box-shadow: 0 20px 40px -16px rgba(115,84,162,.15);
  transition: transform .25s, box-shadow .25s;
}
.fd-contact-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 30px 50px -16px rgba(115,84,162,.25);
}
.fd-contact-card__icon{
  width: 64px; height: 64px;
  border-radius: 9999px;
  background: var(--fd-purple-soft);
  color: var(--fd-purple-deep);
  display: grid; place-items: center;
  font-size: 22px;
  margin: 0 auto 18px;
}
.fd-contact-card--mail .fd-contact-card__icon{ background: #d4f0e2; color: var(--fd-green-deep, #2e7d50); }
.fd-contact-card--addr .fd-contact-card__icon{ background: #fce0e8; color: #c63864; }
.fd-contact-card__label{
  font-family: var(--fd-display);
  font-weight: 800; font-size: 12px;
  letter-spacing: 3px;
  color: var(--fd-ink-soft);
  margin-bottom: 8px;
  text-transform: uppercase;
}
.fd-contact-card__value{
  display: block;
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 20px;
  color: var(--fd-ink);
  line-height: 1.4;
  margin-bottom: 8px;
  text-decoration: none;
  transition: color .2s;
}
.fd-contact-card__value:hover{ color: var(--fd-purple-deep); }
.fd-contact-card__value--small{ font-size: 14px; font-weight: 600; line-height: 1.55; }
.fd-contact-card__hint{
  font-size: 13px;
  color: var(--fd-ink-soft);
}
@media (max-width: 900px){
  .fd-contacts-grid__inner{ grid-template-columns: 1fr; margin-top: -40px; }
}

/* Contact form + map section */
.fd-contact-form-sec{
  padding: 100px 40px;
  background: linear-gradient(180deg, white 0%, var(--fd-bg-soft, #faf7ff) 100%);
}
.fd-contact-form-sec__inner{
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr; gap: 60px;
  align-items: start;
}
.fd-contact-form{
  background: white;
  border-radius: 22px;
  padding: 36px;
  box-shadow: 0 20px 40px -16px rgba(115,84,162,.12);
}
.fd-cf-row{ display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.fd-cf-field{
  display: block; margin-bottom: 18px;
}
.fd-cf-label{
  display: block;
  font-family: var(--fd-display);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 2px;
  color: var(--fd-ink-soft);
  margin-bottom: 8px;
  text-transform: uppercase;
}
.fd-cf-opt{ font-weight: 500; opacity: .6; letter-spacing: 0; text-transform: none; }
.fd-cf-field input,
.fd-cf-field textarea{
  width: 100%;
  padding: 14px 16px;
  border: 1.5px solid var(--fd-purple-soft);
  border-radius: 12px;
  background: var(--fd-bg-soft, #fbfafd);
  font: inherit; font-size: 15px;
  color: var(--fd-ink);
  transition: border-color .2s, background .2s;
}
.fd-cf-field input:focus,
.fd-cf-field textarea:focus{
  outline: none;
  border-color: var(--fd-purple-deep);
  background: white;
}
.fd-cf-field textarea{ resize: vertical; min-height: 110px; }
.fd-cf-policy{
  font-size: 12px;
  color: var(--fd-ink-soft);
  margin: 18px 0 0;
}
.fd-map{
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 20px 40px -16px rgba(115,84,162,.18);
  margin: 18px 0 22px;
}
.fd-map iframe{ display: block; width: 100%; }
.fd-map--placeholder{
  background: linear-gradient(135deg, var(--fd-purple-soft) 0%, white 100%);
  display: grid;
  place-items: center;
  min-height: 420px;
  border: 2px dashed var(--fd-purple);
}
.fd-map__placeholder{
  text-align: center;
  padding: 40px 30px;
  max-width: 360px;
}
.fd-map__placeholder i{
  font-size: 48px;
  color: var(--fd-purple-deep);
  margin-bottom: 18px;
  display: block;
}
.fd-map__placeholder-title{
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 18px;
  color: var(--fd-ink);
  margin-bottom: 8px;
}
.fd-map__placeholder-text{
  font-size: 13.5px;
  color: var(--fd-ink-soft);
  line-height: 1.55;
}
.fd-map__placeholder-text code{
  background: rgba(115,84,162,.12);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 12px;
}

/* ═══════════════════════════════════════════════════════════════════════
   PAGE WRAP — общая обёртка для шаблонов Cart/Checkout/Account/прочих
   (рендерится из page-cart.php / page-checkout.php / page-account.php)
   ═══════════════════════════════════════════════════════════════════════ */
.fd-page-wrap{
  display: block;
  padding-top: 100px; /* отступ под зафиксированный header */
  min-height: 60vh;
  background: var(--fd-bg-soft, #faf7ff);
}
.fd-page-wrap > .fd-cart,
.fd-page-wrap > .fd-checkout,
.fd-page-wrap > .fd-account,
.fd-page-wrap > .fd-cart-empty{
  padding-top: 40px; /* сам блок уже знает свои отступы — здесь только корректировка */
}
.fd-empty-notice{
  max-width: 720px;
  margin: 80px auto;
  padding: 32px 36px;
  background: white;
  border-radius: 18px;
  border-left: 4px solid var(--fd-purple-deep);
  box-shadow: 0 14px 28px -14px rgba(115,84,162,.15);
  font-size: 15px;
  line-height: 1.65;
  color: var(--fd-ink);
}
.fd-map-meta{
  background: white;
  border-radius: 16px;
  padding: 16px 20px;
  box-shadow: 0 10px 24px -10px rgba(115,84,162,.12);
}
.fd-map-meta__row{
  display: flex; align-items: center; gap: 12px;
  font-weight: 600;
  font-size: 14px;
  color: var(--fd-ink);
  margin-bottom: 8px;
}
.fd-map-meta__row:last-child{ margin-bottom: 0; }
.fd-map-meta__row i{ color: var(--fd-purple-deep); width: 18px; }
@media (max-width: 900px){
  .fd-contact-form-sec__inner{ grid-template-columns: 1fr; gap: 40px; }
  .fd-cf-row{ grid-template-columns: 1fr; }
  .fd-contact-form{ padding: 24px; }
}

/* ═══════════════════════════════════════════════════════════════════════
   ABOUT
   ═══════════════════════════════════════════════════════════════════════ */
.fd-mission{
  padding: 100px 40px;
  background: white;
}
.fd-mission__inner{
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 80px; align-items: center;
}
.fd-mission__text{
  font-size: 16px;
  line-height: 1.7;
  color: var(--fd-ink-soft);
  margin: 0 0 16px;
}
.fd-mission__visual{
  position: relative;
  aspect-ratio: 1/1;
  background: radial-gradient(ellipse at 50% 50%, rgba(193,167,226,.18), transparent 70%);
  border-radius: 40% 60% 50% 50%;
  display: flex; align-items: center; justify-content: center;
  min-height: 360px;
}
.fd-mission__pkg{
  position: absolute;
  width: 28%; aspect-ratio: 4/5;
  border-radius: 16px;
  box-shadow: 0 24px 48px -10px rgba(31,31,31,.25);
  animation: fd-active-float 8s ease-in-out infinite;
}
.fd-mission__pkg--purple{ background: linear-gradient(160deg, #f0e3fa 0%, #c1a7e2 100%); top: 20%; left: 10%; animation-delay: 0s; }
.fd-mission__pkg--green{ background: linear-gradient(160deg, #e2f0dd 0%, #a6d49f 100%); top: 25%; right: 15%; animation-delay: -2s; }
.fd-mission__pkg--pink{ background: linear-gradient(160deg, #fde2eb 0%, #f2b7c9 100%); bottom: 15%; left: 35%; animation-delay: -4s; }

/* Если внутри pkg реальное фото — расширяем коробку, убираем bg-градиент, увеличиваем pkg */
.fd-mission__visual--real .fd-mission__pkg{
  background: transparent !important;
  box-shadow: none;
  width: 42%;
  aspect-ratio: 1/1;
  border-radius: 0;
  overflow: visible;
}
.fd-mission__pkg-img,
.fd-mission__visual--real .fd-img-placeholder{
  width: 100%; height: 100%;
  object-fit: contain;
  filter: drop-shadow(0 20px 40px rgba(31,31,31,.18));
  display: block;
}
.fd-mission__visual--real .fd-img-placeholder{
  background: linear-gradient(160deg, var(--fd-purple-soft) 0%, white 100%);
  border-radius: 16px;
  position: relative;
}
.fd-mission__visual--real .fd-img-placeholder::after{
  content: 'Фото';
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  font-family: var(--fd-display);
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--fd-ink-soft);
  text-transform: uppercase;
}

@media (max-width: 900px){
  .fd-mission__inner{ grid-template-columns: 1fr; gap: 50px; }
}

/* Values */
.fd-values{
  padding: 100px 40px;
  background: var(--fd-bg-soft, #faf7ff);
}
.fd-values__inner{ max-width: 1200px; margin: 0 auto; }
.fd-values__head{ text-align: center; margin-bottom: 60px; }
.fd-values__head .fd-tag{ justify-content: center; }
.fd-values__grid{
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
}
.fd-value{
  background: white;
  border-radius: 20px;
  padding: 32px 24px;
  text-align: center;
  transition: transform .25s, box-shadow .25s;
}
.fd-value:hover{
  transform: translateY(-6px);
  box-shadow: 0 24px 40px -16px rgba(115,84,162,.18);
}
.fd-value__icon{
  width: 60px; height: 60px;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--fd-purple-soft), white);
  color: var(--fd-purple-deep);
  display: grid; place-items: center;
  font-size: 22px;
  margin: 0 auto 20px;
  box-shadow: inset 0 0 0 1.5px rgba(115,84,162,.15);
}
.fd-value__title{
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 17px;
  color: var(--fd-ink);
  margin: 0 0 10px;
}
.fd-value__text{
  font-size: 14px;
  line-height: 1.6;
  color: var(--fd-ink-soft);
  margin: 0;
}
@media (max-width: 1024px){
  .fd-values__grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px){
  .fd-values__grid{ grid-template-columns: 1fr; }
}

/* Timeline */
.fd-timeline{
  padding: 100px 40px;
  background: white;
}
/* Уже центрированный контейнер — карточки + год + линия */
.fd-timeline__inner{
  max-width: 760px;
  margin: 0 auto;
}
.fd-timeline__head{ text-align: center; margin-bottom: 60px; }
.fd-timeline__head .fd-tag{ justify-content: center; display: inline-flex; }
.fd-timeline__list{
  position: relative;
  padding-top: 8px;
}
/* Вертикальная линия — толще, с явным градиентом, центр под точками */
.fd-timeline__list::before{
  content: '';
  position: absolute;
  left: 110px;
  top: 0; bottom: 0;
  width: 3px;
  background: linear-gradient(180deg,
    var(--fd-purple-deep) 0%,
    var(--fd-purple) 50%,
    var(--fd-purple-soft) 100%);
  border-radius: 2px;
}
.fd-milestone{
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 40px;
  padding: 12px 0;
  position: relative;
  align-items: stretch;
}
.fd-milestone + .fd-milestone{
  margin-top: 8px;
}
/* Точка-маркер на линии — крупнее, с двойной обводкой */
.fd-milestone::before{
  content: '';
  position: absolute;
  left: 102px;
  top: 30px;
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--fd-purple-deep);
  border: 4px solid white;
  box-shadow:
    0 0 0 2px var(--fd-purple-deep),
    0 8px 18px -4px rgba(115,84,162,.45);
  transition: transform .25s, box-shadow .25s;
  z-index: 2;
}
.fd-milestone:hover::before{
  transform: scale(1.18);
  box-shadow:
    0 0 0 2px var(--fd-ink),
    0 12px 24px -4px rgba(31,31,31,.35);
}
/* Год — крупный курсив, прижат к правому краю своей колонки */
.fd-milestone__year{
  font-family: var(--fd-display);
  font-weight: 900;
  font-size: 32px;
  color: var(--fd-purple-deep);
  text-align: right;
  padding-top: 18px;
  line-height: 1;
  letter-spacing: -1px;
}
/* Карточка — компактная, с hover-лифтом, цветной полоской слева */
.fd-milestone__body{
  background: var(--fd-bg-soft, #faf7ff);
  border-radius: 16px;
  padding: 22px 26px;
  position: relative;
  border-left: 3px solid var(--fd-purple-soft);
  box-shadow: 0 4px 12px -8px rgba(115,84,162,.18);
  transition: transform .25s, box-shadow .25s, border-color .25s, background .25s;
}
.fd-milestone:hover .fd-milestone__body{
  transform: translateX(4px);
  background: white;
  border-left-color: var(--fd-purple-deep);
  box-shadow: 0 14px 28px -12px rgba(115,84,162,.28);
}
.fd-milestone__title{
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 19px;
  color: var(--fd-ink);
  margin: 0 0 6px;
}
.fd-milestone__text{
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--fd-ink-soft);
  margin: 0;
}

/* Цветовые акценты на каждой 5-й карточке (год = «новая эпоха») */
.fd-milestone:nth-child(5n+1) .fd-milestone__body{ border-left-color: var(--fd-purple); }
.fd-milestone:nth-child(5n+2) .fd-milestone__body{ border-left-color: var(--fd-green, #5daa52); }
.fd-milestone:nth-child(5n+3) .fd-milestone__body{ border-left-color: var(--fd-punch, #e84a3b); }
.fd-milestone:nth-child(5n+4) .fd-milestone__body{ border-left-color: var(--fd-pink, #f2b7c9); }
.fd-milestone:nth-child(5n+0) .fd-milestone__body{ border-left-color: var(--fd-ink); }

@media (max-width: 768px){
  .fd-timeline{ padding: 60px 20px; }
  .fd-timeline__inner{ max-width: 100%; }
  .fd-timeline__list::before{ left: 10px; }
  .fd-milestone{
    grid-template-columns: 1fr;
    gap: 6px;
    padding-left: 40px;
  }
  .fd-milestone::before{
    left: 2px; top: 18px;
    width: 16px; height: 16px;
    border-width: 3px;
  }
  .fd-milestone__year{
    text-align: left;
    padding-top: 0;
    font-size: 22px;
    margin-bottom: 4px;
  }
  .fd-milestone__body{
    padding: 16px 18px;
  }
}

/* CTA */
.fd-cta{
  position: relative;
  padding: 100px 40px;
  background: linear-gradient(135deg, var(--fd-purple-deep) 0%, var(--fd-ink) 100%);
  color: white;
  text-align: center;
  overflow: hidden;
}
.fd-cta__inner{ position: relative; z-index: 2; max-width: 720px; margin: 0 auto; }

/* CTA с фоновым фото — фото полностью видимое (cover), сверху лёгкий
   тёмный overlay чтобы белый текст оставался читабельным */
.fd-cta--has-photo .fd-cta__bg{
  position: absolute; inset: 0;
  background-image: var(--fd-cta-bg) !important;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
  opacity: 1;
  z-index: 1;
}
.fd-cta--has-photo{
  background: var(--fd-ink);
}
.fd-cta--has-photo::before{
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(31,31,31,.55) 0%, rgba(31,31,31,.7) 100%);
  z-index: 2;          /* поверх фото, но под контентом (контент z-index 3) */
  pointer-events: none;
}
.fd-cta--has-photo .fd-cta__inner{
  position: relative;
  z-index: 3;          /* контент поверх overlay */
}
.fd-cta__title{
  font-family: var(--fd-display);
  font-weight: 900;
  font-size: clamp(32px, 5vw, 56px);
  line-height: 1.05;
  margin: 0 0 18px;
  letter-spacing: -1.5px;
}
.fd-cta__title em{
  font-family: var(--fd-italic, 'Cormorant Garamond', serif);
  font-style: italic;
  font-weight: 600;
  color: var(--fd-pink, #f2b7c9);
}
.fd-cta__text{
  font-size: 17px;
  line-height: 1.6;
  opacity: .85;
  margin: 0 0 32px;
}
.fd-cta__actions{
  display: flex; gap: 14px; justify-content: center; flex-wrap: wrap;
}
.fd-cta__actions .fd-btn--primary{
  background: white !important;
  color: var(--fd-purple-deep) !important;
}
.fd-cta__actions .fd-btn--primary:hover{
  background: var(--fd-pink, #f2b7c9) !important;
  color: var(--fd-ink) !important;
}
.fd-cta__actions .fd-btn--ghost{
  background: transparent !important;
  color: white !important;
  border: 1px solid rgba(255,255,255,.4) !important;
}
.fd-cta__actions .fd-btn--ghost:hover{
  background: rgba(255,255,255,.1) !important;
  border-color: white !important;
}

/* ═══════════════════════════════════════════════════════════════════════
   SEARCH
   ═══════════════════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════════════════════════════════════════
   SEARCH FORM (общая для 404, /?s=, виджетов)
   ═══════════════════════════════════════════════════════════════════════ */
.screen-reader-text{
  position: absolute !important;
  clip: rect(1px, 1px, 1px, 1px);
  width: 1px; height: 1px;
  overflow: hidden;
  border: 0; padding: 0; margin: -1px;
}
.fd-search-form-wrap{ max-width: 580px; margin: 32px auto 0; }
.fd-search-form{
  display: flex !important;
  align-items: stretch !important;
  gap: 6px !important;
  background: white !important;
  border: 2px solid var(--fd-purple) !important;
  border-radius: 16px !important;
  padding: 6px !important;
  box-shadow: 0 14px 30px -16px rgba(115,84,162,.25) !important;
  transition: border-color .2s, box-shadow .2s !important;
}
.fd-search-form:focus-within{
  border-color: var(--fd-purple-deep) !important;
  box-shadow: 0 18px 36px -16px rgba(115,84,162,.4) !important;
}
.fd-search-form__input,
.fd-search-form input[type="search"]{
  flex: 1 !important;
  min-width: 0 !important;
  border: 0 !important;
  background: transparent !important;
  padding: 14px 18px !important;
  font: inherit !important;
  font-size: 15px !important;
  color: var(--fd-ink) !important;
  outline: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  height: auto !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}
.fd-search-form__input:focus,
.fd-search-form input[type="search"]:focus{
  outline: none !important;
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}
.fd-search-form__input::placeholder{
  color: var(--fd-ink-soft);
  font-weight: 500;
}
.fd-search-form__btn,
.fd-search-form button{
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: var(--fd-ink) !important;
  color: white !important;
  border: 0 !important;
  border-radius: 12px !important;
  padding: 12px 22px !important;
  font-family: var(--fd-display) !important;
  font-weight: 800 !important;
  font-size: 13px !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: background .2s, transform .15s !important;
  white-space: nowrap !important;
  text-decoration: none !important;
}
.fd-search-form__btn:hover,
.fd-search-form button:hover{
  background: var(--fd-purple-deep) !important;
  transform: translateY(-1px) !important;
}
.fd-search-form__btn:focus,
.fd-search-form button:focus{ outline: none !important; }
@media (max-width: 480px){
  .fd-search-form__btn-label{ display: none; }
  .fd-search-form__btn{ padding: 12px 16px; }
  .fd-search-form__input{ padding: 12px 14px; font-size: 14px; }
}

.fd-search-results{
  padding: 60px 40px 100px;
  background: white;
}
.fd-search-results__inner{ max-width: 900px; margin: 0 auto; }
.fd-search-list{ list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.fd-search-item{ list-style: none; }
.fd-search-item__link{
  display: flex; align-items: center; gap: 20px;
  background: var(--fd-bg-soft, #faf7ff);
  border-radius: 18px;
  padding: 20px 22px;
  text-decoration: none;
  transition: background .2s, transform .2s;
}
.fd-search-item__link:hover{
  background: white;
  box-shadow: 0 16px 32px -16px rgba(115,84,162,.18);
  transform: translateX(4px);
}
.fd-search-item__thumb{
  width: 80px; height: 80px;
  border-radius: 14px;
  overflow: hidden;
  flex-shrink: 0;
}
.fd-search-item__thumb img{ width: 100%; height: 100%; object-fit: cover; display: block; }
.fd-search-item__body{ flex: 1; min-width: 0; }
.fd-search-item__type{
  font-family: var(--fd-display);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--fd-purple-deep);
  text-transform: uppercase;
  margin-bottom: 4px;
}
.fd-search-item__title{
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 18px;
  color: var(--fd-ink);
  margin: 0 0 4px;
}
.fd-search-item__excerpt{
  font-size: 13.5px;
  color: var(--fd-ink-soft);
  line-height: 1.55;
}
.fd-search-item__arrow{ color: var(--fd-purple-deep); flex-shrink: 0; }

.fd-search-empty{
  text-align: center;
  background: var(--fd-bg-soft, #faf7ff);
  border-radius: 22px;
  padding: 80px 40px;
}
.fd-search-empty__icon{
  width: 80px; height: 80px;
  border-radius: 9999px;
  background: white;
  color: var(--fd-purple-deep);
  display: grid; place-items: center;
  font-size: 28px;
  margin: 0 auto 22px;
}
.fd-search-empty__title{
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 24px;
  color: var(--fd-ink);
  margin: 0 0 10px;
}
.fd-search-empty p{ font-size: 15px; color: var(--fd-ink-soft); margin: 0 0 24px; }

.fd-search-pagination{
  display: flex; justify-content: center; margin-top: 40px;
}
.fd-search-pagination .nav-links{
  display: inline-flex; gap: 6px;
  background: var(--fd-bg-soft, #faf7ff);
  border-radius: 14px;
  padding: 6px;
}
.fd-search-pagination .page-numbers{
  min-width: 40px; height: 40px;
  display: grid; place-items: center;
  border-radius: 10px;
  font-family: var(--fd-display);
  font-weight: 700;
  font-size: 14px;
  color: var(--fd-ink);
  background: transparent;
  text-decoration: none;
  transition: background .2s, color .2s;
}
.fd-search-pagination .page-numbers:hover{
  background: var(--fd-purple-soft);
  color: var(--fd-purple-deep);
}
.fd-search-pagination .page-numbers.current{
  background: var(--fd-purple-deep);
  color: white;
}

/* ═══════════════════════════════════════════════════════════════════════
   DELIVERY & RETURN
   ═══════════════════════════════════════════════════════════════════════ */

/* Delivery cards (4 способа) */
.fd-delivery{
  padding: 100px 40px;
  background: white;
}
.fd-delivery__inner{ max-width: 1200px; margin: 0 auto; text-align: center; }
.fd-delivery__inner > .fd-tag{
  display: inline-flex !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.fd-delivery__inner > .fd-section-title{ text-align: center; margin-bottom: 50px; }

.fd-delivery__grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.fd-delivery-card{
  position: relative;
  background: var(--fd-bg-soft, #faf7ff);
  border-radius: 22px;
  padding: 32px 26px;
  transition: transform .25s, box-shadow .25s, background .25s;
  display: flex; flex-direction: column;
}
.fd-delivery-card:hover{
  transform: translateY(-6px);
  background: white;
  box-shadow: 0 24px 48px -16px rgba(115,84,162,.18);
}
.fd-delivery-card--featured{
  background: linear-gradient(160deg, var(--fd-purple-deep) 0%, var(--fd-ink) 100%);
  color: white;
}
.fd-delivery-card--featured:hover{ background: linear-gradient(160deg, var(--fd-purple-deep) 0%, var(--fd-ink) 100%); color: white; }
.fd-delivery-card__badge{
  position: absolute; top: 14px; right: 14px;
  background: white;
  color: var(--fd-purple-deep);
  font-family: var(--fd-display);
  font-weight: 800; font-size: 10px;
  letter-spacing: 1.5px;
  padding: 5px 10px;
  border-radius: 6px;
}
.fd-delivery-card__icon{
  width: 56px; height: 56px;
  border-radius: 16px;
  background: var(--fd-purple-soft);
  color: var(--fd-purple-deep);
  display: grid; place-items: center;
  font-size: 22px;
  margin-bottom: 20px;
}
.fd-delivery-card--featured .fd-delivery-card__icon{
  background: rgba(255,255,255,.15);
  color: white;
}
.fd-delivery-card__title{
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 18px;
  margin: 0 0 6px;
}
.fd-delivery-card__price{
  font-family: var(--fd-display);
  font-weight: 700;
  font-size: 14px;
  color: var(--fd-purple-deep);
  margin-bottom: 14px;
}
.fd-delivery-card--featured .fd-delivery-card__price{ color: rgba(255,255,255,.85); }
.fd-delivery-card__text{
  font-size: 14px;
  line-height: 1.6;
  color: var(--fd-ink-soft);
  margin: 0 0 18px;
  flex: 1;
}
.fd-delivery-card--featured .fd-delivery-card__text{ color: rgba(255,255,255,.75); }
.fd-delivery-card__meta{
  display: flex; align-items: center; gap: 8px;
  font-size: 13px;
  color: var(--fd-ink);
  font-weight: 600;
  padding-top: 14px;
  border-top: 1px solid var(--fd-purple-soft);
}
.fd-delivery-card--featured .fd-delivery-card__meta{
  color: white;
  border-top-color: rgba(255,255,255,.15);
}
.fd-delivery-card__meta i{ color: var(--fd-purple-deep); }
.fd-delivery-card--featured .fd-delivery-card__meta i{ color: rgba(255,255,255,.7); }

@media (max-width: 1024px){
  .fd-delivery__grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px){
  .fd-delivery__grid{ grid-template-columns: 1fr; }
}

/* Zones table + Payment list */
.fd-zones{
  padding: 100px 40px;
  background: var(--fd-bg-soft, #faf7ff);
}
.fd-zones__inner{
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 60px;
  align-items: start;
}
.fd-zones__table{
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 6px;
  margin-top: 24px;
}
.fd-zones__table th{
  text-align: left;
  font-family: var(--fd-display);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--fd-ink-soft);
  padding: 12px 16px;
}
.fd-zones__table td{
  background: white;
  padding: 16px;
  font-size: 14.5px;
  color: var(--fd-ink);
  vertical-align: middle;
}
.fd-zones__table td:first-child{
  border-radius: 12px 0 0 12px;
  font-weight: 600;
}
.fd-zones__table td:last-child{
  border-radius: 0 12px 12px 0;
  font-weight: 700;
  color: var(--fd-purple-deep);
  text-align: right;
  font-family: var(--fd-display);
}
.fd-zones__note{
  margin-top: 18px;
  padding: 14px 18px;
  background: white;
  border-left: 3px solid var(--fd-purple-deep);
  border-radius: 10px;
  font-size: 14px;
  color: var(--fd-ink);
}

.fd-pay-list{
  display: flex; flex-direction: column;
  gap: 14px;
  margin-top: 24px;
}
.fd-pay-item{
  display: flex; align-items: flex-start; gap: 16px;
  background: white;
  border-radius: 16px;
  padding: 18px 20px;
  transition: transform .2s;
}
.fd-pay-item:hover{ transform: translateX(4px); }
.fd-pay-item__icon{
  width: 46px; height: 46px;
  border-radius: 12px;
  background: var(--fd-purple-soft);
  color: var(--fd-purple-deep);
  display: grid; place-items: center;
  font-size: 18px;
  flex-shrink: 0;
}
.fd-pay-item__body strong{
  display: block;
  font-family: var(--fd-display);
  font-size: 15px;
  font-weight: 800;
  color: var(--fd-ink);
  margin-bottom: 4px;
}
.fd-pay-item__body span{
  font-size: 13.5px;
  color: var(--fd-ink-soft);
  line-height: 1.5;
}

@media (max-width: 1024px){
  .fd-zones__inner{ grid-template-columns: 1fr; gap: 50px; }
}
@media (max-width: 640px){
  .fd-zones__table th, .fd-zones__table td{ padding: 10px 12px; font-size: 13px; }
}

/* Return section */
.fd-return{
  padding: 100px 40px;
  background: white;
}
.fd-return__inner{ max-width: 1200px; margin: 0 auto; }
.fd-return__head{ text-align: center; max-width: 760px; margin: 0 auto 60px; }
.fd-return__head .fd-tag{ justify-content: center; display: inline-flex; }
.fd-return__lead{
  font-size: 16px;
  line-height: 1.7;
  color: var(--fd-ink-soft);
  margin: 18px 0 0;
}
.fd-return__lead strong{ color: var(--fd-purple-deep); }

.fd-return__steps{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-bottom: 60px;
}
.fd-return-step{
  background: var(--fd-bg-soft, #faf7ff);
  border-radius: 18px;
  padding: 28px 24px;
  position: relative;
}
.fd-return-step__num{
  font-family: var(--fd-display);
  font-weight: 900;
  font-size: 36px;
  color: var(--fd-purple-deep);
  opacity: .25;
  line-height: 1;
  margin-bottom: 8px;
}
.fd-return-step__title{
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 17px;
  color: var(--fd-ink);
  margin: 0 0 8px;
}
.fd-return-step p{
  font-size: 14px;
  line-height: 1.6;
  color: var(--fd-ink-soft);
  margin: 0;
}

.fd-return__rules{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
}
.fd-return__rules-col{
  background: var(--fd-bg-soft, #faf7ff);
  border-radius: 22px;
  padding: 32px 30px;
}
.fd-return__rules-title{
  display: flex; align-items: center; gap: 10px;
  font-family: var(--fd-display);
  font-weight: 800;
  font-size: 17px;
  margin: 0 0 18px;
  color: var(--fd-ink);
}
.fd-return__rules-col:nth-child(1) .fd-return__rules-title i{ color: var(--fd-green-deep, #2e7d50); }
.fd-return__rules-col:nth-child(2) .fd-return__rules-title i{ color: var(--fd-punch, #e84a3b); }
.fd-return__rules-col ul{
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 10px;
}
.fd-return__rules-col li{
  position: relative;
  padding-left: 22px;
  font-size: 14px;
  line-height: 1.55;
  color: var(--fd-ink);
}
.fd-return__rules-col li::before{
  content: '';
  position: absolute;
  left: 0; top: 9px;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--fd-purple-deep);
}
.fd-return__rules-col:nth-child(1) li::before{ background: var(--fd-green-deep, #2e7d50); }
.fd-return__rules-col:nth-child(2) li::before{ background: var(--fd-punch, #e84a3b); }

@media (max-width: 1024px){
  .fd-return__steps{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px){
  .fd-return__steps,
  .fd-return__rules{ grid-template-columns: 1fr; }
}

/* FAQ */
.fd-faq{
  padding: 100px 40px;
  background: var(--fd-bg-soft, #faf7ff);
}
.fd-faq__inner{ max-width: 900px; margin: 0 auto; }
.fd-faq__inner > .fd-tag{ display: inline-flex; }
.fd-faq__inner > .fd-section-title{ margin-bottom: 40px; }

.fd-faq__list{
  display: flex; flex-direction: column;
  gap: 12px;
}
.fd-faq__item{
  background: white;
  border-radius: 16px;
  padding: 0;
  overflow: hidden;
  transition: box-shadow .2s;
}
.fd-faq__item:hover{ box-shadow: 0 14px 28px -16px rgba(115,84,162,.18); }
.fd-faq__item[open]{ box-shadow: 0 20px 40px -20px rgba(115,84,162,.22); }
.fd-faq__q{
  cursor: pointer;
  list-style: none;
  padding: 22px 26px;
  font-family: var(--fd-display);
  font-weight: 700;
  font-size: 16px;
  color: var(--fd-ink);
  position: relative;
  padding-right: 60px;
  user-select: none;
}
.fd-faq__q::-webkit-details-marker{ display: none; }
.fd-faq__q::after{
  content: '+';
  position: absolute;
  right: 24px; top: 50%;
  transform: translateY(-50%);
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--fd-purple-soft);
  color: var(--fd-purple-deep);
  display: grid; place-items: center;
  font-size: 18px;
  font-weight: 700;
  transition: transform .25s, background .25s;
  font-family: sans-serif;
  line-height: 1;
}
.fd-faq__item[open] .fd-faq__q::after{
  transform: translateY(-50%) rotate(45deg);
  background: var(--fd-purple-deep);
  color: white;
}
.fd-faq__a{
  padding: 0 26px 22px;
  font-size: 14.5px;
  line-height: 1.65;
  color: var(--fd-ink-soft);
}

/* ═══════════════════════════════════════════════════════════════════════
   MOBILE AUDIT — финальные правки адаптива (≤768px)
   Унифицированный блок всех исправлений мобильной версии,
   накопленных по итогам live-аудита.
   ═══════════════════════════════════════════════════════════════════════ */

/* ─── Глобальные мобильные исправления ≤768px ─── */
@media (max-width: 768px){

  /* Hero — фото и инфо адекватного размера, не теряются */
  .fd-hero{
    min-height: auto !important;
    padding: 100px 16px 40px !important;
  }
  .fd-hero__stage{
    flex-direction: column !important;
    min-height: auto !important;
    padding: 30px 0 !important;
  }
  /* На мобилке отключаем боковые упаковки prev/next — карусель только через стрелки */
  .fd-hero__sides{ display: none !important; }
  .fd-hero__center{
    width: clamp(220px, 70vw, 380px) !important;
    height: clamp(220px, 70vw, 380px) !important;
    aspect-ratio: 1/1 !important;
  }
  .fd-hero__active:has(.fd-pkg__img:not([hidden])){
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
  }
  .fd-hero__active .fd-pkg--active.fd-pkg--link{
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
  }
  .fd-hero__split{
    font-size: clamp(50px, 16vw, 90px) !important;
    gap: clamp(120px, 40vw, 220px) !important;
    top: 30% !important;
  }
  .fd-hero__info{
    position: static !important;
    transform: none !important;
    text-align: center !important;
    margin-top: 20px !important;
    padding: 0 16px !important;
    max-width: 100% !important;
  }
  .fd-hero__info-bullets{ align-items: center; }
  .fd-hero__info-bullets span{ justify-content: center; }
  .fd-hero__info-title{ font-size: clamp(24px, 5vw, 32px) !important; }
  .fd-arrow{
    width: 44px !important; height: 44px !important;
    font-size: 14px !important;
    top: 28% !important;
  }
  .fd-arrow--left{ left: 8px !important; }
  .fd-arrow--right{ right: 8px !important; }

  /* Products grid (главная) — одна колонка, фото гарантированно показываются */
  .fd-products{ padding: 60px 16px !important; }
  .fd-products__grid{
    grid-template-columns: 1fr !important;
    gap: 40px !important;
    padding: 0 !important;
    max-width: 460px !important;
    margin: 0 auto !important;
  }
  .fd-prod{
    max-width: 100% !important;
    margin: 0 auto !important;
    width: 100% !important;
  }
  .fd-prod__art{
    height: 280px !important;
    max-width: 100% !important;
    margin: 0 auto 14px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden;
  }
  .fd-prod__photo{
    position: relative !important;
    inset: auto !important;
    width: auto !important;
    height: 100% !important;
    max-width: 100% !important;
    object-fit: contain !important;
    padding: 0 !important;
  }
  /* Прячем CSS-арт абсолютно — на случай если :has() где-то не сработает */
  .fd-prod__arc{ display: none !important; }
  .fd-prod__title{ font-size: 20px !important; }
  .fd-prod__price{ font-size: 28px !important; }
  .fd-prod__cta{ justify-content: center !important; gap: 8px; flex-wrap: wrap; }
  .fd-prod__cta .fd-btn{ flex: 1 1 auto; padding: 12px 16px !important; font-size: 12px !important; }

  /* Tagline / общие секции — отступы экономнее */
  .fd-tagline,
  .fd-fan,
  .fd-flavor,
  .fd-life{
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  /* Page-intro decorations — скрыть на мобилке (мешают тексту) */
  .fd-page-intro__decor{ display: none !important; }
  .fd-page-intro{ padding: 100px 20px 60px !important; }
  .fd-page-intro__title{ font-size: clamp(36px, 9vw, 56px) !important; }
  .fd-page-intro__lead{ font-size: 14.5px !important; }

  /* Mission visual (about) — компакт */
  .fd-mission__visual{ min-height: 280px !important; }
  .fd-mission__pkg{ width: 32% !important; }

  /* Footer — нормальный паддинг и центрирование */
  .fd-footer{ padding: 50px 20px 0 !important; }
  .fd-footer__inner{ grid-template-columns: 1fr !important; gap: 32px !important; text-align: center; }
  .fd-footer__brand{ align-items: center; text-align: center; }
  .fd-footer__cols{
    grid-template-columns: 1fr !important;
    gap: 28px !important;
    text-align: center;
  }
  .fd-footer__col h4{ text-align: center !important; }
  .fd-partners{ justify-content: center !important; }
  .fd-contact-line{ justify-content: center !important; }
  .fd-footer__copy{ margin: 0 -20px !important; }

  /* Контакты — карточки в столбик с нормальным top-margin (поверх hero negative-margin) */
  .fd-contacts-grid{ padding: 0 16px 50px !important; }
  .fd-contacts-grid__inner{ margin-top: -30px !important; }

  /* CTA block — компакт */
  .fd-cta{ padding: 60px 20px !important; }
  .fd-cta__title{ font-size: clamp(28px, 7vw, 40px) !important; }
  .fd-cta__text{ font-size: 15px !important; }
  .fd-cta__actions{ flex-direction: column; }
  .fd-cta__actions .fd-btn{ width: 100%; justify-content: center; }

  /* Delivery — карточки и таблицы */
  .fd-delivery{ padding: 60px 16px !important; }
  .fd-zones{ padding: 60px 16px !important; }
  .fd-return{ padding: 60px 16px !important; }
  .fd-faq{ padding: 60px 16px !important; }

  /* Search form — input полная ширина, кнопка квадратная */
  .fd-search-form-wrap{ padding: 0 16px; }
  .fd-search-form__input{ font-size: 14px !important; padding: 12px 14px !important; }
  .fd-search-form__btn{ padding: 12px 14px !important; }
}

/* ─── Узкая мобилка ≤420 ─── */
@media (max-width: 420px){
  .fd-hero{ padding: 90px 12px 30px !important; }
  .fd-hero__center{ width: 80vw !important; height: 80vw !important; }
  .fd-hero__split{ font-size: clamp(42px, 14vw, 70px) !important; }
  .fd-arrow{ width: 38px !important; height: 38px !important; font-size: 12px !important; }
  .fd-prod__art{ height: 240px !important; }
  .fd-page-intro{ padding: 90px 16px 50px !important; }
  .fd-footer{ padding: 40px 16px 0 !important; }
  .fd-footer__copy{ margin: 0 -16px !important; }
}

/* ═══════════════════════════════════════════════════════════════════════
   GTRANSLATE — языковой переключатель в шапке
   ═══════════════════════════════════════════════════════════════════════ */

/* обёртка внутри fd-nav */
.fd-lang {
  display: inline-flex;
  align-items: center;
  position: relative;
}

/* контейнер ссылок EN / RU / UZ */
.fd-lang .gtranslate_wrapper {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;                 /* отступы между переключателями */
}
.fd-lang #google_translate_element2 { display: none !important; }

/* GTranslate: скрываем дефолтную ссылку «Powered by» */
.fd-lang a[href*="gtranslate.io"],
.fd-lang a[href*="gtranslate.com"] { display: none !important; }

/* ── Ссылки-переключатели (links-вариант) ──────────────────────────── */
.fd-lang .glink {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 38px !important;
  padding: 7px 13px !important;
  border-radius: 9999px !important;
  font-family: var(--fd-body) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: .05em !important;
  line-height: 1 !important;
  color: var(--fd-ink-muted) !important;
  text-decoration: none !important;
  border: 1.5px solid transparent !important;
  background: transparent !important;
  cursor: pointer !important;
  transition: color .18s ease, background .18s ease, border-color .18s ease, transform .18s ease, box-shadow .18s ease !important;
}
.fd-lang .glink:hover {
  color: var(--fd-purple-deep) !important;
  background: var(--fd-purple-soft) !important;
  border-color: var(--fd-purple) !important;
  transform: translateY(-1px) !important;
}

/* ── Активный язык — залит брендовым градиентом ────────────────────── */
.fd-lang .glink.gt-current-lang {
  color: #fff !important;
  background: linear-gradient(135deg, var(--fd-purple-deep), var(--fd-pink-deep)) !important;
  border-color: transparent !important;
  box-shadow: var(--fd-shadow-soft) !important;
}
.fd-lang .glink.gt-current-lang:hover {
  color: #fff !important;
  background: linear-gradient(135deg, var(--fd-purple-deep), var(--fd-pink-deep)) !important;
  filter: brightness(1.05) !important;
  transform: translateY(-1px) !important;
}

/* убираем баннер Google Translate сверху (не сдвигаем страницу) */
body { top: 0 !important; }
.goog-te-banner-frame,
.skiptranslate > iframe { display: none !important; }

/* ── Мобилка ≤768 — чуть компактнее ────────────────────────────────── */
@media (max-width: 768px) {
  .fd-lang .gtranslate_wrapper { gap: 8px !important; }
  .fd-lang .glink {
    min-width: 40px !important;
    padding: 8px 14px !important;
    font-size: 13px !important;
  }
  /* пока JS не перенёс переводчик — не показываем его в шапке (не ломаем вёрстку) */
  .fd-nav > .fd-lang:not(.fd-lang--in-menu) { display: none !important; }
}

/* ── На мобилке переводчик живёт внутри выпадающего меню ───────────── */
.fd-lang--in-menu {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 10px !important;
  width: 100% !important;
  margin-top: 8px !important;
  padding: 14px 16px 4px !important;
  border-top: 1px solid var(--fd-purple-soft) !important;
}
.fd-lang--in-menu::before {
  content: "ЯЗЫК";
  font-family: var(--fd-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  color: var(--fd-ink-muted);
}
.fd-lang--in-menu .gtranslate_wrapper {
  width: 100% !important;
  gap: 10px !important;
}


