:root{
  /* Soft pastel palette — meadow + powder pink */
  --sky-1:        #dfeefa;
  --sky-2:        #e9f1f7;
  --sky-soft:     #cee0f0;
  --sky-mid:      #9ec0db;
  --sky-deep:     #6f95b6;
  --cream:        #fbf6f1;
  --cream-warm:   #f7ede4;
  --blush:        #fbe6dd;
  --pink-mist:    #fde7ec;
  --pink-soft:    #f9c8d4;
  --pink-mid:     #f1a8bd;
  --pink-deep:    #d97b97;
  --rose:         #b66481;
  --rose-dark:    #8a3f5c;
  --aubergine:    #2a1c28;
  --plum:         #4a2c3b;
  --muted:        #8a6d72;
  --line:         rgba(166,84,109,.15);
  --gold:         #d4a574;
  --sage:         #b8c5a8;
  --burgundy:     #6f273c;
  --navy-soft:    #6a7da3;

  --shadow-card:  0 16px 40px -18px rgba(180, 90, 120, .25),
                  0 6px 14px -6px rgba(180, 90, 120, .12);
  --shadow-pink:  0 14px 30px -12px rgba(230, 130, 165, .55),
                  inset 0 1px 0 rgba(255,255,255,.6);
  --radius-xl: 28px;
  --radius-lg: 22px;
  --radius-md: 16px;
  --radius-pill: 999px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  min-height:100vh;
  background:
    radial-gradient(ellipse 70% 35% at 50% 0%, rgba(223,238,250,.95), transparent 65%),
    radial-gradient(ellipse 80% 30% at 50% 100%, rgba(249,200,212,.45), transparent 65%),
    radial-gradient(ellipse 60% 30% at 0% 50%, rgba(184,197,168,.18), transparent 60%),
    linear-gradient(180deg, #eaf3f9 0%, #fbf3ec 35%, #fbe6dd 70%, #fde7ec 100%);
  background-attachment: fixed;
  color: var(--aubergine);
  font-family:'Onest','Montserrat', system-ui, sans-serif;
  font-weight: 400;
  line-height: 1.5;
  overflow-x: hidden;
}
img,video{display:block;max-width:100%;height:auto}
button,input,select{font:inherit}
a{color:inherit;text-decoration:none}

/* ============ Floating petals decoration ============ */
.petals{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:0}
.petal{position:absolute;width:14px;height:14px;opacity:.5;animation:float-petal 22s linear infinite}
.petal svg{width:100%;height:100%}
.petal:nth-child(1){left:6%;top:-10%;animation-duration:24s;animation-delay:0s}
.petal:nth-child(2){left:18%;top:-10%;animation-duration:30s;animation-delay:-7s;transform:scale(.7)}
.petal:nth-child(3){left:34%;top:-10%;animation-duration:26s;animation-delay:-14s;transform:scale(1.1)}
.petal:nth-child(4){left:52%;top:-10%;animation-duration:32s;animation-delay:-3s}
.petal:nth-child(5){left:68%;top:-10%;animation-duration:25s;animation-delay:-19s;transform:scale(.85)}
.petal:nth-child(6){left:82%;top:-10%;animation-duration:28s;animation-delay:-9s;transform:scale(1.2)}
.petal:nth-child(7){left:94%;top:-10%;animation-duration:34s;animation-delay:-15s;transform:scale(.65)}
@keyframes float-petal{
  0%{transform:translate3d(0,-10vh,0) rotate(0);opacity:0}
  10%{opacity:.5}
  50%{transform:translate3d(40px,60vh,0) rotate(180deg);opacity:.5}
  90%{opacity:.2}
  100%{transform:translate3d(-25px,120vh,0) rotate(360deg);opacity:0}
}

/* ============ Layout ============ */
.landing{
  position:relative;
  z-index:1;
  width:min(100%, 430px);
  margin:0 auto;
  padding:0 14px 40px;
}


/* ============ HERO ============ */
.hero{
  position:relative;
  margin-top:6px;
  padding:6px 6px 14px;
  text-align:center;
}
.hero__title{
  font-family:'Fraunces',serif;
  font-weight:500;
  font-size:34px;
  line-height:1.02;
  letter-spacing:-.025em;
  color:var(--aubergine);
  font-variation-settings:"opsz" 144, "SOFT" 50;
  animation:slide-up .9s cubic-bezier(.2,.8,.2,1) both;
}
.hero__title-script{
  display:block;
  font-family:'Cormorant Garamond', serif;
  font-style:italic;
  font-weight:500;
  font-size:clamp(26px, 8.6vw, 38px);
  line-height:1.02;
  letter-spacing:-.01em;
  color:var(--rose);
  margin-top:2px;
  white-space:nowrap;
  animation:slide-up 1s cubic-bezier(.2,.8,.2,1) .15s both;
}
.hero__title-script::after{content:''}
.hero__lead{
  margin:10px auto 0;
  font-size:12px;
  line-height:1.4;
  color:var(--plum);
  font-weight:500;
  letter-spacing:-.005em;
  white-space:nowrap;
  animation:slide-up .9s cubic-bezier(.2,.8,.2,1) .25s both;
}
.hero__visual{
  position:relative;
  margin:14px auto 0;
  border-radius:var(--radius-xl);
  overflow:hidden;
  box-shadow:var(--shadow-card);
  animation:slide-up 1s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes slide-up{from{transform:translateY(20px)}to{transform:translateY(0)}}
.hero__visual img{width:100%;display:block}
.hero__sale{
  position:absolute;top:14px;right:14px;
  display:inline-flex;align-items:center;justify-content:center;
  width:54px;height:54px;border-radius:50%;
  background:linear-gradient(135deg,#fff,#fde7ec);
  color:var(--rose-dark);
  font-family:'Montserrat',sans-serif;
  font-weight:800;
  font-size:14px;
  letter-spacing:-.02em;
  box-shadow:0 6px 16px -4px rgba(180,90,120,.4);
  border:1px solid rgba(255,255,255,.8);
  animation:gentle-pulse 3s ease-in-out infinite;
}
.hero__price{
  position:absolute;bottom:14px;
  display:flex;flex-direction:column;align-items:flex-start;
  padding:8px 14px;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);
  border-radius:var(--radius-md);
  box-shadow:0 8px 18px -8px rgba(180,90,120,.3);
}
.hero__price--old{left:14px}
.hero__price--new{right:14px}
.hero__price small{font-size:10px;color:var(--muted);letter-spacing:.05em;text-transform:uppercase;font-weight:600}
.hero__price strong{font-family:'Montserrat',sans-serif;font-size:16px;font-weight:800;letter-spacing:-.02em;color:var(--aubergine)}
.hero__price--old strong{color:var(--muted);text-decoration:line-through;text-decoration-color:var(--pink-deep);text-decoration-thickness:2px;font-weight:700}
.hero__price--new strong{color:var(--rose-dark)}

.hero__cta-row{
  margin-top:18px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
  animation:slide-up .9s cubic-bezier(.2,.8,.2,1) .35s both;
}
@keyframes rise{from{transform:translateY(28px);opacity:0}to{transform:translateY(0);opacity:1}}

/* Accessibility + Lighthouse fallback: when animations are reduced/disabled, show content instantly */
@media (prefers-reduced-motion: reduce){
  .hero__title,
  .hero__title-script,
  .hero__lead,
  .hero__visual,
  .hero__cta-row,
  .reveal{
    opacity:1 !important;
    transform:none !important;
    animation:none !important;
    transition:none !important;
  }
  .petal{animation:none !important;opacity:0 !important}
  .illu-sway,.illu-float,.illu-pulse,.illu-twirl,.illu-rise{animation:none !important}
}

/* ============ Buttons ============ */
.btn{
  position:relative;
  display:inline-flex;
  align-items:center;justify-content:center;
  gap:8px;
  padding:16px 36px;
  border:none;
  border-radius:var(--radius-pill);
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  font-size:16px;
  letter-spacing:-.005em;
  cursor:pointer;
  transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s ease;
  overflow:hidden;
  white-space:nowrap;
}
.btn--primary{
  background:linear-gradient(135deg,#f9c8d4 0%,#f1a8bd 55%,#e88fab 100%);
  color:#fff;
  box-shadow:var(--shadow-pink);
  text-shadow:0 1px 0 rgba(180,90,120,.18);
}
.btn--primary::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.4) 0%,transparent 50%);
  opacity:0;transition:opacity .35s ease;
}
.btn--primary:active{transform:scale(.98)}
.btn--primary:hover{
  transform:translateY(-2px) scale(1.02);
  box-shadow:0 22px 44px -12px rgba(230,130,165,.7),inset 0 1px 0 rgba(255,255,255,.7);
}
.btn--primary:hover::before{opacity:1}
.btn--primary .heart{font-size:14px;color:#fff;opacity:.92}

.btn-link{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 4px;
  font-family:'Montserrat',sans-serif;
  font-weight:500;
  font-size:13px;
  color:var(--plum);
  border-bottom:1px solid var(--line);
  transition:color .25s ease,border-color .25s ease;
  letter-spacing:.01em;
}
.btn-link:hover{color:var(--rose);border-color:var(--pink-mid)}
.btn-link svg{width:12px;height:12px}

/* ============ Mini benefits row ============ */
.mini-benefits{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:6px;
  margin:14px 0 0;
  padding:10px 12px 10px;
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(10px);
  border-radius:var(--radius-lg);
  border:1px solid rgba(255,255,255,.8);
  box-shadow:0 8px 22px -10px rgba(180,90,120,.2);
}
.mini-ben{
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;
  padding:0;
  position:relative;
}
.mini-ben:not(:last-child)::after{
  content:'';
  position:absolute;
  right:-3px;top:14%;bottom:14%;
  width:1px;
  background:linear-gradient(180deg,transparent,var(--line),transparent);
}
.mini-ben__icon{
  width:48px;height:48px;
  display:inline-flex;align-items:center;justify-content:center;
  position:relative;
}
.mini-ben__icon svg{width:48px;height:48px;display:block}
.mini-ben__text{
  font-family:'Onest',sans-serif;
  font-size:11px;line-height:1.3;color:var(--plum);
  font-weight:600;
  letter-spacing:-.005em;
  padding:0 2px;
}
.mini-ben__text em{
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-weight:600;
  color:var(--rose-dark);
}

/* ============ Offer card (price/discount) ============ */
.offer-box{
  margin-top:14px;
  background:linear-gradient(180deg,rgba(255,255,255,.95),rgba(253,231,236,.85));
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:18px 18px 16px;
  box-shadow:var(--shadow-card);
}
.offer-box__heading{
  display:flex;align-items:center;gap:8px;
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-weight:600;
  font-size:18px;
  color:var(--rose-dark);
  margin-bottom:10px;
}
.offer-box__heading::before{
  content:'';width:24px;height:1px;background:var(--pink-mid);
}
.offer-box__row{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:10px 0;
  border-top:1px dashed var(--line);
  font-size:13px;
}
.offer-box__row:first-of-type{border-top:none}
.offer-box__qty{
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  font-size:14px;
  color:var(--aubergine);
}
.offer-box__meta{
  display:block;
  font-size:11px;
  color:var(--muted);
  margin-top:2px;
}
.offer-box__discount{color:var(--rose);font-weight:700}
.offer-box__row strong{
  font-family:'Montserrat',sans-serif;
  font-weight:800;
  font-size:16px;
  color:var(--rose-dark);
  letter-spacing:-.02em;
}

/* ============ Section heads ============ */
.section{margin-top:28px;position:relative}
.divider + .section,
.divider + .showcase-soft,
.divider + .showcase-dark{margin-top:6px}
.section-head{text-align:center;margin-bottom:14px;padding:0 4px}
.section-title{
  font-family:'Playfair Display',serif;
  font-weight:600;
  font-size:26px;
  line-height:1.1;
  letter-spacing:-.01em;
  color:var(--aubergine);
}
.section-title::after{
  content:'♡';
  font-family:'Onest',sans-serif;
  font-size:14px;
  margin-left:6px;
  color:var(--pink-mid);
  vertical-align:5px;
}
.section-sub{
  margin:8px auto 0;
  max-width:340px;
  font-size:13px;
  color:var(--muted);
  line-height:1.5;
}
.section-sub--nowrap{
  white-space:nowrap;
  max-width:none;
  font-size:12.5px;
}
.section-title em{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-weight:500;
  color:var(--rose);
}
.kicker{
  display:inline-block;
  font-family:'Montserrat',sans-serif;
  font-size:10.5px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--rose);
  font-weight:700;
  margin-bottom:10px;
  padding:4px 14px;
  background:rgba(249,200,212,.35);
  border-radius:var(--radius-pill);
}

