:root{
  --bg:#fbf4f3;
  --bg-2:#fffaf8;
  --surface:#ffffff;
  --surface-soft:#fff7f5;
  --surface-rose:#f2d8de;
  --text:#211619;
  --muted:#76666a;
  --line:rgba(54,24,31,.1);
  --accent:#c24872;
  --accent-2:#e97899;
  --accent-dark:#7c3a51;
  --sale-dark:#201518;
  --gold:#d6a33b;
  --radius-2xl:30px;
  --radius-xl:24px;
  --radius-lg:20px;
  --radius-md:16px;
  --shadow:0 14px 34px rgba(55,25,34,.1);
}

*{box-sizing:border-box}

html{scroll-behavior:smooth}

body{
  margin:0;
  min-width:320px;
  background:
    radial-gradient(circle at 50% -8%, rgba(194,72,114,.13), transparent 34%),
    linear-gradient(180deg, #fff9f7 0%, #fbf4f3 46%, #f6eeef 100%);
  color:var(--text);
  font-family:"Onest", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

img,
video{
  display:block;
  max-width:100%;
  height:auto;
}

button,
input{
  font:inherit;
}

a{
  color:inherit;
}

main.landing{
  width:min(100%, 430px);
  margin:0 auto;
  padding:18px 14px 36px;
}

.hero{
  text-align:center;
  overflow:hidden;
  border-radius:32px;
  background:rgba(255,255,255,.92);
  box-shadow:0 18px 38px rgba(55,25,34,.12);
}

.hero__headline{
  padding:22px 16px 16px;
  border-radius:32px 32px 0 0;
  background:
    linear-gradient(145deg, rgba(255,255,255,.12), transparent 42%),
    linear-gradient(180deg, #8f4560 0%, #6c3047 100%);
  color:#fff;
}

.hero__subcard{
  padding:10px 14px 12px;
  border-radius:0;
  background:#f8f0f1;
}

.hero__title{
  max-width:330px;
  margin:0 auto;
  font-family:"Montserrat", system-ui, sans-serif;
  font-size:28px;
  line-height:1.02;
  font-weight:900;
  letter-spacing:0;
}

.hero__lead{
  max-width:300px;
  margin:0 auto;
  color:var(--text);
  font-size:12px;
  line-height:1.3;
  font-weight:800;
}

.hero__chips{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:8px;
  margin-top:14px;
}

.hero__chips span{
  padding:9px 12px;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--line);
  font-size:11px;
  font-weight:700;
  box-shadow:0 8px 20px rgba(55,25,34,.06);
}

.hero__visual{
  position:relative;
  margin:0;
  overflow:hidden;
  border-radius:0 0 32px 32px;
  border:0;
  background:var(--surface);
}

.hero__visual img{
  width:100%;
  aspect-ratio:1 / 1.18;
  object-fit:cover;
  object-position:center 22%;
}

.hero__sale{
  position:absolute;
  top:12px;
  right:12px;
  min-height:24px;
  padding:5px 9px;
  border-radius:999px;
  background:linear-gradient(180deg, #ef7a9b, var(--accent));
  color:#fff;
  font-size:10px;
  font-weight:900;
  letter-spacing:0;
  box-shadow:0 10px 22px rgba(194,72,114,.25);
}

.hero__price{
  position:absolute;
  bottom:12px;
  border-radius:16px;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  box-shadow:0 10px 24px rgba(0,0,0,.16);
}

.hero__price small{
  display:block;
  margin-bottom:3px;
  font-size:8px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0;
}

.hero__price strong{
  display:block;
  font-family:"Montserrat", system-ui, sans-serif;
  font-size:17px;
  line-height:1;
  font-weight:900;
}

.hero__price--old{
  left:12px;
  padding:8px 10px;
  background:rgba(255,255,255,.92);
  color:#81757b;
}

.hero__price--old strong{
  font-size:13px;
  text-decoration:line-through;
}

.hero__price--new{
  right:12px;
  min-width:112px;
  padding:9px 11px 10px;
  background:linear-gradient(135deg, rgba(33,22,25,.96), rgba(108,48,71,.94));
  color:#fff;
  text-align:left;
}

.offer-box{
  margin-top:14px;
  padding:14px 14px 8px;
  border-radius:26px;
  background:rgba(255,255,255,.86);
  border:1px solid rgba(255,255,255,.9);
  box-shadow:var(--shadow);
  text-align:left;
}

.offer-box__heading{
  margin-bottom:8px;
  font-family:"Montserrat", system-ui, sans-serif;
  font-size:16px;
  font-weight:800;
}

.offer-box__row{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  gap:8px 12px;
  align-items:center;
  padding:14px 0;
  border-top:1px solid rgba(62,31,40,.08);
}

.offer-box__row:first-of-type{
  border-top:0;
}

.offer-box__row span{
  display:flex;
  align-items:baseline;
  gap:6px;
  min-width:0;
  white-space:nowrap;
  color:var(--muted);
  font-size:11px;
  line-height:1.2;
}

.offer-box__row strong{
  font-size:15px;
  font-weight:800;
}

.offer-box__qty{
  color:var(--text);
  font-size:15px;
  font-weight:800;
}

.offer-box__meta{
  font-size:11px;
  color:var(--muted);
}

.offer-box__discount{
  color:var(--text);
  font-weight:800;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:0;
  border-radius:999px;
  text-decoration:none;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, opacity .18s ease;
}

.btn:hover{
  transform:translateY(-1px);
}

.btn:disabled{
  opacity:.72;
  cursor:default;
}

.btn--primary{
  background:linear-gradient(180deg, var(--accent-2), var(--accent));
  color:#fff;
  box-shadow:0 14px 28px rgba(194,72,114,.24);
}

.btn--primary{
  width:100%;
  min-height:58px;
  margin-top:14px;
  font-family:"Montserrat", system-ui, sans-serif;
  font-size:15px;
  font-weight:800;
}

.hero__note{
  margin:10px auto 0;
  max-width:340px;
  color:#7a6970;
  font-size:13px;
  line-height:1.45;
}

.section{
  margin-top:24px;
}

.section-intro{
  margin-bottom:12px;
}

.section-kicker{
  margin:0 0 6px;
  color:var(--accent-dark);
  font-size:11px;
  font-weight:800;
  letter-spacing:0;
  text-transform:uppercase;
}

.section-title{
  margin:0;
  font-family:"Montserrat", system-ui, sans-serif;
  font-size:30px;
  line-height:1.1;
  font-weight:800;
  letter-spacing:0;
}

.section-title--accent{
  color:var(--accent-dark);
}

.section-sub{
  margin:8px 0 0;
  color:var(--muted);
  font-size:14px;
  line-height:1.5;
}

.gallery__viewport{
  position:relative;
  overflow:hidden;
  border-radius:26px;
  isolation:isolate;
}

.gallery-nav{
  position:absolute;
  top:50%;
  z-index:12;
  display:grid;
  place-items:center;
  width:36px;
  height:36px;
  padding:0;
  border:1px solid rgba(62,31,40,.08);
  border-radius:50%;
  background:rgba(255,255,255,.46);
  color:var(--text);
  box-shadow:0 8px 18px rgba(55,25,34,.1);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  transform:translateY(-50%);
  cursor:pointer;
  pointer-events:auto;
  touch-action:manipulation;
}

.gallery-nav:disabled{
  opacity:.38;
}

.gallery-nav svg{
  width:18px;
  height:18px;
}

.gallery-nav--prev{
  left:12px;
}

.gallery-nav--next{
  right:12px;
}

.gallery-strip{
  position:relative;
  z-index:1;
  display:flex;
  width:100%;
  padding:0;
  transition:transform .28s ease;
}

.gallery-card{
  flex:0 0 100%;
  margin:0;
  overflow:hidden;
  border-radius:26px;
  background:rgba(255,255,255,.92);
}

.gallery-card.selected{
  box-shadow:0 0 0 2px rgba(163,38,82,.2), var(--shadow);
}

.gallery-card img{
  width:100%;
  aspect-ratio:.78 / 1;
  object-fit:cover;
  object-position:center 18%;
  pointer-events:none;
}

.video__frame{
  position:relative;
  margin-inline:-4px;
  overflow:hidden;
  border-radius:var(--radius-2xl);
  background:#0e0a0b;
  box-shadow:var(--shadow);
}

.video__frame video{
  width:100%;
  aspect-ratio:1 / 1;
  object-fit:cover;
}

.video__toggle{
  position:absolute;
  right:12px;
  bottom:12px;
  width:48px;
  height:48px;
  border:none;
  border-radius:50%;
  background:rgba(255,255,255,.9);
  color:var(--accent);
  box-shadow:0 10px 22px rgba(0,0,0,.18);
}

.story__lead{
  margin:10px 0 0;
  color:var(--text);
  font-size:13px;
  line-height:1.4;
  font-weight:700;
}

.story-panel{
  display:grid;
  gap:14px;
  padding:16px 14px;
  border-radius:26px;
  background:rgba(255,255,255,.9);
  border:1px solid rgba(255,255,255,.94);
  box-shadow:var(--shadow);
}

.story-panel + .story-panel{
  margin-top:14px;
}

.story-check,
.story-dot{
  display:grid;
  grid-template-columns:40px minmax(0, 1fr);
  gap:8px;
  align-items:flex-start;
}

.story-check__icon{
  display:grid;
  place-items:center;
  width:34px;
  height:34px;
  border-radius:50%;
  background:rgba(163,38,82,.12);
  color:var(--accent);
  font-size:20px;
  line-height:1;
  font-weight:900;
}

.story-check p,
.story-dot p{
  margin:0;
  color:var(--text);
  font-size:12px;
  line-height:1.4;
}

.story-panel__title{
  color:var(--text);
  font-size:15px;
  line-height:1.25;
  font-weight:800;
}

.story-dot__icon{
  width:14px;
  height:14px;
  margin:4px 0 0 10px;
  border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 5px rgba(163,38,82,.12);
}

.story__cta{
  margin:14px 0 0;
}

.showcase{
  margin:12px 0 0;
  overflow:hidden;
  border-radius:var(--radius-2xl);
  background:var(--surface);
  box-shadow:var(--shadow);
}

.showcase img{
  width:100%;
  height:auto;
  object-fit:contain;
}

.showcase figcaption{
  margin:0;
  padding:12px 14px 14px;
  color:var(--muted);
  font-size:13px;
  line-height:1.48;
}

.fit-map{
  padding:10px;
  border-radius:var(--radius-2xl);
  background:
    linear-gradient(145deg, rgba(255,255,255,.92), rgba(255,243,246,.88));
  border:1px solid rgba(255,255,255,.94);
  box-shadow:var(--shadow);
}

.fit-map__points{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px;
}

.fit-point{
  min-width:0;
  padding:15px 14px 16px;
  border-radius:22px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.82);
  box-shadow:0 12px 28px rgba(88,38,54,.08);
}

.fit-point__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:8px;
}

.fit-point__num{
  display:inline-flex;
  color:var(--accent);
  font-size:11px;
  line-height:1;
  font-weight:900;
}

.fit-point__icon{
  display:grid;
  place-items:center;
  width:58px;
  height:58px;
  flex:0 0 58px;
  overflow:hidden;
  border-radius:20px;
  background:#fff;
  border:3px solid #fde1e8;
  box-shadow:0 10px 22px rgba(88,38,54,.13);
}

.fit-point__icon img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}

