/* =========================================================
   TOMO SKINCARE — Design System
   Palette: viola pastello / premium
   ========================================================= */

:root {
  /* Colors */
  --plum-900: #2E2140;
  --plum-700: #5A3F8F;
  --violet-500: #8B6FD4;
  --violet-400: #9C84DE;
  --lilac-400: #B79CED;
  --lilac-300: #CDBBF0;
  --lavender-200: #E6DAF7;
  --lavender-100: #F2ECFB;
  --cream: #FAF7FD;
  --white: #FFFFFF;
  --ink: #2A2435;
  --muted: #837A92;
  --line: #ECE5F5;
  --gold: #C9A24B;

  /* Gradients */
  --grad-hero: linear-gradient(135deg, #F3ECFB 0%, #E7DAF7 45%, #D9C6F2 100%);
  --grad-band: linear-gradient(120deg, #E9DDF8 0%, #DCC9F2 100%);
  --grad-violet: linear-gradient(135deg, #9C84DE 0%, #7A5FC4 100%);
  --grad-soft: linear-gradient(135deg, #F6F1FC 0%, #ECE1F8 100%);

  /* Typography */
  --font-display: "Fraunces", "Cormorant Garamond", Georgia, serif;
  --font-body: "Jost", "Helvetica Neue", Arial, sans-serif;

  /* Shape & motion */
  --radius: 18px;
  --radius-lg: 28px;
  --radius-pill: 999px;
  --shadow-sm: 0 4px 18px rgba(90, 63, 143, 0.08);
  --shadow-md: 0 14px 40px rgba(90, 63, 143, 0.12);
  --shadow-lg: 0 30px 70px rgba(90, 63, 143, 0.18);
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-soft: cubic-bezier(0.4, 0, 0.2, 1);

  --container: 1240px;
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--cream);
  line-height: 1.6;
  font-weight: 300;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
ul { list-style: none; }

/* ---------- Typography ---------- */
h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 500; line-height: 1.05; color: var(--plum-900); letter-spacing: -0.3px; font-optical-sizing: auto; }
.hero h1 .accent, .promo-copy h2 .accent, .hero-copy .accent { font-variation-settings: "SOFT" 40, "WONK" 1; }
.h-xl { font-size: clamp(2.8rem, 6vw, 5rem); }
.h-lg { font-size: clamp(2.2rem, 4.4vw, 3.5rem); }
.h-md { font-size: clamp(1.6rem, 3vw, 2.4rem); }
.eyebrow {
  font-family: var(--font-body);
  text-transform: uppercase;
  letter-spacing: 0.32em;
  font-size: 0.72rem;
  font-weight: 500;
  color: var(--violet-500);
}
.lead { font-size: 1.08rem; color: var(--muted); max-width: 56ch; }

/* ---------- Layout helpers ---------- */
.container { width: min(100% - 3rem, var(--container)); margin-inline: auto; }
.section { padding: clamp(4rem, 9vw, 8rem) 0; }
.section--tight { padding: clamp(3rem, 6vw, 5rem) 0; }
.center { text-align: center; }
.grid { display: grid; gap: 1.6rem; }
.stack-sm > * + * { margin-top: 0.6rem; }
.section-head { max-width: 620px; margin: 0 auto clamp(2.4rem, 5vw, 3.6rem); }
.section-head.center { text-align: center; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 0.6rem;
  padding: 0.95rem 1.9rem;
  border-radius: var(--radius-pill);
  font-size: 0.86rem; font-weight: 500; letter-spacing: 0.04em;
  transition: transform 0.4s var(--ease), box-shadow 0.4s var(--ease), background 0.4s var(--ease);
  position: relative; overflow: hidden;
}
.btn .arrow { transition: transform 0.4s var(--ease); }
.btn:hover .arrow { transform: translateX(4px); }
.btn--primary { background: var(--grad-violet); color: #fff; box-shadow: 0 12px 28px rgba(122, 95, 196, 0.35); }
.btn--primary:hover { transform: translateY(-3px); box-shadow: 0 18px 40px rgba(122, 95, 196, 0.45); }
.btn--dark { background: var(--plum-900); color: #fff; }
.btn--dark:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.btn--ghost { background: rgba(255,255,255,0.7); color: var(--plum-900); border: 1px solid var(--line); backdrop-filter: blur(6px); }
.btn--ghost:hover { transform: translateY(-3px); background:#fff; box-shadow: var(--shadow-sm); }
.btn--play { background: rgba(255,255,255,0.65); color: var(--plum-900); border: 1px solid rgba(255,255,255,0.8); backdrop-filter: blur(6px); }
.btn--play .dot { display:grid; place-items:center; width:26px; height:26px; border-radius:50%; background: var(--grad-violet); color:#fff; font-size:0.6rem; }
.link-underline { position: relative; font-size: 0.82rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--plum-700); }
.link-underline::after { content:""; position:absolute; left:0; bottom:-4px; width:100%; height:1px; background: var(--violet-500); transform: scaleX(0); transform-origin: right; transition: transform 0.4s var(--ease); }
.link-underline:hover::after { transform: scaleX(1); transform-origin: left; }

/* =========================================================
   HEADER
   ========================================================= */
.header {
  position: fixed; inset: 0 0 auto 0; z-index: 100;
  padding: 1.2rem 0;
  transition: padding 0.4s var(--ease), background 0.4s var(--ease), box-shadow 0.4s var(--ease);
}
.header.scrolled {
  background: rgba(250, 247, 253, 0.82);
  backdrop-filter: blur(14px);
  padding: 0.7rem 0;
  box-shadow: 0 1px 0 var(--line), var(--shadow-sm);
}
.nav { display: flex; align-items: center; justify-content: space-between; }
.brand { font-family: var(--font-display); font-size: 1.65rem; font-weight: 600; letter-spacing: 0.42em; padding-left: 0.42em; color: var(--plum-900); }
.brand small { display:block; font-family: var(--font-body); font-size: 0.5rem; letter-spacing: 0.5em; font-weight: 400; color: var(--muted); margin-top: -2px; padding-left: 0.5em; }
.nav-links { display: flex; gap: 2.2rem; }
.nav-links a { font-size: 0.86rem; letter-spacing: 0.06em; color: var(--ink); position: relative; padding: 0.2rem 0; }
.nav-links a::after { content:""; position:absolute; left:0; bottom:-2px; width:100%; height:1.5px; background: var(--violet-500); transform: scaleX(0); transform-origin:right; transition: transform 0.4s var(--ease); }
.nav-links a:hover::after, .nav-links a.active::after { transform: scaleX(1); transform-origin:left; }
.nav-actions { display: flex; align-items: center; gap: 1.3rem; }
.icon-btn { width: 40px; height: 40px; display:grid; place-items:center; border-radius:50%; transition: background 0.3s var(--ease), transform 0.3s var(--ease); color: var(--plum-900); }
.icon-btn:hover { background: var(--lavender-200); transform: translateY(-2px); }
.cart-btn { position: relative; }
.cart-count { position:absolute; top:2px; right:2px; min-width:17px; height:17px; padding:0 4px; border-radius:50%; background: var(--violet-500); color:#fff; font-size:0.62rem; display:grid; place-items:center; font-weight:500; }
.burger { display:none; flex-direction:column; gap:5px; width:40px; height:40px; align-items:center; justify-content:center; }
.burger span { width:22px; height:1.6px; background: var(--plum-900); transition: 0.3s var(--ease); }

/* =========================================================
   HERO
   ========================================================= */
.hero { position: relative; padding-top: 9rem; padding-bottom: 4rem; overflow: hidden; }
.hero::before {
  content:""; position:absolute; inset:0; z-index:-2;
  background: var(--grad-hero);
}
.hero-blob { position:absolute; border-radius:50%; filter: blur(60px); z-index:-1; opacity:0.6; }
.hero-blob.b1 { width:420px; height:420px; background:#D6BEF2; top:-120px; right:-80px; animation: float 14s var(--ease-soft) infinite; }
.hero-blob.b2 { width:340px; height:340px; background:#C9B0EE; bottom:-120px; left:-60px; animation: float 18s var(--ease-soft) infinite reverse; }
.hero-grid { display:grid; grid-template-columns: 1.05fr 1fr; align-items:center; gap: 2rem; }
.hero-copy { max-width: 540px; }
.hero h1 .accent { color: var(--violet-500); font-style: italic; }
.hero p { margin: 1.4rem 0 2.2rem; }
.hero-cta { display:flex; gap:1rem; align-items:center; flex-wrap:wrap; }
.hero-trust { display:flex; gap:2rem; margin-top: 3rem; flex-wrap:wrap; }
.hero-trust .t { display:flex; gap:0.7rem; align-items:center; }
.hero-trust .t b { font-size:0.92rem; color:var(--plum-900); font-weight:500; display:block; }
.hero-trust .t span { font-size:0.74rem; color:var(--muted); }
.hero-trust .ic { width:38px; height:38px; border-radius:50%; background:#fff; display:grid; place-items:center; box-shadow: var(--shadow-sm); color: var(--violet-500); }
.hero-media { position: relative; }
.hero-media .frame { position:relative; border-radius: var(--radius-lg); overflow:hidden; box-shadow: var(--shadow-lg); aspect-ratio: 4/4.6; }
.hero-media img { width:100%; height:100%; object-fit:cover; }
.offer-badge {
  position:absolute; top: 6%; right: -3%;
  width: 116px; height: 116px; border-radius:50%;
  background:#fff; box-shadow: var(--shadow-md);
  display:grid; place-items:center; text-align:center;
  animation: spin-slow 18s linear infinite;
}
.offer-badge b { font-family: var(--font-display); font-size: 1.7rem; color: var(--violet-500); display:block; line-height:1; }
.offer-badge span { font-size:0.58rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--muted); }

/* =========================================================
   MARQUEE / TRUST BAR
   ========================================================= */
.marquee { background: var(--plum-900); color:#fff; padding: 1rem 0; overflow:hidden; }
.marquee-track { display:flex; gap:3.5rem; white-space:nowrap; width:max-content; animation: marquee 28s linear infinite; }
.marquee span { font-family: var(--font-display); font-size:1.2rem; letter-spacing:0.1em; opacity:0.92; display:flex; align-items:center; gap:1.2rem; }
.marquee span::after { content:"✶"; color: var(--lilac-400); }

/* =========================================================
   CATEGORIES / COLLECTION CARDS
   ========================================================= */
.cat-grid { grid-template-columns: repeat(4, 1fr); }
.cat-card {
  background:#fff; border-radius: var(--radius); padding: 1.4rem;
  box-shadow: var(--shadow-sm); text-align:center;
  transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease);
}
.cat-card:hover { transform: translateY(-8px); box-shadow: var(--shadow-md); }
.cat-card .thumb { aspect-ratio: 1/1; border-radius: 14px; overflow:hidden; margin-bottom:1rem; background: var(--grad-soft); }
.cat-card .thumb img { width:100%; height:100%; object-fit:cover; transition: transform 0.7s var(--ease); }
.cat-card:hover .thumb img { transform: scale(1.07); }
.cat-card h4 { font-size:1.15rem; }
.cat-card .count { font-size:0.74rem; color:var(--muted); letter-spacing:0.06em; }

/* =========================================================
   PROMO BAND
   ========================================================= */
.promo { background: var(--grad-band); border-radius: var(--radius-lg); overflow:hidden; position:relative; }
.promo-grid { display:grid; grid-template-columns: 1.1fr 1fr; align-items:center; gap:2rem; }
.promo-copy { padding: clamp(2.5rem, 5vw, 4.5rem); }
.promo-copy h2 .accent { color: var(--violet-500); font-style: italic; }
.promo-stats { display:flex; gap:2.5rem; padding: clamp(2rem,4vw,3.5rem); }
.promo-stats .s b { font-family: var(--font-display); font-size: 2.6rem; color: var(--plum-900); display:block; line-height:1; }
.promo-stats .s span { font-size:0.78rem; color: var(--plum-700); letter-spacing:0.05em; }
.promo-media { position:relative; align-self:stretch; min-height: 320px; }
.promo-media img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }

/* =========================================================
   PRODUCT CARDS / BESTSELLERS
   ========================================================= */
.products-head { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:2.4rem; gap:1rem; flex-wrap:wrap; }
.product-grid { grid-template-columns: repeat(4, 1fr); }
.pcard {
  background:#fff; border-radius: var(--radius); overflow:hidden;
  box-shadow: var(--shadow-sm); transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease);
  display:flex; flex-direction:column;
}
.pcard:hover { transform: translateY(-8px); box-shadow: var(--shadow-md); }
.pcard .media { position:relative; aspect-ratio: 1/1.05; background: var(--grad-soft); overflow:hidden; }
.pcard .media img { width:100%; height:100%; object-fit:cover; transition: transform 0.8s var(--ease); }
.pcard:hover .media img { transform: scale(1.06); }
.pcard .wish { position:absolute; top:12px; right:12px; width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,0.85); display:grid; place-items:center; color:var(--plum-700); backdrop-filter:blur(4px); transition: 0.3s var(--ease); }
.pcard .wish:hover { background:#fff; color:var(--violet-500); transform:scale(1.1); }
.pcard .tag { position:absolute; top:12px; left:12px; background: var(--violet-500); color:#fff; font-size:0.62rem; letter-spacing:0.1em; text-transform:uppercase; padding:0.3rem 0.7rem; border-radius: var(--radius-pill); }
.pcard .body { padding: 1.2rem 1.2rem 1.4rem; display:flex; flex-direction:column; gap:0.5rem; flex:1; }
.pcard .rate { display:flex; align-items:center; gap:0.4rem; font-size:0.74rem; color:var(--muted); }
.pcard .rate .stars { color: var(--gold); letter-spacing:1px; }
.pcard h4 { font-size:1.18rem; }
.pcard .price { margin-top:auto; display:flex; align-items:baseline; gap:0.6rem; }
.pcard .price .now { font-size:1.1rem; font-weight:500; color: var(--plum-900); font-family: var(--font-body); }
.pcard .price .was { font-size:0.85rem; color:var(--muted); text-decoration: line-through; }
.pcard .add { margin-top:0.9rem; width:100%; justify-content:center; }

/* =========================================================
   TESTIMONIALS
   ========================================================= */
.testi-grid { grid-template-columns: repeat(3, 1fr); }
.testi {
  background:#fff; border-radius: var(--radius); padding: 2rem;
  box-shadow: var(--shadow-sm); position:relative;
}
.testi .stars { color: var(--gold); letter-spacing:2px; font-size:0.85rem; margin-bottom:0.8rem; }
.testi p { font-size:0.96rem; color:var(--ink); font-weight:300; }
.testi .who { margin-top:1.4rem; display:flex; align-items:center; gap:0.8rem; }
.testi .who .av { width:42px; height:42px; border-radius:50%; background: var(--grad-violet); color:#fff; display:grid; place-items:center; font-weight:500; }
.testi .who b { font-size:0.9rem; font-weight:500; display:block; color:var(--plum-900); }
.testi .who span { font-size:0.74rem; color:var(--muted); }

/* =========================================================
   INGREDIENTS / FEATURE STRIP
   ========================================================= */
.features { grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.feature { text-align:center; padding: 1.5rem; }
.feature .ic { width:64px; height:64px; margin:0 auto 1.2rem; border-radius:50%; background: var(--grad-soft); display:grid; place-items:center; color: var(--violet-500); }
.feature h4 { font-size:1.25rem; margin-bottom:0.5rem; }
.feature p { font-size:0.9rem; color:var(--muted); }

/* =========================================================
   NEWSLETTER
   ========================================================= */
.newsletter { background: var(--grad-violet); border-radius: var(--radius-lg); padding: clamp(2.5rem,6vw,5rem); text-align:center; color:#fff; position:relative; overflow:hidden; }
.newsletter h2 { color:#fff; }
.newsletter p { color: rgba(255,255,255,0.85); max-width: 48ch; margin: 1rem auto 2rem; }
.news-form { display:flex; gap:0.6rem; max-width: 460px; margin:0 auto; }
.news-form input { flex:1; padding: 0.95rem 1.3rem; border-radius: var(--radius-pill); border:none; font-family:inherit; font-size:0.9rem; }
.news-form button { background: var(--plum-900); color:#fff; }
.news-form button:hover { background: #fff; color: var(--plum-900); }

/* =========================================================
   FOOTER
   ========================================================= */
.footer { background: var(--plum-900); color: rgba(255,255,255,0.78); padding: clamp(3.5rem,6vw,5rem) 0 2rem; }
.footer-grid { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap:2.5rem; }
.footer .brand { color:#fff; }
.footer .brand small { color: rgba(255,255,255,0.6); }
.footer h5 { font-family:var(--font-body); font-size:0.82rem; letter-spacing:0.16em; text-transform:uppercase; color:#fff; margin-bottom:1.2rem; font-weight:500; }
.footer a { font-size:0.9rem; transition: color 0.3s var(--ease); }
.footer a:hover { color:#fff; }
.footer .links li { margin-bottom:0.7rem; }
.footer p.sm { font-size:0.88rem; margin-top:1rem; line-height:1.8; }
.socials { display:flex; gap:0.7rem; margin-top:1.2rem; }
.socials a { width:38px; height:38px; border-radius:50%; background: rgba(255,255,255,0.08); display:grid; place-items:center; color:#fff; transition: 0.3s var(--ease); }
.socials a:hover { background: var(--violet-500); transform: translateY(-3px); }
.footer-bottom { margin-top:3rem; padding-top:1.6rem; border-top:1px solid rgba(255,255,255,0.12); display:flex; justify-content:space-between; font-size:0.8rem; flex-wrap:wrap; gap:0.6rem; }

/* =========================================================
   COLLECTION PAGE
   ========================================================= */
.page-hero { padding: 9rem 0 3rem; background: var(--grad-hero); text-align:center; position:relative; overflow:hidden; }
.page-hero .breadcrumb { font-size:0.78rem; letter-spacing:0.1em; color:var(--muted); margin-bottom:0.8rem; }
.page-hero p { margin:1rem auto 0; max-width:52ch; }
.toolbar { display:flex; justify-content:space-between; align-items:center; margin-bottom:2.4rem; flex-wrap:wrap; gap:1rem; }
.filters { display:flex; gap:0.6rem; flex-wrap:wrap; }
.chip { padding:0.5rem 1.2rem; border-radius:var(--radius-pill); font-size:0.8rem; background:#fff; border:1px solid var(--line); color:var(--plum-700); transition:0.3s var(--ease); }
.chip:hover, .chip.active { background: var(--violet-500); color:#fff; border-color:var(--violet-500); }
.select { padding:0.6rem 1.1rem; border-radius:var(--radius-pill); border:1px solid var(--line); background:#fff; font-family:inherit; font-size:0.82rem; color:var(--plum-700); }
.collection-grid { grid-template-columns: repeat(3, 1fr); }

/* =========================================================
   PRODUCT (LANDING) PAGE
   ========================================================= */
.pdp { padding-top: 8rem; }
.pdp-grid { display:grid; grid-template-columns: 1.05fr 1fr; gap: clamp(2rem,5vw,4rem); align-items:flex-start; }
.gallery .main { border-radius: var(--radius-lg); overflow:hidden; box-shadow: var(--shadow-md); aspect-ratio: 1/1.05; background: var(--grad-soft); }
.gallery .main img { width:100%; height:100%; object-fit:cover; }
.thumbs { display:flex; gap:0.8rem; margin-top:1rem; }
.thumbs button { width:78px; height:78px; border-radius:14px; overflow:hidden; border:2px solid transparent; background: var(--grad-soft); transition:0.3s var(--ease); }
.thumbs button.active, .thumbs button:hover { border-color: var(--violet-500); }
.thumbs img { width:100%; height:100%; object-fit:cover; }
.pdp-info .breadcrumb { font-size:0.76rem; color:var(--muted); letter-spacing:0.08em; margin-bottom:1rem; }
.pdp-info h1 { margin:0.4rem 0 0.8rem; }
.pdp-rate { display:flex; align-items:center; gap:0.6rem; font-size:0.84rem; color:var(--muted); margin-bottom:1.2rem; }
.pdp-rate .stars { color: var(--gold); letter-spacing:1.5px; }
.pdp-price { display:flex; align-items:baseline; gap:0.9rem; margin-bottom:1.4rem; }
.pdp-price .now { font-size:1.9rem; font-family:var(--font-display); color:var(--plum-900); }
.pdp-price .was { font-size:1.05rem; color:var(--muted); text-decoration:line-through; }
.pdp-price .save { font-size:0.72rem; background:var(--lavender-200); color:var(--plum-700); padding:0.25rem 0.7rem; border-radius:var(--radius-pill); letter-spacing:0.05em; }
.pdp-desc { color:var(--muted); margin-bottom:1.6rem; }
.pdp-benefits { display:flex; flex-direction:column; gap:0.8rem; margin-bottom:1.8rem; }
.pdp-benefits li { display:flex; gap:0.7rem; align-items:flex-start; font-size:0.92rem; }
.pdp-benefits .ic { color: var(--violet-500); flex:none; margin-top:2px; }
.qty-row { display:flex; gap:1rem; align-items:center; margin-bottom:1.4rem; }
.qty { display:flex; align-items:center; border:1px solid var(--line); border-radius:var(--radius-pill); overflow:hidden; }
.qty button { width:44px; height:48px; font-size:1.2rem; color:var(--plum-700); transition: background 0.3s; }
.qty button:hover { background: var(--lavender-100); }
.qty input { width:44px; text-align:center; border:none; font-family:inherit; font-size:1rem; }
.pdp-actions { display:flex; gap:0.8rem; flex-wrap:wrap; }
.pdp-actions .btn { flex:1; justify-content:center; min-width: 200px; }
.pdp-meta { margin-top:2rem; padding-top:1.6rem; border-top:1px solid var(--line); display:flex; flex-direction:column; gap:0.6rem; font-size:0.84rem; color:var(--muted); }
.accordion { margin-top:2rem; }
.acc-item { border-bottom:1px solid var(--line); }
.acc-head { display:flex; justify-content:space-between; align-items:center; width:100%; padding:1.1rem 0; font-size:1rem; color:var(--plum-900); font-weight:400; text-align:left; }
.acc-head .pm { transition: transform 0.4s var(--ease); color:var(--violet-500); }
.acc-item.open .acc-head .pm { transform: rotate(45deg); }
.acc-body { max-height:0; overflow:hidden; transition: max-height 0.5s var(--ease); }
.acc-body p { padding:0 0 1.1rem; color:var(--muted); font-size:0.9rem; }

/* =========================================================
   CART DRAWER
   ========================================================= */
.overlay { position:fixed; inset:0; background:rgba(46,33,64,0.45); backdrop-filter:blur(3px); opacity:0; visibility:hidden; transition:0.4s var(--ease); z-index:200; }
.overlay.open { opacity:1; visibility:visible; }
.drawer { position:fixed; top:0; right:0; height:100%; width:min(420px, 100%); background:#fff; z-index:210; transform:translateX(100%); transition:transform 0.5s var(--ease); display:flex; flex-direction:column; }
.drawer.open { transform:translateX(0); }
.drawer-head { display:flex; justify-content:space-between; align-items:center; padding:1.6rem; border-bottom:1px solid var(--line); }
.drawer-head h3 { font-size:1.3rem; }
.drawer-body { flex:1; overflow-y:auto; padding:1.6rem; }
.drawer-empty { text-align:center; color:var(--muted); margin-top:3rem; }
.drawer-foot { padding:1.6rem; border-top:1px solid var(--line); }
.drawer-foot .total { display:flex; justify-content:space-between; font-size:1.05rem; margin-bottom:1rem; }
.drawer-foot .total b { color:var(--plum-900); }

/* =========================================================
   ANIMATIONS
   ========================================================= */
.reveal { opacity:0; transform: translateY(36px); transition: opacity 0.9s var(--ease), transform 0.9s var(--ease); }
.reveal.in { opacity:1; transform: none; }
.gsap-on .reveal { transition: none; } /* GSAP gestisce i reveal */
.reveal[data-delay="1"] { transition-delay: 0.08s; }
.reveal[data-delay="2"] { transition-delay: 0.16s; }
.reveal[data-delay="3"] { transition-delay: 0.24s; }
.reveal[data-delay="4"] { transition-delay: 0.32s; }

@keyframes float { 0%,100%{ transform: translate(0,0); } 50%{ transform: translate(20px,-26px); } }
@keyframes spin-slow { to { transform: rotate(360deg); } }
@keyframes marquee { to { transform: translateX(-50%); } }
@keyframes fadeInUp { from{opacity:0; transform:translateY(30px);} to{opacity:1; transform:none;} }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; scroll-behavior:auto !important; }
  .reveal { opacity:1; transform:none; }
}

/* =========================================================
   VARIANT SELECTOR (3 versioni — stile pricing card)
   ========================================================= */
.variant-select { margin: 0 0 1.6rem; }
.variant-head { font-size: 0.78rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--plum-700); margin-bottom: 0.9rem; font-weight: 500; }
.variant-list { display: flex; flex-direction: column; gap: 0.7rem; }
.variant-opt {
  display: grid; grid-template-columns: auto auto 1fr auto; align-items: center; gap: 0.9rem;
  width: 100%; text-align: left; padding: 0.85rem 1rem;
  border: 1.5px solid var(--line); border-radius: 16px; background: #fff;
  transition: border-color 0.3s var(--ease), box-shadow 0.3s var(--ease), transform 0.3s var(--ease), background 0.3s var(--ease);
}
.variant-opt:hover { border-color: var(--lilac-400); transform: translateY(-1px); }
.variant-opt.selected { border-color: var(--violet-500); background: linear-gradient(180deg,#fbf8ff, #f5effd); box-shadow: 0 8px 24px rgba(139,111,212,0.16); }
.vo-radio { width: 20px; height: 20px; border-radius: 50%; border: 2px solid var(--lilac-400); position: relative; flex: none; transition: 0.3s var(--ease); }
.variant-opt.selected .vo-radio { border-color: var(--violet-500); }
.variant-opt.selected .vo-radio::after { content:""; position:absolute; inset:3px; border-radius:50%; background: var(--grad-violet); }
.vo-thumb { width: 48px; height: 48px; border-radius: 11px; overflow: hidden; background: var(--grad-soft); flex: none; }
.vo-thumb img { width: 100%; height: 100%; object-fit: cover; }
.vo-main { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.vo-title { font-size: 1.05rem; font-weight: 500; color: var(--plum-900); display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; }
.vo-badge { font-size: 0.6rem; font-weight: 500; letter-spacing: 0.06em; text-transform: uppercase; padding: 0.2rem 0.55rem; border-radius: var(--radius-pill); white-space: nowrap; }
.vo-badge.pop { background: var(--grad-violet); color: #fff; }
.vo-badge.best { background: var(--gold); color: #fff; }
.vo-sub { font-size: 0.78rem; color: var(--muted); }
.vo-price { text-align: right; display: flex; flex-direction: column; align-items: flex-end; gap: 1px; }
.vo-save { font-size: 0.64rem; font-weight: 500; color: var(--plum-700); background: var(--lavender-200); padding: 0.15rem 0.5rem; border-radius: var(--radius-pill); margin-bottom: 2px; }
.vo-now { font-size: 1.12rem; font-weight: 500; color: var(--plum-900); }
.vo-was { font-size: 0.78rem; color: var(--muted); text-decoration: line-through; }

/* PDP price: "Risparmia" pill */
.pdp-price .save { background: var(--lavender-200); color: var(--plum-700); }
.js-price-was:empty, .js-price-save:empty { display: none; }

/* =========================================================
   CART ITEMS (drawer)
   ========================================================= */
.cart-items { display: flex; flex-direction: column; gap: 1.1rem; }
.cart-item { display: grid; grid-template-columns: 64px 1fr auto; gap: 0.9rem; align-items: flex-start; }
.ci-media { width: 64px; height: 64px; border-radius: 12px; overflow: hidden; background: var(--grad-soft); }
.ci-media img { width: 100%; height: 100%; object-fit: cover; }
.ci-info { display: flex; flex-direction: column; gap: 0.3rem; min-width: 0; }
.ci-info b { font-size: 0.92rem; font-weight: 500; color: var(--plum-900); }
.ci-variant { font-size: 0.76rem; color: var(--muted); }
.ci-qty { display: inline-flex; align-items: center; gap: 0.4rem; border: 1px solid var(--line); border-radius: var(--radius-pill); padding: 0.1rem 0.3rem; width: max-content; margin-top: 0.2rem; }
.ci-qty button { width: 24px; height: 24px; color: var(--plum-700); font-size: 1rem; border-radius: 50%; }
.ci-qty button:hover { background: var(--lavender-100); }
.ci-qty span { min-width: 18px; text-align: center; font-size: 0.85rem; }
.ci-right { text-align: right; display: flex; flex-direction: column; align-items: flex-end; gap: 0.5rem; }
.ci-price { font-size: 0.95rem; font-weight: 500; color: var(--plum-900); }
.ci-remove { font-size: 0.72rem; color: var(--muted); text-decoration: underline; }
.ci-remove:hover { color: var(--violet-500); }
.drawer-empty { display: flex; flex-direction: column; align-items: center; color: var(--muted); margin-top: 2.5rem; }

/* Cart count pulse */
.cart-count.pulse { animation: pop 0.4s var(--ease); }
@keyframes pop { 0% { transform: scale(1); } 40% { transform: scale(1.5); } 100% { transform: scale(1); } }

/* Gallery fade */
.gallery .main img { transition: opacity 0.3s var(--ease); }

/* =========================================================
   PREMIUM POLISH
   ========================================================= */
body { background:
  radial-gradient(1200px 600px at 80% -10%, #F3ECFB 0%, rgba(243,236,251,0) 60%),
  radial-gradient(900px 500px at -10% 10%, #F1EAFB 0%, rgba(241,234,251,0) 55%),
  var(--cream);
}
.pcard, .cat-card, .testi { border: 1px solid rgba(236,229,245,0.8); }
.btn { letter-spacing: 0.06em; }
.btn--primary { background-size: 140% 140%; background-position: 0% 50%; transition: transform 0.4s var(--ease), box-shadow 0.4s var(--ease), background-position 0.6s var(--ease); }
.btn--primary:hover { background-position: 100% 50%; }
.eyebrow { display: inline-block; }
.eyebrow::before { content: "✦ "; color: var(--lilac-400); }
h2.h-lg, h1.h-xl { letter-spacing: -0.5px; }
.pcard .media, .cat-card .thumb, .gallery .main { box-shadow: inset 0 0 0 1px rgba(255,255,255,0.6); }
*:focus-visible { outline: 2px solid var(--violet-500); outline-offset: 3px; border-radius: 4px; }
.section-head .eyebrow { margin-bottom: 0.4rem; }
::selection { background: var(--lilac-300); color: var(--plum-900); }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1024px) {
  .product-grid, .cat-grid { grid-template-columns: repeat(2, 1fr); }
  .collection-grid, .testi-grid, .features { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 860px) {
  .nav-links { position:fixed; inset:0 0 0 auto; width:min(320px,80%); background:#fff; flex-direction:column; padding:6rem 2rem; gap:1.6rem; transform:translateX(100%); transition:transform 0.5s var(--ease); box-shadow: var(--shadow-lg); z-index:150; }
  .nav-links.open { transform:translateX(0); }
  .burger { display:flex; }
  .hero-grid, .pdp-grid, .promo-grid { grid-template-columns: 1fr; }
  .promo-media { min-height: 280px; }
  .hero-media { order:-1; }
}
@media (max-width: 560px) {
  .product-grid, .cat-grid, .collection-grid, .testi-grid, .features { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .hero-trust { gap:1.2rem; }
  .news-form { flex-direction:column; }
}

/* =========================================================
   v2 — HERO IMMAGINE, COLOR BLOCK, VIDEO, TRUST, PDP EXTRAS
   ========================================================= */

/* Announcement bar + sticky header */
.announce { background: var(--plum-900); color:#fff; font-size:0.74rem; letter-spacing:0.03em; }
.announce-row { display:flex; gap:2rem; justify-content:center; align-items:center; padding:0.55rem 0; flex-wrap:wrap; }
.announce span { opacity:0.92; }
.header { position: sticky; }

/* ---- HERO (immagine intera + testo a sinistra) ---- */
.hero { position: relative; background: var(--grad-hero); overflow:hidden; }
.hero-bg { display:block; width:100%; }
.hero-bg img { width:100%; height:auto; display:block; }
.hero::before { content:""; position:absolute; inset:0; z-index:1; background:linear-gradient(90deg, rgba(243,236,251,0.72) 0%, rgba(243,236,251,0.25) 34%, rgba(243,236,251,0) 54%); }
.hero .container { position:absolute; inset:0; z-index:2; display:flex; align-items:center; pointer-events:none; }
.hero-copy { max-width: 460px; pointer-events:auto; }
.hero p { margin: 1.3rem 0 2rem; }
.hero-mini { display:flex; gap:1.4rem; margin-top:2.2rem; flex-wrap:wrap; }
.hero-mini li { display:flex; align-items:center; gap:0.45rem; font-size:0.82rem; color:var(--plum-700); }
.hero-mini svg { color: var(--violet-500); flex:none; }
@media (min-width: 1500px) { .hero-bg img { max-height: 88vh; object-fit: cover; object-position: 75% center; } }

/* ---- Product card extras ---- */
.pcard-desc { font-size:0.84rem; color:var(--muted); }
.tag--reco { background: var(--grad-violet); color:#fff; }
.pcard--reco { box-shadow: 0 0 0 2px var(--lilac-300), var(--shadow-md); }

/* ---- BRAND color block ---- */
.brand-block { display:grid; grid-template-columns: 1fr 1fr; background: var(--grad-band); border-radius: var(--radius-lg); overflow:hidden; }
.brand-media { min-height: 420px; background: var(--grad-soft); }
.brand-media img { width:100%; height:100%; object-fit:cover; }
.brand-copy { padding: clamp(2rem,4vw,3.6rem); display:flex; flex-direction:column; justify-content:center; }
.brand-copy h2 { margin:0.5rem 0 0.8rem; }
.brand-copy > p { color: var(--plum-700); max-width:46ch; }
.info-cards { display:grid; grid-template-columns: repeat(3,1fr); gap:0.7rem; margin-top:1.6rem; }
.info-card { background: rgba(255,255,255,0.75); border-radius:14px; padding:0.9rem; }
.info-card b { display:block; font-size:0.9rem; color:var(--plum-900); }
.info-card span { font-size:0.72rem; color:var(--plum-700); }

/* ---- VIDEO clienti (UGC) ---- */
.video-row { display:grid; grid-template-columns: repeat(3,1fr); gap:1.2rem; }
.vcard { background:#fff; border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow-sm); border:1px solid var(--line); transition: transform .5s var(--ease), box-shadow .5s var(--ease); }
.vcard:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.vmedia { position:relative; aspect-ratio: 9/16; background: var(--grad-soft); overflow:hidden; }
.vmedia img { width:100%; height:100%; object-fit:cover; }
.vplay { position:absolute; inset:0; margin:auto; width:56px; height:56px; border-radius:50%; background: rgba(255,255,255,0.92); color: var(--violet-500); display:grid; place-items:center; box-shadow: var(--shadow-md); transition: transform .3s var(--ease), background .3s; }
.vplay:hover { transform: scale(1.08); background:#fff; }
.vbadge { position:absolute; top:10px; left:10px; background: rgba(46,33,64,0.72); color:#fff; font-size:0.6rem; letter-spacing:0.04em; padding:0.25rem 0.6rem; border-radius: var(--radius-pill); backdrop-filter: blur(4px); }
.vcard figcaption { padding:0.85rem 1rem; display:flex; flex-direction:column; gap:1px; }
.vcard figcaption b { font-size:0.9rem; color:var(--plum-900); }
.vcard figcaption span { font-size:0.76rem; color:var(--muted); }

/* ---- TRUST badges ---- */
.trust-grid { grid-template-columns: repeat(6,1fr); gap:0.9rem; }
.trust-card { background:#fff; border:1px solid var(--line); border-radius:16px; padding:1.2rem 0.8rem; text-align:center; display:flex; flex-direction:column; align-items:center; gap:0.45rem; box-shadow: var(--shadow-sm); }
.trust-card .ic { width:42px; height:42px; border-radius:50%; background: var(--lavender-100); display:grid; place-items:center; color: var(--violet-500); }
.trust-card b { font-size:0.82rem; color:var(--plum-900); }
.trust-card span { font-size:0.72rem; color:var(--muted); }

/* ---- FAQ ---- */
.faq-wrap { max-width: 820px; }

/* ---- PDP: assurance + payment methods ---- */
.assurance { display:flex; gap:1.3rem; flex-wrap:wrap; margin:0.2rem 0 1.2rem; }
.assurance span { display:flex; align-items:center; gap:0.45rem; font-size:0.78rem; color:var(--plum-700); }
.assurance svg { color: var(--violet-500); flex:none; }
.pay-row { display:flex; align-items:center; gap:0.4rem; flex-wrap:wrap; margin-top:1.2rem; padding-top:1.2rem; border-top:1px solid var(--line); }
.pay-row .lbl { font-size:0.74rem; color:var(--muted); margin-right:0.3rem; }
.pay-badge { height:26px; padding:0 0.5rem; border:1px solid var(--line); border-radius:6px; background:#fff; display:inline-flex; align-items:center; justify-content:center; font-size:0.6rem; font-weight:600; letter-spacing:0.02em; color:var(--plum-700); }

/* ---- PDP: risultati dopo 30 giorni ---- */
.results { background: var(--grad-soft); border-radius: var(--radius-lg); padding: clamp(2rem,5vw,3.6rem); }
.results h2 { text-align:center; }
.results .sub { text-align:center; color:var(--muted); margin-top:0.4rem; }
.results-list { display:flex; flex-direction:column; gap:1.3rem; max-width:680px; margin:2.2rem auto 0; }
.result-row { display:grid; grid-template-columns: 130px 1fr; gap:1.4rem; align-items:center; padding-bottom:1.3rem; border-bottom:1px solid rgba(90,63,143,0.12); }
.result-row:last-child { border-bottom:none; padding-bottom:0; }
.result-pct { font-family: var(--font-display); font-weight:500; font-size: clamp(2.4rem,5vw,3.3rem); color: var(--violet-500); line-height:1; }
.result-row p { color:var(--ink); font-size:0.96rem; }
.results .note { text-align:center; font-size:0.72rem; color:var(--muted); margin-top:1.8rem; font-style:italic; }

/* ---- PDP: how-to video ---- */
.howto-grid { grid-template-columns: repeat(3,1fr); gap:1.2rem; }
.howto-card { background:#fff; border:1px solid var(--line); border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow-sm); transition: transform .5s var(--ease), box-shadow .5s var(--ease); }
.howto-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.howto-media { position:relative; aspect-ratio:9/16; background: var(--grad-soft); overflow:hidden; }
.howto-media img { width:100%; height:100%; object-fit:cover; }
.howto-body { padding:1.1rem 1.3rem 1.3rem; }
.howto-step { font-size:0.68rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--violet-500); }
.howto-body h4 { font-size:1.12rem; margin:0.25rem 0; }
.howto-body p { font-size:0.86rem; color:var(--muted); }

/* ---- Accenti per prodotto ---- */
.accent-rosa { --violet-500:#D98AA0; --grad-violet:linear-gradient(135deg,#E2A0B4 0%,#CC7E96 100%); }

/* =========================================================
   v2 RESPONSIVE
   ========================================================= */
@media (max-width: 1024px) {
  .trust-grid { grid-template-columns: repeat(3,1fr); }
  .video-row { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 860px) {
  .hero { display:block; }
  .hero::before { display:none; }
  .hero .container { position:static; padding-top:2.2rem; padding-bottom:0.5rem; }
  .hero-copy { max-width:none; }
  .hero-bg img { height:auto; }
  .brand-block { grid-template-columns: 1fr; }
  .brand-media { min-height: 280px; }
  .howto-grid { grid-template-columns: 1fr; }
  .video-row { grid-auto-flow: column; grid-template-columns:none; grid-auto-columns: 68%; overflow-x:auto; scroll-snap-type: x mandatory; -webkit-overflow-scrolling:touch; padding-bottom:0.6rem; }
  .vcard { scroll-snap-align: start; }
}
@media (max-width: 560px) {
  .trust-grid { grid-template-columns: repeat(2,1fr); }
  .info-cards { grid-template-columns: 1fr; }
  .video-row { grid-auto-columns: 80%; }
  .result-row { grid-template-columns: 84px 1fr; gap:0.9rem; }
}

/* =========================================================
   v3 — HERO A PANNELLO (ref.1) + COLOR BLOCKING + PAGAMENTI
   ========================================================= */

/* ---- Hero contenuta in un pannello arrotondato ---- */
.hero { width: min(100% - 2.4rem, 1340px); margin: 1.4rem auto 0; border-radius: 30px; box-shadow: var(--shadow-md); }
.hero .offer-badge { position:absolute; top:24px; right:24px; z-index:3; animation:none; width:112px; height:112px; }
.hero-cta .btn--primary { background: var(--plum-900); box-shadow: 0 12px 28px rgba(46,33,64,0.25); }
.hero-cta .btn--primary:hover { background: var(--plum-700); }

/* mini trust badge stile ref.1 (icona + 2 righe) */
.hero-mini { gap:1.8rem; }
.hero-mini li { align-items:center; gap:0.6rem; }
.hero-mini .ic { width:36px; height:36px; border-radius:50%; background:#fff; box-shadow: var(--shadow-sm); display:grid; place-items:center; color:var(--violet-500); flex:none; }
.hero-mini .tx { display:flex; flex-direction:column; line-height:1.2; }
.hero-mini .tx b { font-size:0.82rem; color:var(--plum-900); font-weight:500; }
.hero-mini .tx span { font-size:0.7rem; color:var(--muted); }

/* ---- Color blocking lavanda (ref.2) ---- */
.section--lav { background: linear-gradient(180deg,#F4EEFC 0%, #ECE2F8 100%); border-radius: 36px; margin: 1.2rem auto; width: min(100% - 2.4rem, 1340px); }
.section--lav + .section--lav { margin-top: 0; }

/* ---- Pagamenti brandizzati ---- */
.payments { display:flex; align-items:center; gap:0.5rem; flex-wrap:wrap; }
.pay { height:30px; min-width:48px; padding:0 0.6rem; border-radius:7px; background:#fff; border:1px solid var(--line); display:inline-flex; align-items:center; justify-content:center; gap:3px; font-weight:700; font-size:0.68rem; letter-spacing:0.01em; box-shadow:0 1px 3px rgba(90,63,143,0.10); font-family: Arial, Helvetica, sans-serif; }
.pay--visa { color:#1A1F71; font-style:italic; }
.pay--mc .mc { display:inline-flex; align-items:center; }
.pay--mc .mc i { width:15px; height:15px; border-radius:50%; display:block; }
.pay--mc .mc i:first-child { background:#EB001B; }
.pay--mc .mc i:last-child { background:#F79E1B; margin-left:-6px; mix-blend-mode:multiply; }
.pay--pp .a{color:#003087; font-style:italic;} .pay--pp .b{color:#009CDE; font-style:italic;}
.pay--applepay { color:#111; }
.pay--gpay { color:#5F6368; }
.pay--klarna { background:#FFB3C7; border-color:#FFB3C7; color:#17120F; }
.pay--amex { background:#2671B9; border-color:#2671B9; color:#fff; }
.pay-strip { text-align:center; margin-top:2rem; }
.pay-strip .lbl { display:block; font-size:0.74rem; color:var(--muted); letter-spacing:0.08em; text-transform:uppercase; margin-bottom:0.8rem; }
.pay-strip .payments { justify-content:center; }

/* pagamenti nel footer */
.footer-pay { display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; padding:1.4rem 0; border-top:1px solid rgba(255,255,255,0.12); }
.footer-pay span.lbl { font-size:0.82rem; color:rgba(255,255,255,0.7); }

/* pagamenti su PDP */
.pay-row .payments { margin-left:0; }

@media (max-width:560px){
  .hero .offer-badge { width:84px; height:84px; top:14px; right:14px; }
  .hero .offer-badge b { font-size:1.2rem; }
  .footer-pay { justify-content:center; }
}

/* =========================================================
   v4 — MENU MOBILE STABILE, HERO MOBILE, STICKY CART, CARD 2-COL
   ========================================================= */

/* ---- Overlay + blocco scroll menu mobile ----
   Overlay SOTTO l'header (z<100) così il drawer (dentro l'header, z:100)
   resta opaco, sopra e cliccabile. */
.nav-overlay { position:fixed; inset:0; background:rgba(46,33,64,0.5); backdrop-filter:blur(2px); opacity:0; visibility:hidden; transition:opacity .3s var(--ease), visibility .3s var(--ease); z-index:90; }
.nav-overlay.open { opacity:1; visibility:visible; }
body.menu-open { overflow:hidden; }
body.menu-open .sticky-cart { display:none !important; }

/* ---- Sticky add to cart (solo mobile PDP) ---- */
.sticky-cart { position:fixed; left:0; right:0; bottom:0; z-index:130; display:flex; align-items:center; gap:0.8rem;
  background:#fff; border-top:1px solid var(--line); box-shadow:0 -8px 28px rgba(90,63,143,0.14);
  padding:0.6rem 1rem calc(0.6rem + env(safe-area-inset-bottom)); transform:translateY(115%); transition:transform .35s var(--ease); }
.sticky-cart.show { transform:translateY(0); }
.sticky-cart img { width:46px; height:46px; border-radius:10px; object-fit:cover; flex:none; background:var(--grad-soft); }
.sticky-cart .sc-info { flex:1; min-width:0; }
.sticky-cart .sc-name { font-size:0.82rem; font-weight:500; color:var(--plum-900); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sticky-cart .sc-price { font-size:0.92rem; font-weight:600; color:var(--violet-500); }
.sticky-cart .btn { padding:0.85rem 1.2rem; white-space:nowrap; }
@media (min-width:861px){ .sticky-cart { display:none !important; } }

/* ---- HERO MOBILE: foto come sfondo reale + testo sopra ---- */
@media (max-width: 860px) {
  .hero { position:relative; display:block; min-height: 86vh; margin-top:0.8rem; border-radius:22px; }
  .hero-bg { position:absolute; inset:0; z-index:0; }
  .hero-bg img { width:100%; height:100%; object-fit:cover; object-position:center bottom; }
  .hero::before { display:block; inset:0; z-index:1; background:linear-gradient(180deg, rgba(244,238,252,0.95) 0%, rgba(244,238,252,0.72) 24%, rgba(244,238,252,0.15) 48%, rgba(244,238,252,0) 60%); }
  .hero .container { position:absolute; inset:0; z-index:2; display:block; padding:2rem 1.3rem 0; }
  .hero-copy { max-width:none; }
  .hero h1 { font-size: clamp(2.1rem, 8.5vw, 3rem); }
  .hero p { margin:0.9rem 0 1.4rem; font-size:0.96rem; }
  .hero-cta { gap:0.7rem; }
  .hero-mini { display:none; }

  /* menu drawer solido e sopra tutto */
  .nav-links { z-index:160; background:#fff; box-shadow:-14px 0 44px rgba(46,33,64,0.20); }

  /* sezioni color-block a tutta larghezza su mobile */
  .section--lav { border-radius:24px; }
}

/* ---- Card prodotto 2 colonne su mobile (ref.) ---- */
@media (max-width: 560px) {
  .product-grid, .collection-grid { grid-template-columns: repeat(2,1fr); gap:0.8rem; }
  .pcard .body { padding:0.85rem 0.8rem 1rem; gap:0.35rem; }
  .pcard h4 { font-size:1rem; line-height:1.15; }
  .pcard-desc { display:none; }
  .pcard .rate { font-size:0.68rem; }
  .pcard .price .now { font-size:1rem; }
  .pcard .add { padding:0.7rem 0.6rem; font-size:0.76rem; }
  .pcard .tag { font-size:0.56rem; padding:0.25rem 0.55rem; }
}

/* ---- Sezione brand senza immagine (centrata) ---- */
.brand-block--solo { grid-template-columns: 1fr; text-align:center; padding: clamp(2.2rem,5vw,3.6rem); }
.brand-block--solo .brand-copy { align-items:center; }
.brand-block--solo .brand-copy > p { margin-inline:auto; }
.brand-block--solo .info-cards { max-width:680px; margin-inline:auto; width:100%; }
.brand-block--solo .eyebrow { justify-content:center; }

/* =========================================================
   v5 — RIFINITURA MOBILE (ui pro max): spazi, tipografia, eleganza
   ========================================================= */
@media (max-width: 860px) {
  .section { padding: 3rem 0; }
  .section--tight { padding: 2.2rem 0; }
  .section-head { margin-bottom: 1.8rem; }
  .section-head .lead { font-size: 0.95rem; }
  .promo-copy { padding: 2rem 1.6rem 2.4rem; }
  .promo-stats { padding: 0 1.6rem 2rem; gap: 2rem; }
  .newsletter { padding: 2.4rem 1.4rem; }
  .results { padding: 1.8rem 1.3rem; }
  .info-cards { gap: 0.6rem; }
  /* CTA hero a tutta larghezza per tap comodo */
  .hero-cta { flex-direction: column; align-items: stretch; }
  .hero-cta .btn { width: 100%; justify-content: center; }
}
@media (max-width: 560px) {
  :root { --container: 1200px; }
  .container { width: min(100% - 2rem, var(--container)); }
  .section { padding: 2.6rem 0; }
  h1.h-xl { font-size: clamp(2.1rem, 9vw, 2.8rem); }
  h2.h-lg { font-size: clamp(1.8rem, 7.5vw, 2.4rem); }
  .announce-row { gap: 1.1rem; font-size: 0.66rem; }
  .trust-grid { gap: 0.6rem; }
  .trust-card { padding: 0.9rem 0.5rem; border-radius: 13px; }
  .trust-card b { font-size: 0.74rem; }
  .trust-card span { font-size: 0.64rem; }
  .testi { padding: 1.5rem; }
  .pay-strip .payments { gap: 0.4rem; }
  .pay { height: 28px; min-width: 44px; font-size: 0.62rem; }
  .brand-copy h2 { font-size: clamp(1.6rem, 7vw, 2rem); }
  .result-pct { font-size: 2.6rem; }
}

/* =========================================================
   v6 — FIX MENU iOS, GARANZIA, ROUTINE A PILL, BURGER X
   ========================================================= */

/* Fix definitivo drawer trasparente: quando il menu è aperto disattivo
   il backdrop-filter dell'header (su iOS intrappola gli elementi fixed
   e li rende trasparenti/tagliati). */
body.menu-open .header { backdrop-filter: none !important; -webkit-backdrop-filter: none !important; background: #fff !important; box-shadow: 0 1px 0 var(--line) !important; }

/* Hamburger → X */
.burger.active span:nth-child(1) { transform: translateY(6.6px) rotate(45deg); }
.burger.active span:nth-child(2) { opacity: 0; }
.burger.active span:nth-child(3) { transform: translateY(-6.6px) rotate(-45deg); }

/* Drawer mobile più elegante */
@media (max-width: 860px) {
  .burger { position: relative; z-index: 170; }
  .nav-links { padding: 5.5rem 2rem 2rem; gap: 0.4rem; }
  .nav-links a { font-size: 1.15rem; font-family: var(--font-display); color: var(--plum-900); padding: 0.7rem 0; border-bottom: 1px solid var(--line); width: 100%; }
  .nav-links a::after { display: none; }
  .nav-links li:last-child a { border-bottom: none; }
}

/* ---- GARANZIA 90 giorni ---- */
.guarantee { display:flex; align-items:center; gap:1.5rem; border-radius:24px; padding:1.7rem 2rem; box-shadow: var(--shadow-sm);
  background:
   radial-gradient(circle at 86% 24%, rgba(255,255,255,0.55), rgba(255,255,255,0) 42%),
   radial-gradient(circle at 70% 90%, rgba(255,255,255,0.35), rgba(255,255,255,0) 40%),
   linear-gradient(120deg,#E9DDF8 0%, #D6C2F0 100%); }
.g-icon { width:58px; height:58px; border-radius:16px; background: var(--grad-violet); color:#fff; display:grid; place-items:center; flex:none; box-shadow:0 10px 22px rgba(122,95,196,0.35); }
.g-body h3 { font-size:1.35rem; color:var(--plum-900); }
.g-body p { color:var(--plum-700); font-size:0.93rem; margin:0.4rem 0 0.7rem; max-width:62ch; }
@media (max-width:560px){ .guarantee { flex-direction:column; text-align:center; gap:1rem; padding:1.6rem 1.3rem; } }

/* ---- Routine TOMO a pill (ref. screenshot 2) ---- */
.routine-benefits { display:flex; flex-direction:column; gap:1.5rem; max-width:580px; margin:1.8rem auto 0; }
.rb { text-align:center; }
.rb-pill { display:inline-block; background: var(--lavender-200); color:var(--plum-900); font-weight:600; font-size:0.94rem; padding:0.55rem 1.4rem; border-radius: var(--radius-pill); box-shadow: 0 2px 8px rgba(90,63,143,0.08); }
.rb p { color:var(--muted); font-size:0.92rem; margin-top:0.65rem; line-height:1.6; }

/* v7 — thumbs gallery scrollabili (4 immagini) */
.thumbs { overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch; padding-bottom: 2px; }
.thumbs::-webkit-scrollbar { display: none; }
.thumbs button { flex: 0 0 auto; }
@media (max-width: 560px) { .thumbs button { width: 70px; height: 70px; } }

/* =========================================================
   v8 — ROUTINE CARDS (foto1), HERO MOBILE LEGGIBILE, MENU
   ========================================================= */

/* ---- La routine TOMO: card con icona a sinistra ---- */
.routine { background: linear-gradient(180deg,#F4EEFC 0%, #ECE1F8 100%); }
.routine-head em { font-style: italic; color: var(--lilac-400); }
.routine-cards { display:flex; flex-direction:column; gap:1.2rem; max-width:760px; margin:2.4rem auto 0; }
.rcard { display:flex; align-items:center; gap:1.3rem; background:#fff; border-radius:24px; padding:1.5rem 1.7rem; box-shadow: var(--shadow-sm); }
.rcard-ic { width:86px; height:86px; flex:none; border-radius:50%; background: radial-gradient(circle at 35% 30%, #ffffff, #EFE7FA); display:grid; place-items:center; color:var(--plum-700); box-shadow: inset 0 0 0 1px rgba(139,111,212,0.12); }
.rcard-body h3 { font-size:1.35rem; color:var(--plum-900); display:flex; align-items:center; gap:0.5rem; }
.rcard-body h3 .spark { color:#D98AA0; font-size:0.85rem; }
.rcard-body p { color:var(--muted); font-size:0.93rem; line-height:1.6; margin-top:0.6rem; padding-top:0.6rem; border-top:1px solid rgba(217,138,160,0.22); max-width:48ch; }
.rcard--accent { background: linear-gradient(120deg,#F6E2EB 0%, #EBD9F2 100%); }
.rcard--accent .rcard-ic { width:70px; height:70px; background: rgba(255,255,255,0.55); color:#C77E96; box-shadow:none; }
.rcard--accent .rcard-body h3 { font-size:1.12rem; }
.rcard--accent .rcard-body p { border-top:none; padding-top:0; margin-top:0.3rem; }
@media (max-width:560px){
  .rcard { gap:1rem; padding:1.2rem 1.1rem; border-radius:20px; }
  .rcard-ic { width:64px; height:64px; }
  .rcard-ic svg { width:26px; height:26px; }
  .rcard-body h3 { font-size:1.12rem; }
  .rcard-body p { font-size:0.86rem; }
}

/* ---- HERO MOBILE: testo leggibile su lavanda, niente alone, donna visibile ---- */
@media (max-width: 860px) {
  .hero { display:block; min-height:auto; overflow:hidden; background: var(--grad-hero); padding:0; }
  .hero::before { display:none !important; }              /* via l'alone bianco sul viso */
  .hero .container { position:static; display:block; padding:2.2rem 1.4rem 0.6rem; }
  .hero-copy { max-width:none; }
  .hero h1 { color: var(--plum-900); font-size: clamp(2.2rem,9vw,3rem); }
  .hero p { color: var(--muted); }
  .hero-bg { position:static; inset:auto; margin-top:1.3rem; }
  .hero-bg img { width:100%; height:auto; aspect-ratio: 4/5; object-fit:cover; object-position:70% 22%; }
  .hero .offer-badge { top:18px; right:18px; }
  .hero-mini { display:none; }
}

/* ---- MENU a tendina: niente sottolineature, font elegante ---- */
@media (max-width: 860px) {
  .nav-links a { font-family: var(--font-display); font-size:1.3rem; font-weight:500; letter-spacing:0.005em; color:var(--plum-900); border-bottom:none; padding:0.7rem 0; }
  .nav-links a::after { display:none !important; }
  .nav-links a.active { color: var(--violet-500); }
}

/* =========================================================
   v9 — HERO come immagine 3 (testo su lavanda, bottoni sulla spalla)
        + trust card sotto la hero + perf
   ========================================================= */

/* Trust card subito sotto la hero (bianca, premium) */
.hero-trust-wrap { margin-top: -2.4rem; position: relative; z-index: 6; }
.hero-mini { background:#fff; border-radius:22px; box-shadow: var(--shadow-md); display:flex; justify-content:space-between; gap:1rem; padding:1.15rem 1.5rem; }
.hero-mini li { display:flex; align-items:center; gap:0.65rem; flex:1; justify-content:center; }
.hero-mini .ic { width:40px; height:40px; border-radius:50%; background: var(--lavender-100); display:grid; place-items:center; color:var(--violet-500); flex:none; box-shadow:none; }
.hero-mini .tx { display:flex; flex-direction:column; line-height:1.2; }
.hero-mini .tx b { font-size:0.85rem; color:var(--plum-900); font-weight:500; }
.hero-mini .tx span { font-size:0.72rem; color:var(--muted); }

/* Desktop: badge sopra l'immagine, non spinnare troppo */
.hero .offer-badge { animation: none; }

/* ---- HERO MOBILE v12: testuale premium (niente donna su mobile) ---- */
@media (max-width: 860px) {
  .hero { position:relative; display:block; width:auto; margin:0;
          border-radius:0; box-shadow:none; min-height:0; overflow:hidden; padding:0;
          background:
            radial-gradient(120% 80% at 85% 0%, #F3ECFB 0%, rgba(243,236,251,0) 55%),
            linear-gradient(165deg, #EFE6FA 0%, #E3D3F4 60%, #D9C6F0 100%); }
  .hero::before { display:none !important; }
  .hero-bg { display:none !important; }   /* via la donna su mobile */
  .hero .container { position:static; z-index:2; padding:2.6rem 1.4rem 1.6rem; }
  .hero-grid { display:block; }
  .hero-copy { display:block; max-width:none; }
  .hero h1 { color:var(--plum-900); font-size:clamp(2.3rem,9.5vw,3rem); line-height:1.05; }
  .hero p { color:var(--ink); opacity:0.82; max-width:30rem; margin:0.9rem 0 1.4rem; }
  .hero-cta { flex-direction:column; gap:0.7rem; }
  .hero-cta .btn { width:100%; justify-content:center; }
  /* badge -20% in alto a destra sulla lavanda */
  .hero .offer-badge { position:absolute; top:14px; right:14px; bottom:auto; left:auto;
        margin:0; width:84px; height:84px; z-index:4; }
  /* benefit banner: alzato + aria sotto, UNA sola riga */
  .hero-trust-wrap { margin-top:1.2rem; margin-bottom:2rem; }
  .hero-mini { display:flex; flex-direction:row; align-items:center; justify-content:space-between; gap:0.4rem; padding:0.9rem 0.7rem; }
  .hero-mini li { flex:1; min-width:0; gap:0.4rem; justify-content:center; }
  .hero-mini .ic { width:28px; height:28px; flex:none; }
  .hero-mini .ic svg { width:15px; height:15px; }
  .hero-mini .tx b { font-size:0.66rem; line-height:1.15; }
  .hero-mini .tx span { font-size:0.56rem; line-height:1.1; }
}
/* barra annuncio: una sola riga su mobile (mostra solo il 1° messaggio) */
@media (max-width: 620px) {
  .announce-row { justify-content:center; gap:0; white-space:nowrap; }
  .announce-row span:nth-child(n+2) { display:none; }
}

/* perf: hint GPU solo dove serve */
.pcard .media img, .hero-bg img, .vmedia img, .howto-media img { will-change: transform; }

/* =========================================================
   v11 — VIDEO nelle card + pagamenti AMEX in riga (mobile)
   ========================================================= */
.vmedia video, .howto-media video { width:100%; height:100%; object-fit:cover; display:block; background:var(--grad-soft); }
.howto-media { position:relative; }

/* pagamenti: tutti in una riga anche su mobile, AMEX incluso */
@media (max-width: 560px) {
  .pay-row .payments, .pay-strip .payments, .footer-pay .payments { flex-wrap:nowrap; gap:0.28rem; max-width:100%; }
  .pay { flex:0 1 auto; min-width:0; padding:0 0.3rem; height:25px; font-size:0.54rem; gap:2px; }
  .pay--mc .mc i { width:12px; height:12px; }
  .pay-row { gap:0.3rem; }
  .pay-row .lbl { display:none; }   /* su mobile togliamo "Pagamenti:" per fare spazio */
}

/* =========================================================
   v13 — video 9:16: altezza controllata su desktop + niente poster
   ========================================================= */
.howto-media video, .vmedia video { width:100%; height:100%; object-fit:cover; display:block; background:var(--grad-soft); }
@media (min-width: 861px) {
  .howto-card { max-width: 300px; margin-inline: auto; width: 100%; }
  .video-row .vcard { max-width: 300px; margin-inline: auto; width: 100%; }
}