/* ============ Colors CTA ============ */
.colors-cta{
  margin-top:18px;
  display:flex;
  justify-content:center;
}

/* ============ Benefits CTA ============ */
.benefits-cta{
  margin-top:18px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
}
.benefits-cta__hint{
  font-size:11px;
  letter-spacing:.04em;
  color:var(--muted);
  font-weight:500;
}

/* ============ Why-she-loves-it ============ */
.why-lead{
  font-size:14px;
  line-height:1.55;
  color:var(--plum);
  text-align:left;
  padding:0 4px;
  margin-bottom:18px;
}
.why-lead b{font-weight:700;color:var(--aubergine)}

.why-card{
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.95);
  border-radius:var(--radius-xl);
  padding:20px 18px;
  box-shadow:var(--shadow-card);
  margin-bottom:14px;
}
.why-card:last-child{margin-bottom:0}

.why-subtitle{
  font-family:'Playfair Display',serif;
  font-weight:600;
  font-size:18px;
  letter-spacing:-.01em;
  color:var(--aubergine);
  margin-bottom:14px;
}
.why-list{
  list-style:none;
  padding:0;margin:0;
  display:flex;flex-direction:column;
  gap:14px;
}
.why-list li{
  display:flex;
  align-items:flex-start;
  gap:12px;
  font-size:13.5px;
  line-height:1.5;
  color:var(--plum);
}
.why-list li b{
  font-weight:700;
  color:var(--aubergine);
}
.why-icon{
  flex:0 0 26px;
  width:26px;height:26px;
  border-radius:50%;
  display:inline-flex;
  align-items:center;justify-content:center;
  margin-top:1px;
}
.why-icon--check{
  background:linear-gradient(135deg,#f9c8d4,#e88fab);
  box-shadow:0 4px 10px -4px rgba(230,130,165,.5);
}
.why-icon--check svg{width:14px;height:14px}
.why-icon--dot{
  width:14px;height:14px;
  flex-basis:14px;
  margin-top:6px;margin-left:6px;
  background:linear-gradient(135deg,#f1a8bd,#d97b97);
  box-shadow:0 0 0 4px rgba(241,168,189,.22);
}

/* ============ Benefits grid (watercolor cards) ============ */
.benefits{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.benefit-card{
  position:relative;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.9);
  border-radius:var(--radius-lg);
  padding:18px 12px 16px;
  text-align:center;
  box-shadow:var(--shadow-card);
  overflow:hidden;
  transition:transform .5s cubic-bezier(.2,.8,.2,1),box-shadow .5s ease;
}
.benefit-card::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(249,200,212,0) 0%,rgba(249,200,212,.18) 100%);
  opacity:0;transition:opacity .5s ease;pointer-events:none;
}
.benefit-card::before{
  content:'♡';
  position:absolute;
  bottom:8px;left:50%;
  transform:translateX(-50%);
  font-size:9px;
  color:var(--pink-mid);
  opacity:.8;
}
.benefit-card:active{transform:scale(.98)}
.benefit-card:hover{
  transform:translateY(-4px);
  box-shadow:0 26px 50px -22px rgba(180,90,120,.32),0 10px 20px -8px rgba(180,90,120,.18);
}
.benefit-card:hover::after{opacity:1}
.benefit-card__illu{
  width:100%;
  aspect-ratio:1/1;
  margin:0 0 10px;
  border-radius:var(--radius-md);
  overflow:hidden;
  position:relative;
  background:#fbf3ec;
}
.benefit-card__illu img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  transition:transform .7s cubic-bezier(.2,.8,.2,1);
}
.benefit-card:hover .benefit-card__illu img{transform:scale(1.06)}
.benefit-card__title{
  font-family:'Playfair Display',serif;
  font-weight:600;
  font-size:15px;
  line-height:1.15;
  color:var(--aubergine);
  margin-bottom:6px;
  padding:0 2px;
}
.benefit-card__desc{
  font-size:11.5px;line-height:1.4;
  color:var(--muted);
  padding:0 2px 14px;
}