.fit-point strong{
  display:block;
  color:var(--text);
  font-size:13px;
  line-height:1.2;
  font-weight:900;
}

.fit-point p{
  margin:6px 0 0;
  color:var(--muted);
  font-size:12px;
  line-height:1.35;
  font-weight:650;
}

.color-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px;
}

.color-card{
  appearance:none;
  -webkit-appearance:none;
  padding:0;
  border:1px solid rgba(255,255,255,.86);
  border-radius:24px;
  background:var(--surface);
  overflow:hidden;
  color:var(--text);
  text-align:left;
  box-shadow:var(--shadow);
}

.color-card__media{
  display:block;
}

.color-card__media img{
  width:100%;
  aspect-ratio:.88 / 1.12;
  object-fit:cover;
}

.color-card__label{
  display:block;
  padding:11px 10px 13px;
  text-align:center;
  font-size:13px;
  font-weight:800;
}

.color-card[data-color="Марсала"] .color-card__label{
  color:#5e2542;
}

.color-card[data-color="Темно-синій"] .color-card__label{
  color:#394476;
}

.color-card[data-color="Чорний"] .color-card__label{
  color:#171515;
}

.color-card[data-color="Пудрова троянда"] .color-card__label{
  color:#9c6070;
}

.color-card[data-color="Рожевий"] .color-card__label{
  color:#c84f84;
}