/* Continuous gentle animations on illustrations */
.illu-sway   {animation:sway 6s ease-in-out infinite;transform-origin:50% 80%}
.illu-float  {animation:float-y 5s ease-in-out infinite}
.illu-pulse  {animation:gentle-pulse 4s ease-in-out infinite;transform-origin:50% 50%}
.illu-twirl  {animation:twirl 9s ease-in-out infinite;transform-origin:50% 60%}
.illu-rise   {animation:rise-arrow 3.5s ease-in-out infinite}
@keyframes sway       {0%,100%{transform:rotate(-3deg)} 50%{transform:rotate(3deg)}}
@keyframes float-y    {0%,100%{transform:translateY(0)} 50%{transform:translateY(-5px)}}
@keyframes gentle-pulse{0%,100%{transform:scale(1);opacity:.85} 50%{transform:scale(1.08);opacity:1}}
@keyframes twirl      {0%,100%{transform:rotate(-2deg) translateY(0)} 50%{transform:rotate(2deg) translateY(-3px)}}
@keyframes rise-arrow {0%,100%{transform:translateY(0);opacity:.7} 50%{transform:translateY(-4px);opacity:1}}

/* Reveal-on-scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ============ Video section ============ */
.video__frame{
  position:relative;
  border-radius:var(--radius-xl);
  overflow:hidden;
  background:#000;
  box-shadow:var(--shadow-card);
}
.video__frame video{width:100%;display:block}
.video__toggle{
  position:absolute;bottom:12px;right:12px;
  width:42px;height:42px;border:none;border-radius:50%;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(6px);
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--aubergine);cursor:pointer;
  box-shadow:0 4px 12px rgba(0,0,0,.25);
}
.video__toggle svg{width:18px;height:18px}
.showcase__frame{
  position:relative;
  border-radius:var(--radius-xl);
  overflow:hidden;
  box-shadow:var(--shadow-card);
}
.showcase__frame img{width:100%;display:block}
.showcase__frame figcaption{
  position:absolute;
  bottom:0;left:0;right:0;
  padding:14px 16px 12px;
  background:linear-gradient(180deg,transparent,rgba(42,28,40,.7));
  color:#fff;
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-weight:500;
  font-size:13px;
  line-height:1.35;
  text-align:center;
  text-shadow:0 1px 4px rgba(0,0,0,.3);
}


/* ============ Colors strip ============ */
.colors{position:relative}
.colors__viewport{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  padding:6px 0 14px;
}
.color-card{
  background:#fff;
  border:1px solid rgba(255,255,255,.95);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:0 8px 22px -10px rgba(180,90,120,.18);
  transition:transform .35s ease,box-shadow .35s ease;
  cursor:pointer;
  text-align:center;
  padding-bottom:10px;
  width:100%;
}
.color-card:active{transform:scale(.97)}
.color-card.selected{box-shadow:0 0 0 2px var(--pink-mid),0 12px 26px -10px rgba(230,130,165,.4)}
.color-card__media{display:block;aspect-ratio:3/4;overflow:hidden;background:var(--cream-warm)}
.color-card__media img{width:100%;height:100%;object-fit:cover}
.color-card__dot{
  display:inline-block;width:10px;height:10px;border-radius:50%;
  background:var(--dot,#000);border:1px solid rgba(0,0,0,.08);
  margin:8px 6px 4px;
  vertical-align:-1px;
}
.color-card__label{
  display:inline-block;
  font-family:'Montserrat',sans-serif;
  font-weight:600;
  font-size:12px;
  color:var(--aubergine);
  letter-spacing:-.005em;
}

/* ============ Sizes ============ */
.sizecard{
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.9);
  border-radius:var(--radius-lg);
  padding:14px;
  box-shadow:var(--shadow-card);
  overflow:hidden;
}
.sizetable{
  width:100%;border-collapse:collapse;
  font-size:13px;
}
.sizetable th{
  text-align:left;
  font-family:'Playfair Display',serif;
  font-weight:600;
  font-size:13px;
  color:var(--rose-dark);
  padding:10px 8px;
  border-bottom:1px solid var(--line);
}
.sizetable td{
  padding:10px 8px;
  border-bottom:1px solid var(--line);
  color:var(--plum);
}
.sizetable tr:last-child td{border-bottom:none}
.size-note{
  margin-top:10px;
  font-size:12px;
  color:var(--muted);
  text-align:center;
  font-style:italic;
}