.color-card[data-color="Червоний"] .color-card__label{
  color:#bd1f36;
}

.color-card.selected{
  box-shadow:0 0 0 2px rgba(163,38,82,.2), var(--shadow);
}

.reviews-summary{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  margin-bottom:14px;
  padding:15px 12px;
  border-radius:26px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.94);
  box-shadow:var(--shadow);
}

.reviews-summary__stars{
  color:#ffad00;
  font-size:22px;
  line-height:1;
  letter-spacing:1px;
  text-shadow:0 8px 18px rgba(255,173,0,.18);
}

.reviews-summary__score{
  display:flex;
  align-items:baseline;
  gap:6px;
  color:var(--text);
  font-family:"Montserrat", system-ui, sans-serif;
  font-size:16px;
  line-height:1;
  font-weight:900;
}

.reviews-summary__score strong,
.reviews-summary__score b{
  font-weight:900;
}

.reviews__list{
  display:grid;
  gap:14px;
}

.review-card{
  position:relative;
  overflow:hidden;
  padding:18px 16px 19px;
  border-radius:28px;
  background:
    radial-gradient(circle at 9% 10%, rgba(226,130,157,.12), transparent 25%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,252,251,.94));
  border:1px solid rgba(255,255,255,.96);
  box-shadow:0 18px 36px rgba(55,25,34,.08);
}