/* ============ Reviews ============ */
.reviews-strip{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding:6px 0 14px;
}
.review-card{
  display:grid;
  grid-template-columns:96px 1fr;
  gap:12px;
  background:rgba(255,255,255,.9);
  backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.9);
  border-radius:var(--radius-lg);
  padding:12px;
  box-shadow:var(--shadow-card);
}
.review-card__photo{
  width:96px;height:120px;
  border-radius:var(--radius-md);
  object-fit:cover;
}
.review-card__body{display:flex;flex-direction:column;gap:4px;min-width:0}
.review-card__head{
  display:flex;justify-content:space-between;align-items:flex-start;gap:8px;
}
.review-card__author{
  display:flex;flex-direction:column;gap:1px;
  min-width:0;
}
.review-card__head strong{
  font-family:'Playfair Display',serif;
  font-weight:600;
  font-size:14px;
  color:var(--aubergine);
  line-height:1.15;
}
.review-card__author em{
  font-family:'Onest',sans-serif;
  font-style:normal;
  font-size:11px;
  color:var(--rose);
  font-weight:500;
  letter-spacing:.005em;
}
.review-card__head > span{font-size:11px;color:var(--muted);flex-shrink:0;padding-top:2px}
.review-card__stars{color:var(--gold);font-size:13px;letter-spacing:1px;margin:2px 0}
.review-card__body p{font-size:12.5px;line-height:1.45;color:var(--plum)}

/* ============ Gallery slider ============ */
.gallery{margin-top:32px}
.gallery__viewport{
  position:relative;
  border-radius:var(--radius-xl);
  overflow:hidden;
  box-shadow:var(--shadow-card);
  background:var(--cream-warm);
  aspect-ratio:3/4;
}
.gallery-strip{
  position:relative;
  width:100%;height:100%;
}
.gallery-card{
  position:absolute;
  inset:0;
  margin:0;
  opacity:0;
  transform:scale(1.04);
  transition:opacity .55s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1);
  pointer-events:none;
}
.gallery-card.active{
  opacity:1;
  transform:scale(1);
  pointer-events:auto;
}
.gallery-card img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
}
.gallery-nav{
  position:absolute;top:50%;
  transform:translateY(-50%);
  width:42px;height:42px;
  border:none;border-radius:50%;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(8px);
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--aubergine);cursor:pointer;
  box-shadow:0 4px 14px rgba(0,0,0,.18);
  transition:transform .25s ease,background .25s ease;
  z-index:5;
}
.gallery-nav:hover{background:rgba(255,255,255,.98);transform:translateY(-50%) scale(1.06)}
.gallery-nav:active{transform:translateY(-50%) scale(.95)}
.gallery-nav svg{width:18px;height:18px}
.gallery-nav--prev{left:10px}
.gallery-nav--next{right:10px}
.gallery-dots{
  display:flex;justify-content:center;gap:6px;
  margin-top:14px;
}
.gallery-dot{
  width:6px;height:6px;border-radius:50%;
  background:rgba(166,84,109,.25);
  transition:all .3s ease;
}
.gallery-dot.active{
  width:22px;
  background:var(--pink-mid);
  border-radius:3px;
}
.gallery-current-color{
  margin-top:10px;
  text-align:center;
  font-size:13px;
  color:var(--muted);
}
.gallery-current-color strong{
  color:var(--rose-dark);
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-weight:600;
  font-size:14px;
}