.review-card__top{
  display:grid;
  grid-template-columns:54px minmax(0, 1fr) auto;
  gap:11px;
  align-items:center;
}

.review-card__avatar{
  display:grid;
  place-items:center;
  width:54px;
  height:54px;
  border-radius:50%;
  color:#fff;
  background:
    linear-gradient(145deg, rgba(255,255,255,.2), transparent 42%),
    linear-gradient(135deg, #7c3a51, #d95a86);
  font-family:"Montserrat", system-ui, sans-serif;
  font-size:21px;
  line-height:1;
  font-weight:900;
  box-shadow:0 12px 22px rgba(124,58,81,.22);
}

.review-card:nth-child(3n+2) .review-card__avatar{
  background:
    linear-gradient(145deg, rgba(255,255,255,.2), transparent 42%),
    linear-gradient(135deg, #2b2532, #6f5871);
}

.review-card:nth-child(3n+3) .review-card__avatar{
  background:
    linear-gradient(145deg, rgba(255,255,255,.2), transparent 42%),
    linear-gradient(135deg, #9a5f70, #e88ca7);
}

.review-card__identity{
  min-width:0;
}

.review-card__identity strong{
  display:block;
  color:var(--text);
  font-family:"Montserrat", system-ui, sans-serif;
  font-size:16px;
  line-height:1.06;
  font-weight:900;
}

.review-card__identity span{
  display:block;
  margin-top:4px;
  color:#71727a;
  font-size:15px;
  line-height:1;
  font-weight:900;
}

.review-card__date{
  align-self:start;
  padding-top:5px;
  color:#9aa0aa;
  font-family:"Montserrat", system-ui, sans-serif;
  font-size:13px;
  line-height:1;
  font-weight:900;
  white-space:nowrap;
}

.review-card__stars{
  margin-top:12px;
  color:var(--gold);
  font-size:13px;
  letter-spacing:0;
}

.review-card p{
  margin:9px 0 0;
  color:var(--text);
  font-size:15px;
  line-height:1.48;
  letter-spacing:-.01em;
}

.sizecard{
  overflow:hidden;
  border-radius:26px;
  background:rgba(255,255,255,.9);
  border:1px solid rgba(255,255,255,.94);
  box-shadow:var(--shadow);
}

.sizetable{
  width:100%;
  border-collapse:collapse;
}

.sizetable thead th{
  padding:14px 12px;
  background:linear-gradient(135deg, #3b252b, #6c3047);
  color:#fff;
  font-size:12px;
  font-weight:800;
  text-align:left;
}

.sizetable tbody td{
  padding:13px 12px;
  border-top:1px solid rgba(62,31,40,.08);
  font-size:14px;
  font-weight:700;
}

.sizetable tbody tr:nth-child(even) td{
  background:#fff5f5;
}

.size-note{
  margin:10px 0 0;
  color:var(--muted);
  font-size:13px;
  line-height:1.45;
}

.order__summary{
  padding:18px 16px;
  border-radius:24px;
  background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,244,247,.92));
  border:1px solid rgba(255,255,255,.92);
  box-shadow:var(--shadow);
}

.order__summary-line{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  font-size:13px;
  font-weight:700;
}

.order__summary-line strong{
  color:var(--accent-dark);
  font-size:15px;
  font-weight:800;
}

.colorpicker{
  margin-top:12px;
  padding:14px;
  border-radius:24px;
  background:rgba(255,255,255,.9);
  border:1px solid rgba(255,255,255,.92);
  box-shadow:var(--shadow);
}

.colorpicker__label{
  margin-bottom:10px;
  font-size:13px;
  font-weight:800;
}

.colorpicker__pills{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.colorpicker label{
  position:relative;
  display:inline-flex;
}

.colorpicker input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.colorpicker span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:38px;
  padding:8px 12px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(62,31,40,.08);
  font-size:13px;
  font-weight:700;
  transition:border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}

.colorpicker span i{
  width:12px;
  height:12px;
  border-radius:50%;
  background:var(--dot);
  border:1px solid rgba(0,0,0,.1);
}

.colorpicker input:checked + span{
  border-color:rgba(163,38,82,.44);
  box-shadow:0 0 0 3px rgba(163,38,82,.12);
  transform:translateY(-1px);
}

.order__form{
  display:grid;
  gap:12px;
  margin-top:12px;
  padding:16px;
  border-radius:24px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.94);
  box-shadow:var(--shadow);
}

.order__form label{
  display:grid;
  gap:8px;
  font-size:13px;
  font-weight:700;
}

.order__form input[type="text"],
.order__form input[type="tel"]{
  width:100%;
  min-height:52px;
  padding:0 16px;
  border:1px solid rgba(62,31,40,.1);
  border-radius:16px;
  background:#fff;
  color:var(--text);
  font-size:16px;
}

.order__form input::placeholder{
  color:#a19299;
}

.footer{
  margin-top:26px;
  padding:18px 16px 10px;
  border-radius:24px;
  background:rgba(255,255,255,.7);
  color:var(--muted);
  text-align:center;
}

.footer__item + .footer__item{
  margin-top:14px;
}

.footer__item span{
  display:block;
  margin-bottom:5px;
  font-size:11px;
  font-weight:800;
  letter-spacing:0;
  text-transform:uppercase;
}

.footer__item strong,
.footer__item a{
  color:var(--text);
  font-size:14px;
  font-weight:700;
  text-decoration:none;
}

.doclinks{
  margin:16px 0 0;
}

.doclinks a{
  color:var(--accent-dark);
  font-size:13px;
  font-weight:700;
  text-decoration:none;
}

.footer__copy{
  margin:14px 0 0;
  font-size:12px;
}

@media (max-width:370px){
  .hero__title{
    font-size:24px;
  }

  .section-title{
    font-size:27px;
  }

  .gallery__top{
    align-items:center;
  }

  .reviews-summary{
    flex-direction:column;
    gap:7px;
  }

  .reviews-summary__stars{
    font-size:20px;
  }

  .fit-map__points{
    grid-template-columns:1fr;
  }
}