/* ============ Decorative dividers between sections ============ */
.divider{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  margin:8px auto 4px;
  padding:0 24px;
  max-width:340px;
  opacity:0;
  transform:translateY(20px);
  transition:opacity .9s ease,transform .9s ease;
}
.divider.in{opacity:1;transform:translateY(0)}
.divider::before,
.divider::after{
  content:'';
  flex:1;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--line),transparent);
}
.divider__mark{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.divider__mark svg{width:32px;height:32px;display:block}
.divider__quote{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-weight:500;
  font-size:14px;
  color:var(--rose);
  text-align:center;
  letter-spacing:.005em;
  white-space:nowrap;
}

/* ============ Showcase (soft sky editorial) ============ */
.showcase-soft{
  margin-top:8px;
  margin-left:-14px;
  margin-right:-14px;
  padding:18px 18px 22px;
  background:
    radial-gradient(ellipse 90% 50% at 50% 0%, rgba(158,192,219,.32), transparent 65%),
    linear-gradient(180deg, rgba(223,238,250,.85) 0%, rgba(233,241,247,.9) 100%);
  position:relative;
  overflow:hidden;
}
.showcase-soft::before{
  content:'';
  position:absolute;
  top:-30px;left:-30px;
  width:120px;height:120px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(212,165,116,.18),transparent 70%);
  pointer-events:none;
}
.showcase-soft::after{
  content:'';
  position:absolute;
  bottom:-40px;right:-40px;
  width:140px;height:140px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(241,168,189,.22),transparent 70%);
  pointer-events:none;
}
.showcase-soft__head{
  text-align:center;
  margin-bottom:14px;
  position:relative;
  z-index:1;
}
.showcase-soft__kicker{
  display:inline-block;
  font-family:'Montserrat',sans-serif;
  font-size:10.5px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--sky-deep);
  font-weight:700;
  margin-bottom:8px;
  padding:4px 14px;
  background:rgba(255,255,255,.7);
  border:1px solid rgba(255,255,255,.95);
  border-radius:var(--radius-pill);
}
.showcase-soft__title{
  font-family:'Fraunces',serif;
  font-weight:500;
  font-size:24px;
  line-height:1.1;
  letter-spacing:-.02em;
  color:var(--aubergine);
  font-variation-settings:"opsz" 144, "SOFT" 50;
}
.showcase-soft__title em{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-weight:500;
  color:var(--rose);
}
.showcase-soft__sub{
  margin:6px auto 0;
  font-size:12px;
  color:var(--muted);
  line-height:1.5;
  position:relative;
  z-index:1;
  white-space:nowrap;
  letter-spacing:-.005em;
}
.showcase-soft__frame{
  position:relative;
  z-index:1;
  border-radius:var(--radius-xl);
  overflow:hidden;
  box-shadow:0 18px 40px -16px rgba(180,90,120,.35);
}
.showcase-soft__frame img{width:100%;display:block}

/* Legacy dark variant (no longer used but keep CSS in case) */
.showcase-dark{display:none}

/* ============ Sticky bottom CTA ============ */
.sticky-cta{
  position:fixed;
  left:50%;
  bottom:14px;
  transform:translateX(-50%) translateY(20px);
  z-index:80;
  opacity:0;
  pointer-events:none;
  transition:opacity .35s ease,transform .35s cubic-bezier(.2,.8,.2,1);
}
.sticky-cta.show{
  opacity:1;
  pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}
.sticky-cta__btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:14px 28px;
  background:linear-gradient(135deg,#f9c8d4 0%,#f1a8bd 55%,#e88fab 100%);
  color:#fff;
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  font-size:15px;
  letter-spacing:-.005em;
  border-radius:var(--radius-pill);
  text-decoration:none;
  white-space:nowrap;
  box-shadow:0 12px 28px -8px rgba(230,130,165,.55),
             0 4px 10px -4px rgba(180,90,120,.25),
             inset 0 1px 0 rgba(255,255,255,.6);
  transition:transform .25s ease,box-shadow .25s ease;
}
.sticky-cta__btn:hover{
  transform:translateY(-1px);
  box-shadow:0 16px 32px -8px rgba(230,130,165,.65),inset 0 1px 0 rgba(255,255,255,.7);
}
.sticky-cta__btn:active{transform:scale(.97)}
.sticky-cta__sep{opacity:.55;font-weight:400;margin:0 -2px}
.sticky-cta__price{font-weight:800;letter-spacing:-.01em}
.sticky-cta__btn .heart{font-size:13px;opacity:.92;margin-left:2px}

/* Add bottom padding to body so content not hidden under sticky bar */
body.has-sticky{padding-bottom:80px}

/* ============ Sky-blue accents (sprinkled across) ============ */
.section-title em.sky{color:var(--sky-deep)}
.kicker.kicker--sky{
  color:var(--sky-deep);
  background:rgba(158,192,219,.22);
}

/* Pulse on dot indicators (uniform pink) */
.gallery-dot.active{background:var(--pink-mid)}

/* Why-card "Деталі" section uses sky-blue dots for variety */
.why-card--details .why-icon--dot{
  background:linear-gradient(135deg,var(--sky-mid),var(--sky-deep));
  box-shadow:0 0 0 4px rgba(158,192,219,.25);
}
.order{margin-top:14px;padding:0 4px}
.colorpicker{
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.9);
  border-radius:var(--radius-lg);
  padding:14px;
  margin-bottom:14px;
  box-shadow:var(--shadow-card);
}
.colorpicker__label{
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-weight:600;
  font-size:14px;
  color:var(--rose-dark);
  margin-bottom:10px;
}
.colorpicker__pills{display:flex;flex-wrap:wrap;gap:6px}
.colorpicker__pills label{cursor:pointer}
.colorpicker__pills input{position:absolute;opacity:0;pointer-events:none}
.colorpicker__pills span{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 12px;
  border-radius:var(--radius-pill);
  background:#fff;
  border:1px solid var(--line);
  font-size:12px;
  font-weight:600;
  color:var(--plum);
  transition:all .25s ease;
}
.colorpicker__pills i{
  display:inline-block;width:11px;height:11px;border-radius:50%;
  background:var(--dot,#000);border:1px solid rgba(0,0,0,.08);
}
.colorpicker__pills input:checked + span{
  background:linear-gradient(135deg,#fde7ec,#f9c8d4);
  border-color:var(--pink-mid);
  color:var(--rose-dark);
  box-shadow:0 4px 10px -4px rgba(230,130,165,.4);
}

.order__form{
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.9);
  border-radius:var(--radius-lg);
  padding:18px;
  display:flex;flex-direction:column;gap:12px;
  box-shadow:var(--shadow-card);
}
.order__form label{
  font-family:'Montserrat',sans-serif;
  font-weight:600;
  font-size:11px;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--muted);
  display:flex;flex-direction:column;gap:6px;
}
.order__form input[type=text],
.order__form input[type=tel]{
  width:100%;
  padding:14px 16px;
  border:1px solid var(--line);
  border-radius:var(--radius-pill);
  background:rgba(255,255,255,.95);
  font-family:'Onest',sans-serif;
  font-size:15px;
  font-weight:500;
  color:var(--aubergine);
  letter-spacing:0;
  transition:border-color .25s ease,box-shadow .25s ease;
  outline:none;
  text-transform:none;
}
.order__form input::placeholder{color:#bba8ac;font-weight:400}
.order__form input:focus{
  border-color:var(--pink-mid);
  box-shadow:0 0 0 3px rgba(241,168,189,.25);
}
.order__form .btn--primary{margin-top:6px}

/* ============ Footer ============ */
.footer{
  margin-top:36px;
  padding:24px 14px 8px;
  text-align:center;
  border-top:1px dashed var(--line);
  font-size:12px;
  color:var(--muted);
}
.footer__item{margin-bottom:8px}
.footer__item span{display:block;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--rose);font-weight:600;margin-bottom:2px}
.footer__item strong{font-weight:600;color:var(--plum)}
.footer__copy{margin-top:14px;font-size:11px;font-style:italic;color:var(--muted)}
.footer .doclinks a{color:var(--rose);text-decoration:underline;font-size:11px}

/* ============ Responsive: extra small ============ */
@media (max-width:360px){
  .hero__lead{font-size:11px}
}
@media (max-width:340px){
  .hero__title{font-size:24px}
  .hero__title-script{font-size:clamp(22px,7.5vw,28px)}
  .hero__lead{white-space:normal;font-size:12px}
  .benefit-card__title{font-size:13px}
  .benefit-card__desc{font-size:10.5px}
}