/* =====================================================
   Women Essential — Landing
   Brand canon: brand/brand-kit.md + brand/brand-story.md
   Paleta:  #F5EFE6 crema · #EDE4D3 beige · #FFF perla · #1A1A1A tinta · #A89B8A taupe
   Fuentes: Fraunces (sustituto free de Editorial New) + Inter
   ===================================================== */

:root{
  --crema:#F5EFE6;
  --beige:#EDE4D3;
  --perla:#FFFFFF;
  --tinta:#1A1A1A;
  --tinta-soft:#3a3633;
  --taupe:#A89B8A;
  --taupe-deep:#8B7E6C;

  --serif:'Fraunces','Editorial New','Cormorant Garamond',Georgia,serif;
  --sans:'Inter','Söhne','Helvetica Neue',Arial,sans-serif;

  --max:1240px;
  --gutter:clamp(1.25rem, 4vw, 3rem);
  --section-pad:clamp(4.5rem, 9vw, 8rem);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:80px;scroll-padding-bottom:100px}
@media (max-width:640px){html{scroll-padding-top:60px;scroll-padding-bottom:100px}}
body{
  font-family:var(--sans);
  background:var(--crema);
  color:var(--tinta);
  line-height:1.55;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:clip;
}
html{overflow-x:clip}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:color .25s ease, opacity .25s ease}
a:hover{color:var(--taupe-deep)}
em,.italic{font-style:italic;font-family:var(--serif);font-weight:300}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ============ NAV (transparente sobre hero crema, blur al scroll) ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:120;
  isolation:isolate;
  display:flex;
  align-items:center;
  gap:1.5rem;
  padding:1.4rem var(--gutter);
  background:transparent;
  border-bottom:1px solid transparent;
  transition:background .35s ease, padding .35s ease, border-color .35s ease, backdrop-filter .35s ease;
}
.nav .wordmark-mini{margin-right:auto}  /* empuja todo el resto a la derecha */
.nav.is-scrolled{
  background:rgba(245,239,230,.85);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom-color:rgba(26,26,26,.06);
  padding:1rem var(--gutter);
}
.wordmark-mini{
  display:inline-flex;align-items:center;
  height:32px;
  line-height:1;
  color:var(--tinta);  /* el SVG usa currentColor → escala sin pérdida */
}
.wordmark-mini img{
  height:22px;
  width:auto;
  display:block;
}
@media (max-width:640px){
  .wordmark-mini img{height:18px}
}
.nav nav{display:flex;gap:1.75rem}
.nav nav a{
  font-size:.7rem;
  letter-spacing:.24em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--tinta);
}
@media (max-width:640px){
  .nav{padding:.95rem 1rem}
  .nav.is-scrolled{padding:.75rem 1rem}
  .wordmark-mini img{height:14px}
  .nav nav{gap:.8rem}
  .nav nav a{
    font-size:.58rem;
    letter-spacing:.14em;
    white-space:nowrap;
  }
  .nav-cart{width:34px;height:34px}
  .nav-cart svg{width:18px;height:18px}
}
@media (max-width:380px){
  .nav nav{gap:.55rem}
  .nav nav a{font-size:.54rem;letter-spacing:.1em}
  .wordmark-mini img{height:12px}
}

/* ============ HERO · MAGAZINE COVER ASIMÉTRICO ============
   Wrapper .hero-pin con altura 200vh: 1 viewport sticky pin + 1 viewport para que
   la siguiente sección (editorial) se deslice por encima como cortina. */
.hero-pin{
  position:relative;
  z-index:5;
  margin-top:-100vh;
  margin-top:-100svh;
  height:200vh;
  height:200svh;
}
.hero-mag{
  position:sticky;top:0;
  z-index:5;
  height:100vh;
  height:100svh;
  width:100%;
  background:var(--crema);
  overflow:hidden;
  isolation:isolate;
  padding:6.5rem var(--gutter) 6rem;
  display:flex;flex-direction:column;
  justify-content:center;
}

/* Print marks (esquinas tipo página de revista) */
.mag-folio{
  position:absolute;
  z-index:5;
  display:inline-flex;align-items:center;gap:.7rem;
  font-size:.62rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--taupe);
  font-weight:500;
  padding-bottom:.45rem;
  border-bottom:1px solid rgba(168,155,138,.35);
  display:flex;align-items:center;gap:.6rem;
  pointer-events:none;
}
.mag-folio-tl{top:6.4rem;left:var(--gutter)}
.mag-folio-tr{top:6.4rem;right:var(--gutter)}
.folio-num{
  font-family:var(--serif);
  font-style:italic;
  text-transform:lowercase;
  letter-spacing:.04em;
  color:var(--tinta);
  font-size:.95rem;
  font-weight:400;
  line-height:1;
}
.folio-sep{
  display:inline-block;
  width:18px;height:1px;
  background:var(--taupe);
  opacity:.6;
}

/* Eyebrow vertical lateral derecho (rotada) */
.mag-side{
  position:absolute;
  right:1.2rem;
  top:50%;
  transform:translateY(-50%) rotate(180deg);
  writing-mode:vertical-rl;
  font-size:.66rem;
  letter-spacing:.4em;
  text-transform:uppercase;
  color:var(--taupe);
  opacity:.7;
  font-weight:500;
  white-space:nowrap;
  z-index:4;
  pointer-events:none;
  user-select:none;
}

/* Stage central — cluster editorial */
.mag-stage{
  position:relative;
  max-width:64rem;
  margin:0 auto;
  width:100%;
  padding:0 1rem;
}
.mag-cluster{
  text-align:center;
  display:flex;flex-direction:column;align-items:center;
}
.mag-over{
  display:flex;align-items:center;justify-content:center;gap:.85rem;
  font-size:.7rem;letter-spacing:.34em;text-transform:uppercase;
  color:var(--taupe);font-weight:500;
  margin-bottom:2.5rem;
  opacity:0;
  animation:fadeIn .9s ease .1s forwards;
}
.ov-line{
  display:inline-block;width:40px;height:1px;background:var(--taupe);opacity:.6;
}
.mag-display{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(2.8rem, 8.5vw, 7rem);
  line-height:1.02;
  letter-spacing:-.022em;
  color:var(--tinta);
  padding-top:.06em;
  overflow:visible;
  max-width:100%;
}
.mag-word{
  display:block;
  opacity:0;
  transform:translateY(36px);
  filter:blur(8px);
  animation:revealWord 1.15s cubic-bezier(.2,.7,.2,1) forwards;
}
.mag-word em{font-style:italic;font-weight:300;color:var(--tinta)}
.mag-word-1{animation-delay:.25s}
.mag-word-2{animation-delay:.5s}
@keyframes revealWord{
  to{opacity:1;transform:none;filter:blur(0)}
}
@keyframes fadeIn{to{opacity:1}}

/* Divider editorial fino */
.mag-divider{
  width:100%;max-width:18rem;
  margin:3rem 0 2.25rem;
  display:flex;align-items:center;justify-content:center;gap:.85rem;
  opacity:0;
  animation:fadeIn 1s ease 1s forwards;
}
.mag-divider::before,
.mag-divider::after{
  content:'';flex:1;height:1px;background:rgba(26,26,26,.18);
}
.mag-divider span{
  display:inline-block;
  width:5px;height:5px;
  background:var(--taupe);
  border-radius:50%;
}

.mag-sub{
  font-size:clamp(.98rem,1.15vw,1.1rem);
  line-height:1.65;
  color:var(--tinta-soft);
  max-width:30rem;
  margin-bottom:2.5rem;
  opacity:0;
  animation:fadeIn 1s ease 1.2s forwards;
}
.mag-actions{
  display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap;justify-content:center;
  opacity:0;
  animation:fadeIn 1s ease 1.4s forwards;
}

/* Bottom band */
.mag-bottom{
  position:absolute;
  left:var(--gutter);right:var(--gutter);bottom:1.75rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  z-index:4;
  opacity:0;
  animation:fadeIn 1s ease 1.8s forwards;
}
.mag-trust{
  list-style:none;
  display:flex;flex-wrap:wrap;gap:.4rem 1.5rem;
}
.mag-trust li{
  font-size:.7rem;
  color:var(--taupe);
  letter-spacing:.18em;
  text-transform:uppercase;
  position:relative;
  padding-left:1rem;
}
.mag-trust li::before{
  content:'';position:absolute;left:0;top:.48rem;
  width:5px;height:5px;border-radius:50%;background:var(--taupe);
}
.mag-scroll{
  display:flex;align-items:center;gap:.7rem;
  color:var(--tinta);
  font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;font-weight:500;
}
.mag-arrow{
  display:inline-block;width:1px;height:30px;
  background:linear-gradient(to bottom, var(--tinta), transparent);
  position:relative;overflow:hidden;
}
.mag-arrow::after{
  content:'';position:absolute;left:0;top:0;width:1px;height:12px;
  background:var(--tinta);
  animation:scrollHint 2.2s ease-in-out infinite;
}
@keyframes scrollHint{
  0%{transform:translateY(-12px);opacity:0}
  40%{opacity:1}
  100%{transform:translateY(30px);opacity:0}
}

/* Grain sutil (sin mix-blend para evitar saturar el crema) */
.mag-grain{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.10 0 0 0 0 0.08 0 0 0 0 0.06 0 0 0 0.4 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.06;
}

/* Tablet */
@media (max-width:1100px){
  .mag-display{font-size:clamp(2.6rem, 9vw, 6rem);line-height:1.04}
}

/* Mobile */
@media (max-width:768px){
  .hero-mag{padding:5.5rem var(--gutter) 5rem;min-height:100svh}
  .mag-folio{font-size:.6rem;letter-spacing:.22em}
  .mag-folio-tl,.mag-folio-tr{top:5rem}
  .folio-num{font-size:.7rem}
  .mag-side{font-size:.58rem;letter-spacing:.32em;right:.7rem}

  .mag-over{margin-bottom:1.75rem;font-size:.62rem;letter-spacing:.28em;gap:.6rem}
  .ov-line{width:28px}
  .mag-display{font-size:clamp(2.2rem, 11vw, 3.6rem);line-height:1.06}
  .mag-divider{margin:2rem 0 1.75rem;max-width:14rem}
  .mag-sub{font-size:.95rem;margin-bottom:2rem}

  .mag-bottom{flex-wrap:wrap;gap:.85rem;bottom:1rem}
  .mag-trust{order:2;width:100%;gap:.3rem 1rem;justify-content:center}
  .mag-trust li{font-size:.58rem;letter-spacing:.14em;padding-left:.85rem}
  .mag-trust li::before{top:.4rem;width:4px;height:4px}
  .mag-scroll{order:1;font-size:.6rem;letter-spacing:.2em}
  .mag-arrow{height:22px}
}

@media (max-width:480px){
  .mag-actions{gap:1rem;width:100%;flex-direction:column}
  .mag-actions .btn{width:100%}
  .mag-side{display:none}
}

@media (prefers-reduced-motion: reduce){
  .mag-word,.mag-sub,.mag-actions,.mag-divider,.mag-over,.mag-bottom{
    opacity:1 !important;transform:none !important;filter:none !important;animation:none !important;
  }
  .mag-arrow::after{animation:none;height:30px;opacity:.7}
}

/* ============ HERO ============ */
.hero{
  min-height:100vh;
  min-height:100svh;
  padding:7rem var(--gutter) 4rem;
  display:grid;
  grid-template-columns:1fr 1.05fr;
  gap:clamp(2rem, 5vw, 5rem);
  align-items:center;
  max-width:var(--max);
  margin:0 auto;
}
.hero-copy{padding-right:1rem}
.hero-eyebrow{
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--taupe);
  margin-bottom:2rem;
  font-weight:500;
}
.hero-h1{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(2.5rem, 6.5vw, 4.75rem);
  line-height:1.04;
  letter-spacing:-.018em;
  color:var(--tinta);
  padding-top:.08em;
  overflow:visible;
  margin-bottom:1.75rem;
}
.hero-h1 em{font-style:italic;font-weight:300;color:var(--tinta)}
.hero-sub{
  font-size:clamp(1rem,1.3vw,1.1rem);
  line-height:1.6;
  color:var(--tinta-soft);
  max-width:30rem;
  margin-bottom:2.5rem;
}
.hero-actions{
  display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap;
  margin-bottom:2.25rem;
}
.hero-trust{
  list-style:none;
  display:flex;flex-wrap:wrap;gap:.4rem 1.5rem;
  padding-top:1.5rem;
  border-top:1px solid rgba(26,26,26,.1);
  max-width:30rem;
}
.hero-trust li{
  font-size:.78rem;
  color:var(--taupe);
  letter-spacing:.06em;
  position:relative;
  padding-left:1.1rem;
}
.hero-trust li::before{
  content:'';
  position:absolute;left:0;top:.55rem;
  width:6px;height:6px;
  border-radius:50%;
  background:var(--taupe);
}
.hero-photo{
  aspect-ratio:3/4;
  overflow:hidden;
  background:var(--beige);
}
.hero-photo img{
  width:100%;height:100%;
  object-fit:cover;
  filter:saturate(.96);
}
@media (max-width:860px){
  .hero{grid-template-columns:1fr;padding-top:6rem}
  .hero-copy{order:2;padding-right:0}
  .hero-photo{order:1;aspect-ratio:4/5;max-height:65vh}
}

/* ============ BTN SYSTEM ============ */
.btn{
  position:relative;
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:1.05rem 2rem;
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:lowercase;
  font-weight:500;
  min-height:48px;
  cursor:pointer;
  border:1px solid transparent;
  overflow:hidden;
  isolation:isolate;
  transition:background .35s cubic-bezier(.2,.7,.2,1),
             color .35s cubic-bezier(.2,.7,.2,1),
             border-color .35s ease,
             transform .25s cubic-bezier(.2,.7,.2,1),
             box-shadow .35s ease,
             letter-spacing .35s ease;
}
.btn:active{transform:translateY(0) scale(.985)}

/* Primary: tinta sólido + shimmer al hover + arrow micro */
.btn-primary{
  background:var(--tinta);
  color:var(--crema);
  border-color:var(--tinta);
  box-shadow:0 2px 6px -3px rgba(0,0,0,.15);
}
.btn-primary::before{
  content:'';
  position:absolute;
  top:0;left:-150%;
  width:60%;height:100%;
  background:linear-gradient(105deg, transparent 0%, rgba(245,239,230,.18) 50%, transparent 100%);
  transition:left .9s cubic-bezier(.2,.7,.2,1);
  pointer-events:none;
  z-index:0;
}
.btn-primary:hover{
  background:var(--tinta);
  border-color:var(--tinta);
  color:var(--crema);
  transform:translateY(-2px);
  box-shadow:0 12px 28px -14px rgba(0,0,0,.45);
  letter-spacing:.24em;
}
.btn-primary:hover::before{left:130%}
.btn-primary > *{position:relative;z-index:1}

/* Disabled state */
.btn[data-disabled="true"]{
  background:transparent !important;
  color:var(--taupe) !important;
  border-color:rgba(26,26,26,.18) !important;
  cursor:not-allowed;
  box-shadow:none !important;
  letter-spacing:.22em !important;
}
.btn[data-disabled="true"]:hover{
  transform:none !important;
  background:transparent !important;
  color:var(--taupe-deep) !important;
}
.btn[data-disabled="true"]::before{display:none}

.btn-full{display:flex;width:100%;margin-top:.5rem}

/* ===== Botón "Añadir al carrito" — secundario outline ===== */
.btn-cart{
  background:transparent;
  color:var(--tinta);
  border:1px solid var(--tinta);
  margin-top:.6rem;
}
.btn-cart::before{
  content:'';
  position:absolute;
  inset:0;
  background:var(--tinta);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .42s cubic-bezier(.55,.06,.18,1);
  z-index:0;
}
.btn-cart > *{position:relative;z-index:1}
.btn-cart .cart-ico{display:block;flex-shrink:0}
.btn-cart:hover{
  color:var(--crema);
  border-color:var(--tinta);
  transform:translateY(-2px);
  letter-spacing:.24em;
  box-shadow:0 12px 28px -16px rgba(0,0,0,.3);
}
.btn-cart:hover::before{transform:scaleX(1)}
.btn-cart[data-disabled="true"]::before{display:none}

/* ===== Icono carrito en nav con badge ===== */
.nav-cart{
  position:relative;
  display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;
  color:var(--tinta);
  margin-left:.5rem;
}
.nav-cart svg{transition:transform .25s ease}
.nav-cart:hover svg{transform:translateY(-1px)}
.nav-cart-badge{
  position:absolute;
  top:-4px;right:-6px;
  min-width:18px;height:18px;
  padding:0 5px;
  border-radius:9px;
  background:var(--tinta);
  color:var(--crema);
  font-family:var(--sans);
  font-size:.62rem;
  font-weight:600;
  letter-spacing:.02em;
  display:flex;align-items:center;justify-content:center;
  font-variant-numeric:tabular-nums;
  opacity:0;
  transform:scale(.6);
  transition:opacity .25s ease, transform .25s cubic-bezier(.34,1.56,.64,1);
  pointer-events:none;
}
.nav-cart.has-items .nav-cart-badge{
  opacity:1;
  transform:scale(1);
}
.nav-cart.is-pulse .nav-cart-badge{
  animation:cartPulse .55s cubic-bezier(.34,1.56,.64,1);
}
@keyframes cartPulse{
  0%{transform:scale(1)}
  35%{transform:scale(1.35)}
  100%{transform:scale(1)}
}

/* ===== Toast "Añadido al carrito" ===== */
.cart-toast{
  position:fixed;
  top:5rem;right:1.25rem;
  z-index:100;
  display:flex;align-items:center;gap:.6rem;
  padding:.85rem 1.15rem;
  background:var(--tinta);
  color:var(--crema);
  border-radius:2px;
  font-family:var(--sans);
  font-size:.78rem;
  letter-spacing:.06em;
  font-weight:500;
  box-shadow:0 8px 24px -12px rgba(0,0,0,.4);
  opacity:0;
  transform:translateY(-8px);
  transition:opacity .35s ease, transform .35s ease;
  pointer-events:none;
}
.cart-toast.is-visible{
  opacity:1;
  transform:translateY(0);
}
.cart-toast svg{flex-shrink:0;color:#5fa86d}
@media (max-width:640px){
  .cart-toast{left:1rem;right:1rem;justify-content:center}
}

/* ===== Drawer del carrito (panel lateral derecho) ===== */
.cart-drawer{
  position:fixed;inset:0;
  z-index:200;
  visibility:hidden;
  pointer-events:none;
}
.cart-drawer.is-open{
  visibility:visible;
  pointer-events:auto;
}
.cart-drawer-overlay{
  position:absolute;inset:0;
  background:rgba(26,26,26,.45);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  opacity:0;
  transition:opacity .35s ease;
  cursor:pointer;
}
.cart-drawer.is-open .cart-drawer-overlay{opacity:1}
.cart-drawer-panel{
  position:absolute;
  top:0;right:0;
  width:min(420px, 100%);
  height:100%;
  background:var(--crema);
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform .42s cubic-bezier(.2,.7,.2,1);
  box-shadow:-20px 0 60px -30px rgba(0,0,0,.35);
}
.cart-drawer.is-open .cart-drawer-panel{transform:translateX(0)}

.cart-drawer-head{
  display:flex;align-items:flex-start;justify-content:space-between;
  padding:1.5rem 1.5rem 1rem;
  border-bottom:1px solid rgba(26,26,26,.08);
  flex-shrink:0;
}
.cart-drawer-eyebrow{
  font-size:.62rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--taupe);
  font-weight:500;
  margin-bottom:.3rem;
}
.cart-drawer-title{
  font-family:var(--serif);
  font-weight:300;
  font-size:1.5rem;
  color:var(--tinta);
  letter-spacing:-.01em;
  line-height:1.1;
}
.cart-drawer-close{
  background:transparent;border:0;
  color:var(--tinta);
  cursor:pointer;
  padding:.4rem;
  margin:-.4rem -.4rem 0 0;
  transition:color .2s ease, transform .2s ease;
}
.cart-drawer-close:hover{
  color:var(--taupe-deep);
  transform:rotate(90deg);
}

.cart-drawer-body{
  flex:1;
  overflow-y:auto;
  padding:1rem 1.5rem;
  display:flex;flex-direction:column;
  gap:1.25rem;
}
.cart-drawer-body:empty{display:none}

.cart-item{
  display:grid;
  grid-template-columns:84px 1fr auto;
  gap:1rem;
  padding-bottom:1.25rem;
  border-bottom:1px solid rgba(26,26,26,.06);
}
.cart-item:last-child{border-bottom:0;padding-bottom:0}
.cart-item-img{
  width:84px;height:108px;
  overflow:hidden;
  background:var(--beige);
  flex-shrink:0;
}
.cart-item-img img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center top;
  display:block;
}
.cart-item-info{
  display:flex;flex-direction:column;justify-content:space-between;gap:.4rem;
  min-width:0;
}
.cart-item-name{
  font-family:var(--serif);
  font-weight:400;
  font-size:1rem;
  line-height:1.2;
  color:var(--tinta);
  letter-spacing:-.005em;
}
.cart-item-meta{
  font-size:.74rem;
  color:var(--taupe);
  letter-spacing:.04em;
}
.cart-item-qty{
  display:inline-flex;align-items:center;
  border:1px solid rgba(26,26,26,.18);
  width:fit-content;
  margin-top:.2rem;
}
.cart-item-qty button{
  width:30px;height:30px;
  background:transparent;border:0;
  font-family:var(--serif);font-size:1.1rem;font-weight:300;
  color:var(--tinta);cursor:pointer;
  transition:background .2s ease;
}
.cart-item-qty button:hover{background:var(--beige)}
.cart-item-qty span{
  min-width:30px;text-align:center;
  font-family:var(--sans);font-size:.85rem;font-weight:500;
  font-variant-numeric:tabular-nums;
  border-left:1px solid rgba(26,26,26,.18);
  border-right:1px solid rgba(26,26,26,.18);
  padding:.4rem 0;
  color:var(--tinta);
}
.cart-item-side{
  display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end;
  text-align:right;gap:.5rem;
}
.cart-item-price{
  font-family:var(--serif);
  font-weight:400;
  font-size:1.05rem;
  color:var(--tinta);
  font-variant-numeric:tabular-nums;
  line-height:1;
}
.cart-item-remove{
  background:transparent;border:0;
  color:var(--taupe);
  cursor:pointer;
  font-size:.7rem;
  letter-spacing:.16em;
  text-transform:lowercase;
  padding:.25rem 0;
  transition:color .2s ease;
}
.cart-item-remove:hover{color:var(--tinta)}

/* Empty state */
.cart-drawer-empty{
  flex:1;
  display:none;
  flex-direction:column;align-items:center;justify-content:center;
  padding:2rem 1.5rem;
  text-align:center;
  gap:.75rem;
}
.cart-drawer.is-empty .cart-drawer-empty{display:flex}
.cart-drawer.is-empty .cart-drawer-body{display:none}
.cart-drawer.is-empty .cart-drawer-foot{display:none}
.cart-empty-title{
  font-family:var(--serif);
  font-style:italic;font-weight:300;
  font-size:1.4rem;
  color:var(--tinta);
  letter-spacing:-.01em;
}
.cart-empty-sub{
  font-size:.85rem;
  color:var(--tinta-soft);
  max-width:18rem;
}
.cart-continue-empty{
  margin-top:1rem;
  width:auto !important;
  display:inline-flex !important;
  padding:.85rem 1.6rem;
}

/* Footer */
.cart-drawer-foot{
  padding:1.25rem 1.5rem 1.5rem;
  border-top:1px solid rgba(26,26,26,.08);
  background:var(--crema);
  flex-shrink:0;
}
.cart-totals{
  display:flex;flex-direction:column;
  margin-bottom:1.1rem;
}
.ct-row{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:.45rem 0;
  font-size:.85rem;
  color:var(--tinta-soft);
}
.ct-row strong{
  font-weight:500;
  color:var(--tinta);
  font-variant-numeric:tabular-nums;
}
.ct-row.ct-savings{color:#3d6e47}
.ct-row.ct-savings strong{color:#3d6e47}
.ct-row.ct-total{
  border-top:1px solid rgba(26,26,26,.1);
  padding-top:.85rem;
  margin-top:.3rem;
  font-family:var(--serif);
  font-size:1.05rem;
  color:var(--tinta);
}
.ct-row.ct-total strong{
  font-size:1.35rem;
  font-weight:400;
}
.cart-checkout{margin-top:.25rem}
.cart-trust{
  margin-top:.85rem;
  font-size:.7rem;
  letter-spacing:.04em;
  color:var(--taupe);
  text-align:center;
  font-style:italic;
  font-family:var(--serif);
}

@media (max-width:640px){
  .cart-drawer-panel{width:100%}
  .cart-item{grid-template-columns:72px 1fr auto;gap:.75rem}
  .cart-item-img{width:72px;height:92px}
}

/* No scroll del body cuando drawer abierto */
body.cart-locked{overflow:hidden}
/* Body lock cuando modal abierto: página de fondo TOTALMENTE fija */
html.rev-locked,
body.rev-locked{
  overflow:hidden !important;
  height:100%;
  position:fixed;
  width:100%;
  top:var(--rev-scroll-top, 0);
  left:0;
  right:0;
}

/* ============ Estrellas (color dorado tipo AliExpress) ============ */
.res-stars svg{fill:#FFA801 !important}
.res-card-stars{color:#FFA801 !important;letter-spacing:.05em}
.rev-stars{
  display:inline-flex;align-items:center;color:#FFA801;font-size:.9rem;
  letter-spacing:.06em;line-height:1;
}
.rev-stars-lg{font-size:1.05rem}

/* ============ Link "Ver todas →" en el header de reseñas ============ */
.res-see-all{
  display:inline-block;
  margin-top:.5rem;
  color:#2D6CDF;
  font-size:.8rem;
  letter-spacing:.06em;
  font-weight:500;
  text-decoration:underline;
  text-underline-offset:4px;
  text-decoration-thickness:1px;
  transition:color .2s ease;
  cursor:pointer;
}
.res-see-all:hover{color:#1849A8}

/* Botón "Ver las 340 reseñas verificadas" al final de la sección actual */
.res-more-all{
  background:var(--tinta);
  color:var(--crema);
  padding:1.1rem 1.8rem;
  border:1px solid var(--tinta);
  font-size:.8rem;
  letter-spacing:.22em;
  text-transform:lowercase;
  font-weight:500;
  cursor:pointer;
  display:inline-flex;align-items:center;gap:.7rem;
  transition:background .3s ease, color .3s ease, transform .25s ease, letter-spacing .3s ease;
  position:relative;overflow:hidden;
}
.res-more-all:hover{
  transform:translateY(-2px);
  letter-spacing:.24em;
  box-shadow:0 12px 28px -16px rgba(0,0,0,.35);
}
.res-more-all .rm-arrow{
  transition:transform .3s ease;
  font-size:.95rem;
}
.res-more-all:hover .rm-arrow{transform:translateX(4px)}

/* ============ Reviews Modal (estilo AliExpress) ============ */
.rev-modal{
  position:fixed;inset:0;
  z-index:300;
  visibility:hidden;
  pointer-events:none;
}
.rev-modal.is-open{
  visibility:visible;
  pointer-events:auto;
}
.rev-modal-overlay{
  position:absolute;inset:0;
  background:rgba(26,26,26,.55);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  opacity:0;
  transition:opacity .35s ease;
  cursor:pointer;
}
.rev-modal.is-open .rev-modal-overlay{opacity:1}
.rev-modal-panel{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%, -48%);
  width:min(820px, 94vw);
  max-height:88vh;
  background:#fff;
  border-radius:6px;
  display:flex;flex-direction:column;
  opacity:0;
  transition:opacity .35s ease, transform .42s cubic-bezier(.2,.7,.2,1);
  box-shadow:0 24px 70px -20px rgba(0,0,0,.5);
  overflow:hidden;
}
.rev-modal.is-open .rev-modal-panel{
  opacity:1;
  transform:translate(-50%, -50%);
}
.rev-modal-close{
  position:absolute;
  top:1rem;right:1rem;
  z-index:5;
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  background:transparent;border:0;
  color:var(--tinta);
  cursor:pointer;
  border-radius:50%;
  transition:background .2s ease, transform .2s ease;
}
.rev-modal-close:hover{
  background:rgba(26,26,26,.06);
  transform:rotate(90deg);
}
.rev-modal-head{
  padding:1.5rem 1.5rem 1rem;
  border-bottom:1px solid rgba(26,26,26,.08);
  flex-shrink:0;
}
.rev-modal-headline{
  display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;
  margin-bottom:1rem;
}
.rev-modal-title{
  font-family:var(--sans);
  font-size:1.1rem;
  font-weight:600;
  color:var(--tinta);
  margin:0;
}
.rev-modal-sep{color:rgba(26,26,26,.2);font-weight:300}
.rev-modal-score{
  font-family:var(--sans);
  font-size:1.1rem;
  font-weight:600;
  color:var(--tinta);
}
.rev-modal-count{
  font-size:.82rem;
  color:var(--tinta-soft);
  font-weight:500;
}
.rev-modal-verified{
  display:inline-flex;align-items:center;gap:.3rem;
  font-size:.78rem;
  color:#3d7e44;
  font-weight:500;
}
.rev-modal-verified svg{color:#3d7e44}
.rev-modal-filters{
  display:flex;gap:.45rem;flex-wrap:wrap;
}
.rev-chip{
  display:inline-flex;align-items:center;gap:.35rem;
  padding:.5rem .85rem;
  background:#F5F5F5;
  border:1px solid transparent;
  border-radius:4px;
  font-family:var(--sans);
  font-size:.78rem;
  color:var(--tinta);
  font-weight:500;
  cursor:pointer;
  transition:background .2s ease, border-color .2s ease;
}
.rev-chip:hover{background:#EBEBEB}
.rev-chip.is-active,
.rev-chip.is-current{
  background:#fff;
  border-color:var(--tinta);
}
.rev-chip svg{color:var(--tinta-soft)}

.rev-modal-body{
  flex:1;
  overflow-y:auto;
  padding:.5rem 1.5rem 1rem;
}
/* Sentinel + final markers para infinite scroll */
.rev-end-sentinel{
  height:1px;width:100%;
  pointer-events:none;
}
.rev-end{
  text-align:center;
  padding:1.5rem .5rem;
  font-size:.78rem;
  color:var(--taupe);
  font-style:italic;
  font-family:var(--serif);
}

/* Cards de reseña dentro del modal */
.rev-card{
  display:grid;
  grid-template-columns:1fr auto;
  gap:1rem;
  padding:1.2rem 0;
  border-bottom:1px solid rgba(26,26,26,.07);
}
.rev-card:last-child{border-bottom:0}
.rev-card-main{display:flex;flex-direction:column;gap:.5rem}
.rev-card-top{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap}
.rev-avatar{
  width:32px;height:32px;
  border-radius:50%;
  background:var(--beige);
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--serif);
  font-size:.85rem;
  color:var(--tinta);
  flex-shrink:0;
  letter-spacing:0;
  font-weight:400;
}
.rev-card-stars{color:#FFA801;letter-spacing:.05em;line-height:1}
.rev-card-meta{
  font-size:.78rem;
  color:var(--tinta-soft);
}
.rev-card-meta strong{color:var(--tinta);font-weight:500}
.rev-card-body{
  font-size:.88rem;
  color:var(--tinta);
  line-height:1.55;
}
.rev-card-foot{
  display:flex;align-items:center;gap:.85rem;flex-wrap:wrap;
  font-size:.72rem;
  color:var(--tinta-soft);
  margin-top:.25rem;
}
.rev-card-foot .rev-author{font-weight:500;color:var(--tinta)}
.rev-card-foot .rev-sep{color:rgba(26,26,26,.25)}
.rev-card-helpful{
  display:inline-flex;align-items:center;gap:.3rem;
  margin-left:auto;
  color:var(--tinta-soft);
  font-size:.72rem;
}
.rev-card-imgs{
  display:flex;gap:.3rem;
  flex-shrink:0;
  align-self:flex-start;
}
.rev-card-imgs img{
  width:64px;height:64px;
  object-fit:cover;
  border-radius:2px;
  background:var(--beige);
}
.rev-card-imgs-more{
  position:relative;
  width:64px;height:64px;
}
.rev-card-imgs-more::after{
  content:'+' attr(data-more);
  position:absolute;inset:0;
  background:rgba(26,26,26,.55);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:.85rem;
  font-weight:500;
}

.rev-empty{
  padding:3rem 1rem;
  text-align:center;
  color:var(--tinta-soft);
  font-style:italic;
  font-family:var(--serif);
}

@media (max-width:640px){
  .rev-modal-panel{width:100vw;max-height:100vh;border-radius:0;top:0;left:0;transform:none;transform-origin:0 0}
  .rev-modal.is-open .rev-modal-panel{transform:none}
  .rev-card{grid-template-columns:1fr;gap:.75rem}
  .rev-card-imgs img{width:54px;height:54px}
}
.btn-link{
  font-size:.82rem;
  color:var(--tinta);
  text-decoration:underline;
  text-underline-offset:6px;
  text-decoration-thickness:1px;
  text-decoration-color:var(--taupe);
  letter-spacing:.04em;
  font-weight:400;
}
.btn-link:hover{color:var(--taupe-deep);text-decoration-color:var(--tinta)}

/* ============ SECTION COMMONS ============ */
.section-num{
  display:inline-flex;align-items:center;gap:.85rem;
  font-family:var(--sans);
  font-size:.68rem;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--taupe);
  margin-bottom:1.8rem;
  font-weight:500;
  position:relative;
  padding:0;
}
.section-num::before{
  content:'';
  display:inline-block;
  width:28px;height:1px;
  background:currentColor;
  opacity:.5;
  flex-shrink:0;
}
/* Cuando el padre está centrado, mantener el eyebrow centrado con línea a ambos lados */
[style*="text-align:center"] .section-num,
.faq .section-num,
.cuidado-content .section-num{
  display:inline-flex;
}
.faq .section-num::after,
.cuidado-content .section-num::after{
  content:'';
  display:inline-block;
  width:28px;height:1px;
  background:currentColor;
  opacity:.5;
  flex-shrink:0;
}
.section-title{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(2.25rem, 5.5vw, 4rem);
  line-height:1.05;
  letter-spacing:-.015em;
  padding-top:.08em;
  overflow:visible;
  color:var(--tinta);
}
.section-title em{font-style:italic;font-weight:300}

/* ============ 2. FEATURES ============ */
.features{
  background:transparent;
  padding:var(--section-pad) var(--gutter);
}
.features-grid{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:3rem 2.5rem;
}
.feat{
  display:flex;flex-direction:column;gap:.6rem;
  padding-top:1.5rem;
  border-top:1px solid var(--tinta);
  position:relative;
}
.feat-num{
  position:absolute;top:1.5rem;right:0;
  font-family:var(--serif);
  font-style:italic;
  font-size:.85rem;
  color:var(--taupe);
}
.feat h3{
  font-family:var(--serif);
  font-weight:400;
  font-size:1.25rem;
  line-height:1.25;
  letter-spacing:-.005em;
  color:var(--tinta);
}
.feat p{
  font-size:.92rem;
  color:var(--tinta-soft);
  line-height:1.6;
  max-width:18rem;
}
@media (max-width:900px){
  .features-grid{grid-template-columns:repeat(2,1fr);gap:2.5rem 2rem}
}
@media (max-width:480px){
  .features-grid{grid-template-columns:1fr;gap:2rem}
}

/* ============ SCROLL-SCRUB genérico (.scrub > .scrub-sticky > .scrub-video) ============ */
.scrub{
  position:relative;
  width:100%;
  height:250vh;
  background:var(--crema);
  isolation:isolate;
}
/* Editorial entra POR ENCIMA del hero magazine como cortina */
.scrub.editorial{
  z-index:10;
  margin-top:-100vh;
  margin-top:-100svh;
}
.scrub-sticky{
  position:sticky;top:0;
  width:100%;
  height:100vh;
  height:100svh;
  overflow:hidden;
  background:var(--crema);
}
.scrub-video{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  object-position:center center;
  background:var(--crema);
  display:block;
  pointer-events:none;
  /* Forzar GPU compositing → reduce el granulado en mobile durante scroll */
  transform:translateZ(0);
  -webkit-transform:translateZ(0);
  will-change:transform;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
  image-rendering:high-quality;
  image-rendering:-webkit-optimize-contrast;
}
/* Videos mobile son ya 9:16 → cover llena perfecto sin pixelar */

/* ============ 3. EDITORIAL · scroll-scrub con features glass cards arriba + quote abajo ============ */
.ed-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(245,239,230,.55) 0%, rgba(245,239,230,.20) 35%, rgba(245,239,230,.20) 65%, rgba(245,239,230,.65) 100%);
  z-index:2;
  pointer-events:none;
}
.editorial-content{
  position:absolute;
  inset:0;
  z-index:3;
  padding:clamp(5rem, 10vw, 9rem) var(--gutter) clamp(2.5rem, 5vw, 4rem);
  display:flex;flex-direction:column;justify-content:space-between;align-items:stretch;gap:1.5rem;
  pointer-events:none;
}
.editorial-content .features-grid{
  max-width:var(--max);
  width:100%;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1rem;
  pointer-events:auto;
}
.feat-glass{
  background:rgba(245,239,230,.88);
  backdrop-filter:blur(10px) saturate(1.1);
  -webkit-backdrop-filter:blur(10px) saturate(1.1);
  padding:1.3rem 1.1rem 1.5rem;
  border:1px solid rgba(26,26,26,.06);
  position:relative;
  display:flex;flex-direction:column;gap:.55rem;
}
.feat-glass .feat-num{
  position:absolute;
  top:.85rem;right:1.1rem;
  font-family:var(--serif);
  font-style:italic;
  font-size:.78rem;
  color:var(--taupe);
}
.feat-glass h3{
  font-family:var(--serif);
  font-weight:400;
  font-size:1.1rem;
  line-height:1.2;
  letter-spacing:-.005em;
  color:var(--tinta);
  padding-right:1.5rem;
}
.feat-glass p{
  font-size:.82rem;
  color:var(--tinta-soft);
  line-height:1.55;
  max-width:none;
}
.ed-quote{
  z-index:3;
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(1.5rem, 4vw, 2.6rem);
  line-height:1.15;
  color:var(--crema);
  letter-spacing:-.01em;
  max-width:32rem;
  text-shadow:0 2px 24px rgba(0,0,0,.45);
  margin:0 auto;
  align-self:center;
  text-align:center;
}
.ed-quote em{font-style:italic;color:var(--crema)}

@media (max-width:900px){
  .editorial-content .features-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}
  .feat-glass{padding:1.1rem .9rem 1.3rem}
  .feat-glass h3{font-size:1rem}
  .feat-glass p{font-size:.78rem}
}
@media (max-width:480px){
  .editorial-content{padding:5rem 1rem 1.5rem;gap:1rem}
  .feat-glass{padding:.95rem .85rem 1.1rem;gap:.4rem}
  .feat-glass h3{font-size:.92rem}
  .feat-glass p{font-size:.72rem;line-height:1.45}
  .ed-quote{font-size:1.15rem;line-height:1.25;max-width:18rem}
}

/* ============ 4. PRODUCTO ============ */
.producto{
  position:relative;
  z-index:15;                /* cubre al editorial (z-index 10) al salir */
  margin-top:-100vh;         /* se desliza encima del último viewport del editorial */
  margin-top:-100svh;
  background:var(--crema);
  padding:var(--section-pad) var(--gutter) clamp(2rem, 4vw, 3rem);
  width:100%;
}
.prod-head{
  max-width:var(--max);
  margin:0 auto 3rem;
}
.prod-grid{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:clamp(2rem, 5vw, 5rem);
  align-items:start;
}
.prod-gallery{display:flex;flex-direction:column;gap:.85rem;position:relative}
.prod-main{
  display:block;
  width:100%;
  aspect-ratio:1023/1300;
  object-fit:cover;
  object-position:center top;
  background:transparent;
  min-height:280px;
  opacity:1 !important;
  transform:none !important;
}
.prod-thumbs{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:flex-start}
.swatch{
  width:48px;height:48px;
  position:relative;
  background:transparent;
  border:1px solid transparent;
  cursor:pointer;
  padding:0;
  transition:border-color .25s ease;
}
.swatch::before{
  content:'';
  position:absolute;
  inset:6px;
  border-radius:50%;
  background:var(--swatch);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.08);
  transition:transform .25s ease;
}
.swatch:hover::before{transform:scale(1.08)}
.swatch.is-active{border-color:var(--tinta)}
.prod-colorname{
  font-family:var(--serif);
  font-style:italic;
  font-size:.95rem;
  color:var(--taupe);
  letter-spacing:.04em;
  text-transform:lowercase;
  margin-top:.25rem;
}

/* prod info right */
.prod-info{padding-top:.25rem}
.prod-tag{
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--taupe);
  font-weight:500;
  margin-bottom:1rem;
}
.prod-name{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(1.8rem, 3.5vw, 2.5rem);
  line-height:1.1;
  letter-spacing:-.01em;
  margin-bottom:1.5rem;
}
/* Claim editorial — voz de marca italic */
.prod-claim{
  font-family:var(--serif);
  font-weight:300;
  font-size:1.25rem;
  line-height:1.4;
  color:var(--tinta);
  margin-bottom:1rem;
  max-width:32rem;
}
.prod-claim em{font-style:italic;color:var(--taupe-deep)}

/* Spec técnica — sans, soft, debajo del claim */
.prod-desc{
  font-size:.92rem;
  line-height:1.6;
  color:var(--tinta-soft);
  margin-bottom:2rem;
  max-width:32rem;
}

/* Price layout reestructurado: número grande + subtítulo en línea */
.prod-price{
  display:flex;flex-direction:column;gap:.25rem;
  padding:1.5rem 0;
  border-top:1px solid rgba(26,26,26,.1);
  border-bottom:1px solid rgba(26,26,26,.1);
  margin-bottom:1.75rem;
}
.pp-now{
  font-family:var(--serif);
  font-size:2.5rem;
  font-weight:400;
  color:var(--tinta);
  letter-spacing:-.015em;
  font-variant-numeric:tabular-nums;
  line-height:1;
}
.pp-sub{
  display:flex;align-items:baseline;gap:.5rem;
  font-size:.82rem;
  color:var(--taupe);
  font-variant-numeric:tabular-nums;
}
.pp-old{text-decoration:line-through}
.pp-sep{opacity:.5}
.pp-off{color:var(--tinta-soft);font-weight:500}

/* Bundle badge dentro de prod-price */
.pp-bundle{
  display:inline-flex;align-items:center;gap:.55rem;
  margin-top:.85rem;
  padding:.5rem .85rem .5rem .65rem;
  background:var(--beige);
  font-size:.85rem;
  color:var(--tinta);
  font-family:var(--sans);
  letter-spacing:.005em;
  width:fit-content;
  font-variant-numeric:tabular-nums;
}
.pp-bundle strong{font-weight:600}
.pp-bundle-tag{
  font-family:var(--sans);
  font-size:.62rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--crema);
  background:var(--tinta);
  padding:.25rem .55rem;
  font-weight:500;
}
.prod-meta{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1.25rem;
  margin-bottom:2rem;
  padding-bottom:1.75rem;
  border-bottom:1px solid rgba(26,26,26,.06);
}
.pm-h{
  font-size:.65rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--taupe);
  margin-bottom:.35rem;
  font-weight:500;
}
.pm-v{font-size:.88rem;color:var(--tinta);line-height:1.4}
.prod-stock{
  font-size:.78rem;
  color:var(--taupe);
  margin-top:1rem;
  letter-spacing:.04em;
  font-style:italic;
  font-family:var(--serif);
  text-align:center;
}
@media (max-width:900px){
  .prod-grid{grid-template-columns:1fr;gap:2.5rem}
  .prod-gallery{position:static}
  .prod-main{max-width:560px}
}
@media (max-width:480px){
  .prod-meta{grid-template-columns:1fr;gap:1rem}
  .pp-off{display:none}
  .prod-price{flex-wrap:wrap}
}

/* ============ 5. DETALLE ============ */
.detalle{
  background:transparent;
  padding:clamp(2rem, 4vw, 3rem) var(--gutter) var(--section-pad);
}
.detalle-grid{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns:.78fr 1fr;
  align-items:start;
  gap:clamp(2rem, 5vw, 5rem);
  align-items:center;
}
.det-img{
  aspect-ratio:1152/2048;
  background:transparent;
  max-width:420px;
  margin:0 auto;
  width:100%;
}
.det-img img{width:100%;height:auto;display:block}
.det-info .section-num{margin-bottom:1rem}
.det-info .section-title{margin-bottom:2.5rem}
.det-list{
  display:flex;flex-direction:column;
}
.det-list > div{
  display:grid;
  grid-template-columns:140px 1fr;
  gap:1.5rem;
  padding:1.1rem 0;
  border-top:1px solid rgba(26,26,26,.1);
  align-items:baseline;
}
.det-list > div:last-child{border-bottom:1px solid rgba(26,26,26,.1)}
.det-list dt{
  font-size:.7rem;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--taupe);
  font-weight:500;
}
.det-list dd{
  font-size:.95rem;
  color:var(--tinta);
  line-height:1.55;
}
@media (max-width:900px){
  .detalle-grid{grid-template-columns:1fr;gap:2.5rem}
  .det-img{max-width:520px}
}
@media (max-width:480px){
  .det-list > div{grid-template-columns:1fr;gap:.3rem;padding:.85rem 0}
}

/* ============ 6. HANNA · about ============ */
.hanna{
  padding:var(--section-pad) var(--gutter) clamp(2rem, 4vw, 3rem);
  background:var(--crema);
}
.hanna-grid{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:clamp(2rem, 5vw, 5rem);
  align-items:center;
}
.hanna-img{
  aspect-ratio:1023/1300;
  overflow:hidden;
  position:relative;
}
.hanna-img img{width:100%;height:100%;object-fit:cover;object-position:center top}
.hanna-text{
  display:flex;flex-direction:column;
  justify-content:center;
}
.hanna-text .section-num{margin-bottom:.8rem}
.hanna-text .section-title{margin-bottom:1.5rem}
.hanna-text p{margin-bottom:1rem}
.hanna-text .section-num{margin-bottom:1rem}
.hanna-text .section-title{margin-bottom:2rem}
.hanna-text p{
  font-size:1.02rem;
  line-height:1.75;
  color:var(--tinta-soft);
  margin-bottom:1.25rem;
  max-width:34rem;
}
.hanna-sign{
  font-family:var(--serif);
  font-style:italic;
  color:var(--taupe);
  margin-top:1.5rem !important;
  font-size:.95rem;
}
@media (max-width:900px){
  .hanna-grid{grid-template-columns:1fr;gap:2.5rem}
  .hanna-img{max-width:520px}
}

/* ============ 7. CUIDADO · scroll-scrub con cards encima del vídeo ============ */
.cuidado-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(245,239,230,.55) 0%, rgba(245,239,230,.20) 35%, rgba(245,239,230,.20) 65%, rgba(245,239,230,.65) 100%);
  z-index:2;
  pointer-events:none;
}
.cuidado-content{
  position:absolute;
  inset:0;
  z-index:3;
  padding:clamp(2.5rem, 6vw, 5rem) var(--gutter);
  display:flex;flex-direction:column;justify-content:space-between;align-items:center;
  pointer-events:none;
}
.cuidado-header{
  display:flex;flex-direction:column;align-items:center;gap:.4rem;
  text-align:center;
}
.cuidado-content .section-num{
  color:var(--tinta);
  text-shadow:0 1px 12px rgba(245,239,230,.8);
}
.cuidado-content .section-title{
  color:var(--tinta);
  text-shadow:0 2px 18px rgba(245,239,230,.7);
}
.cuidado-content .care-grid{
  width:100%;
  pointer-events:auto;
}
.care-grid{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1.25rem;
}
.care-card{
  background:rgba(245,239,230,.92);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  padding:1.5rem 1.25rem 1.75rem;
  display:flex;flex-direction:column;gap:.7rem;
  position:relative;
  border:1px solid rgba(26,26,26,.05);
}
.care-num{
  position:absolute;
  top:.85rem;right:1.1rem;
  font-family:var(--serif);
  font-style:italic;
  font-size:.8rem;
  color:var(--taupe);
}
.care-card h3{
  font-family:var(--serif);
  font-weight:400;
  font-size:1.25rem;
  letter-spacing:-.005em;
}
.care-card p{
  font-size:.86rem;
  color:var(--tinta-soft);
  line-height:1.55;
}
@media (max-width:900px){
  .care-grid{grid-template-columns:repeat(2,1fr);gap:.8rem}
  .care-card{padding:1.2rem 1rem 1.4rem}
  .care-card h3{font-size:1.1rem}
  .care-card p{font-size:.8rem}
}
@media (max-width:480px){
  .care-grid{grid-template-columns:1fr 1fr;gap:.6rem}
  .cuidado-content{padding-top:1.5rem;padding-bottom:1.5rem}
}

/* ============ 8. TESTIMONIOS placeholder ============ */
.testimonios{
  padding:var(--section-pad) var(--gutter);
  max-width:48rem;
  margin:0 auto;
  text-align:center;
}
.testimonios .section-num{margin-bottom:1.5rem}
.testimonios .section-title{margin-bottom:2rem}
.testi-placeholder{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.1rem;
  color:var(--tinta-soft);
  line-height:1.7;
  max-width:34rem;
  margin:0 auto;
}

/* ============ 9. FAQ ============ */
.faq{
  padding:clamp(2rem, 4vw, 3rem) var(--gutter) var(--section-pad);
  max-width:var(--max);
  margin:0 auto;
  text-align:center;
}
.faq .section-num{text-align:center}
.faq .section-title{
  margin-bottom:3rem;
  text-align:center;
}
.faq-list{
  max-width:46rem;
  margin:0 auto;
  text-align:left;
}
.faq-item{border-top:1px solid rgba(26,26,26,.1);padding:0}
.faq-item:last-child{border-bottom:1px solid rgba(26,26,26,.1)}
.faq-item summary{
  display:flex;align-items:center;justify-content:space-between;
  gap:2rem;padding:1.4rem 0;cursor:pointer;list-style:none;
  font-family:var(--serif);
  font-size:1.15rem;font-weight:400;color:var(--tinta);
  line-height:1.4;letter-spacing:-.005em;
  transition:color .25s ease;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--taupe-deep)}
.faq-icon{
  width:16px;height:16px;flex-shrink:0;position:relative;
  transition:transform .35s cubic-bezier(.2,.7,.2,1);
}
.faq-icon::before,.faq-icon::after{
  content:'';position:absolute;background:var(--tinta);
  top:50%;left:50%;transform:translate(-50%,-50%);
}
.faq-icon::before{width:14px;height:1px}
.faq-icon::after{width:1px;height:14px}
.faq-item[open] .faq-icon{transform:rotate(45deg)}
.faq-body{
  padding:0 0 1.5rem;max-width:36rem;
  font-size:.95rem;line-height:1.75;color:var(--tinta-soft);
  animation:faqFade .35s ease;
}
@keyframes faqFade{
  from{opacity:0;transform:translateY(-4px)}
  to{opacity:1;transform:translateY(0)}
}

/* ============ 10. CIERRE oscuro + LISTA ============ */
.cierre{
  background:var(--tinta);
  color:var(--crema);
  padding:var(--section-pad) var(--gutter);
}
.cierre-inner{
  max-width:42rem;margin:0 auto;text-align:center;
}
.cierre-inner .section-num{margin-bottom:1.5rem}
.cierre-h{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(2.5rem, 6.5vw, 4.5rem);
  line-height:1.05;
  letter-spacing:-.018em;
  color:var(--crema);
  padding-top:.08em;
  margin-bottom:2rem;
}
.cierre-h em{font-style:italic;font-weight:300;color:var(--taupe)}
.cierre-sub{
  font-size:1rem;
  color:rgba(245,239,230,.78);
  line-height:1.7;
  max-width:34rem;
  margin:0 auto 2.5rem;
}
.cierre-sub strong{color:var(--crema);font-weight:500}

.waitlist-count{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--taupe);margin-bottom:1.5rem;font-weight:500;
}
.wc-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--taupe);position:relative;display:inline-block;
}
.wc-dot::after{
  content:'';position:absolute;inset:-3px;border-radius:50%;
  border:1px solid var(--taupe);opacity:.5;
  animation:wcPulse 2.4s ease-out infinite;
}
@keyframes wcPulse{0%{transform:scale(.6);opacity:.7}100%{transform:scale(1.8);opacity:0}}

.cierre-form{
  display:flex;gap:.5rem;max-width:30rem;margin:0 auto;
  border-bottom:1px solid var(--crema);padding-bottom:.25rem;
}
.cierre-form input{
  flex:1;border:0;background:transparent;
  font-family:var(--sans);font-size:1rem;padding:.85rem .25rem;
  color:var(--crema);outline:none;
}
.cierre-form input::placeholder{color:rgba(245,239,230,.45)}
.cierre-form button{
  border:0;background:transparent;
  font-family:var(--sans);font-size:.78rem;
  letter-spacing:.22em;text-transform:lowercase;
  color:var(--crema);cursor:pointer;padding:.85rem 1rem;
  transition:color .25s ease, transform .25s ease;font-weight:500;
}
.cierre-form button:hover{color:var(--taupe);transform:translateX(3px)}
.cierre-note{
  font-size:.78rem;color:rgba(245,239,230,.55);
  margin-top:1.5rem;letter-spacing:.04em;
}
.cierre-note.ok{color:var(--crema)}
.cierre-note.err{color:#e88}

/* ============ FOOTER ============ */
.ft{
  background:var(--tinta);
  color:var(--crema);
  padding:4rem var(--gutter) 2rem;
  border-top:1px solid rgba(245,239,230,.08);
}
.ft-cols{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:3rem;
  padding-bottom:3rem;
  border-bottom:1px solid rgba(245,239,230,.12);
}
.ft-wordmark{
  margin:0 0 .75rem;
  display:flex;align-items:center;
}
.ft-wordmark img{
  width:auto;
  height:96px;
  display:block;
  opacity:.95;
}
@media (max-width:768px){
  .ft-wordmark{justify-content:center}
}
.ft-tag{
  font-size:.78rem;letter-spacing:.12em;
  color:var(--taupe);text-transform:uppercase;
}
.ft-links{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.ft-h{
  font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--taupe);margin-bottom:1rem;font-weight:500;
}
.ft-links a{
  display:block;font-size:.95rem;padding:.35rem 0;color:var(--crema);
}
.ft-links a:hover{color:var(--taupe)}
.ft-links a small{font-size:.7rem;color:var(--taupe);margin-left:.4rem;letter-spacing:.08em}
.ft-links a[aria-disabled="true"]{opacity:.6;pointer-events:none}
.ft-meta{
  max-width:var(--max);margin:2rem auto 0;
  font-size:.72rem;letter-spacing:.14em;
  color:var(--taupe);text-transform:uppercase;text-align:center;
}
@media (max-width:768px){
  .ft-cols{grid-template-columns:1fr;gap:2.5rem}
  .ft-brand{order:0;text-align:center;width:100%}
  .ft-brand .ft-wordmark,.ft-brand .ft-tag{text-align:center}
  .ft-links{grid-template-columns:1fr 1fr;width:100%}
}

/* ============ HERO FOLIO LIVE DOT ============ */
.folio-live{
  display:inline-block;
  width:7px;height:7px;
  border-radius:50%;
  background:#5fa86d;
  position:relative;
  margin-right:.45rem;
  box-shadow:0 0 0 0 rgba(95,168,109,.6);
  animation:liveBlink 2s ease-in-out infinite;
}
@keyframes liveBlink{
  0%,100%{box-shadow:0 0 0 0 rgba(95,168,109,.5)}
  50%{box-shadow:0 0 0 5px rgba(95,168,109,0)}
}

/* ============ PRODUCT ANGLES ============ */
.prod-angles{
  display:flex;gap:.25rem;flex-wrap:wrap;
  margin-top:.4rem;
  padding:0;
}
.angle{
  position:relative;
  background:transparent;
  border:0;
  color:var(--taupe);
  font-family:var(--sans);
  font-size:.7rem;
  letter-spacing:.18em;
  text-transform:lowercase;
  padding:.55rem 1rem .85rem;
  cursor:pointer;
  font-weight:500;
  min-height:36px;
  transition:background .25s ease, color .25s ease, border-color .25s ease;
}
.angle{
  transition:color .25s ease;
}
.angle::after{
  content:'';
  position:absolute;
  left:50%;bottom:.3rem;
  height:1px;
  width:0;
  background:var(--tinta);
  transform:translateX(-50%);
  transition:width .35s cubic-bezier(.2,.7,.2,1);
}
.angle:hover{
  color:var(--tinta);
}
.angle:hover::after{
  width:calc(100% - 1.4rem);
}
.angle.is-active{
  color:var(--tinta);
}
.angle.is-active::after{
  width:calc(100% - 1.4rem);
  height:1.5px;
  background:var(--tinta);
}
.angle:focus-visible{outline:2px solid var(--taupe-deep);outline-offset:2px;border-radius:2px}

/* ============ PROD STOCK DOT (verde) ============ */
.prod-stock{display:flex;align-items:center;justify-content:center;gap:.5rem;font-style:normal !important;font-family:var(--sans) !important}
.stock-dot{
  display:inline-block;
  width:7px;height:7px;
  border-radius:50%;
  background:#5fa86d;
  position:relative;
}
.stock-dot::after{
  content:'';
  position:absolute;inset:-3px;
  border-radius:50%;
  border:1px solid #5fa86d;
  opacity:.4;
  animation:wcPulse 2.4s ease-out infinite;
}

/* ============ PROD OPTIONS: size chips + qty stepper ============ */
.prod-options{
  display:flex;flex-direction:column;gap:1.5rem;
  margin-bottom:1.5rem;
}
.opt-block{display:flex;flex-direction:column;gap:.65rem}
.opt-head{
  display:flex;align-items:baseline;justify-content:space-between;gap:1rem;
}
.opt-label{
  font-size:.7rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--taupe);
  font-weight:500;
}
.opt-help{
  font-family:var(--serif);
  font-style:italic;
  font-size:.85rem;
  color:var(--taupe);
  transition:color .25s ease;
}
.opt-help.ok{color:var(--tinta)}

/* Bundle banner — oferta 2×59,99 con peso visual real */
.bundle-banner{
  display:flex;align-items:center;gap:.85rem;
  margin:.4rem 0 .85rem;
  padding:.7rem 1rem .7rem .55rem;
  background:var(--tinta);
  color:var(--crema);
  border:1px solid var(--tinta);
  position:relative;
  overflow:hidden;
  animation:bundleSlideIn .6s cubic-bezier(.2,.7,.2,1) .2s both;
}
@keyframes bundleSlideIn{
  from{opacity:0;transform:translateY(-8px)}
  to{opacity:1;transform:none}
}
/* Brillo deslizante sutil, infinito pero discreto */
.bundle-banner::after{
  content:'';
  position:absolute;top:0;bottom:0;
  left:-30%;width:30%;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(245,239,230,.12) 50%,
    transparent 100%);
  animation:bundleShine 4.5s ease-in-out infinite;
  pointer-events:none;
}
@keyframes bundleShine{
  0%   { left:-30%; }
  60%  { left:130%; }
  100% { left:130%; }
}

.bb-tag{
  flex-shrink:0;
  font-family:var(--sans);
  font-size:.62rem;
  font-weight:600;
  letter-spacing:.22em;
  background:var(--crema);
  color:var(--tinta);
  padding:.35rem .55rem;
  white-space:nowrap;
}
.bb-text{
  flex:1;
  display:flex;flex-direction:column;gap:.05rem;
  line-height:1.25;
}
.bb-text strong{
  font-family:var(--sans);
  font-size:.95rem;
  font-weight:500;
  color:var(--crema);
  font-variant-numeric:tabular-nums;
}
.bb-save{
  font-family:var(--serif);
  font-style:italic;
  font-size:.78rem;
  color:rgba(245,239,230,.7);
  font-variant-numeric:tabular-nums;
}
.bb-arrow{
  flex-shrink:0;
  font-family:var(--sans);
  font-size:1rem;
  color:var(--crema);
  animation:bundleBob 1.8s ease-in-out infinite;
}
@keyframes bundleBob{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(3px)}
}

/* Estado "aplicado" cuando user ya ha subido a 2+ unidades */
.bundle-banner.is-applied{
  background:#3d6e47;          /* verde más profundo y elegante */
  border-color:#3d6e47;
}
.bundle-banner.is-applied .bb-tag{
  background:#a8d4b3;
  color:#1d3527;
}
.bundle-banner.is-applied .bb-arrow{
  animation:none;
  transform:none;
}

@media (prefers-reduced-motion: reduce){
  .bundle-banner::after,
  .bb-arrow{animation:none !important}
  .bundle-banner{animation:none !important}
}

/* Size chips */
.size-chips{display:flex;gap:.45rem;flex-wrap:wrap}
.chip{
  position:relative;
  min-width:54px;min-height:50px;
  padding:.65rem 1rem;
  background:transparent;
  border:1px solid rgba(26,26,26,.18);
  font-family:var(--sans);
  font-size:.92rem;
  font-weight:500;
  letter-spacing:.06em;
  color:var(--tinta);
  cursor:pointer;
  overflow:hidden;
  isolation:isolate;
  transition:border-color .25s ease, color .25s ease, transform .35s cubic-bezier(.2,.7,.2,1);
  font-variant-numeric:tabular-nums;
}
.chip::before{
  content:'';
  position:absolute;
  inset:0;
  background:var(--tinta);
  transform:scaleY(0);
  transform-origin:bottom;
  transition:transform .42s cubic-bezier(.55,.06,.18,1);
  z-index:-1;
}
.chip:hover{
  border-color:var(--tinta);
  transform:translateY(-1px);
}
.chip[aria-checked="true"]{
  border-color:var(--tinta);
  color:var(--crema);
  transform:translateY(0);
}
.chip[aria-checked="true"]::before{
  transform:scaleY(1);
}
.chip:focus-visible{outline:2px solid var(--taupe-deep);outline-offset:2px}

/* Quantity stepper */
.qty-stepper{
  display:inline-flex;align-items:center;
  border:1px solid rgba(26,26,26,.18);
  width:fit-content;
}
.qty-btn{
  width:44px;height:44px;
  background:transparent;border:0;
  font-family:var(--serif);
  font-size:1.3rem;
  font-weight:300;
  color:var(--tinta);
  cursor:pointer;
  transition:background .2s ease;
  line-height:1;
}
.qty-btn:hover{background:var(--beige)}
.qty-btn:disabled{opacity:.3;cursor:not-allowed}
.qty-val{
  min-width:44px;
  text-align:center;
  font-family:var(--sans);
  font-size:.95rem;
  font-weight:500;
  font-variant-numeric:tabular-nums;
  color:var(--tinta);
  border-left:1px solid rgba(26,26,26,.18);
  border-right:1px solid rgba(26,26,26,.18);
  padding:.6rem 0;
}

/* Selección consolidada antes del CTA */
.prod-selection{
  display:flex;flex-wrap:wrap;align-items:baseline;gap:.4rem;
  padding:1rem 0;
  font-family:var(--serif);
  font-style:italic;
  font-size:.92rem;
  color:var(--tinta);
  margin-bottom:.85rem;
  border-top:1px solid rgba(26,26,26,.08);
}
.sel-sep{color:var(--taupe);opacity:.6}
.sel-piece.sel-pending{color:var(--taupe);font-style:italic}

/* CTA disabled state (mientras no haya talla elegida) */
.btn[data-disabled="true"]{
  background:transparent !important;
  color:var(--taupe) !important;
  border-color:rgba(26,26,26,.2) !important;
  cursor:not-allowed;
}
.btn[data-disabled="true"]:hover{
  transform:none !important;
  background:transparent !important;
  color:var(--taupe-deep) !important;
}

/* ============ SIZE TABLE (colapsable dentro de prod-info) ============ */
.size-table{
  border-top:1px solid rgba(26,26,26,.1);
  border-bottom:1px solid rgba(26,26,26,.1);
  margin-bottom:1.5rem;
}
.size-table summary{
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;
  padding:1rem 0;
  cursor:pointer;
  list-style:none;
  font-family:var(--sans);
  font-size:.85rem;
  letter-spacing:.02em;
  color:var(--tinta);
  font-weight:400;
  transition:color .25s ease;
}
.size-table summary em{
  font-family:var(--serif);
  font-style:italic;
  color:var(--taupe);
  font-size:.9rem;
  margin-left:.2em;
}
.size-table summary::-webkit-details-marker{display:none}
.size-table summary:hover{color:var(--taupe-deep)}
.size-table[open] .faq-icon{transform:rotate(45deg)}
.size-table-body{
  padding:.5rem 0 1.25rem;
  animation:faqFade .35s ease;
}
.size-table table{
  width:100%;
  border-collapse:collapse;
  font-size:.85rem;
}
.size-table thead th{
  text-align:left;
  font-family:var(--sans);
  font-size:.65rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--taupe);
  font-weight:500;
  padding:.5rem .25rem;
  border-bottom:1px solid rgba(26,26,26,.1);
}
.size-table tbody td{
  padding:.55rem .25rem;
  border-bottom:1px solid rgba(26,26,26,.05);
  color:var(--tinta);
  font-variant-numeric:tabular-nums;
}
.size-table tbody tr:last-child td{border-bottom:0}
.size-table tbody td:first-child{
  font-family:var(--serif);
  font-weight:400;
  font-size:.95rem;
}
.size-note{
  margin-top:1rem;
  font-size:.78rem;
  line-height:1.5;
  color:var(--tinta-soft);
}
.size-note strong{color:var(--tinta);font-weight:500}

/* ============ RESEÑAS ============ */
.resenas{
  background:transparent;
  padding:clamp(2rem, 4vw, 3rem) var(--gutter);
}
.res-summary{
  max-width:var(--max);
  margin:0 auto 3.5rem;
  border-bottom:1px solid rgba(26,26,26,.1);
  padding-bottom:2.5rem;
}
.res-title{
  margin-bottom:2.5rem;
  text-align:left;
}
.res-meta{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:3rem;
  align-items:start;
}
.res-rate{
  display:flex;flex-direction:column;gap:.5rem;
  flex-shrink:0;
}
.res-stars{display:flex;gap:.25rem}
.res-stars svg{
  width:22px;height:22px;
  fill:var(--taupe);
}
.res-score{
  display:flex;align-items:baseline;gap:.3rem;
  font-family:var(--serif);
  font-weight:300;
  font-size:2rem;
  color:var(--tinta);
  font-variant-numeric:tabular-nums;
  line-height:1;
  margin-top:.5rem;
}
.res-score strong{font-weight:400;font-size:2.5rem}
.res-score span{color:var(--taupe);font-size:1.2rem}
.res-score-label{
  font-size:.7rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--taupe);
  font-weight:500;
  margin-top:.3rem;
}
.res-count{
  max-width:42rem;
  padding-top:.6rem;
  line-height:1.5;
}
.res-count em{
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  font-size:1.5rem;
  letter-spacing:-.01em;
  color:var(--tinta);
}
.res-count-sub{
  display:inline-block;
  margin-top:.4rem;
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--taupe);
  font-weight:500;
}

@media (max-width:768px){
  .res-meta{
    grid-template-columns:1fr;
    gap:1.5rem;
  }
}

.res-grid{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1.25rem;
  position:relative;
}
/* Colapsado por defecto: solo 9 cards visibles */
.res-grid.is-collapsed .res-card:nth-child(n+10){
  display:none;
}
/* Fade gradient sobre la última fila visible (sugiere que hay más) */
.res-grid.is-collapsed::after{
  content:'';
  position:absolute;
  left:0;right:0;bottom:0;
  height:140px;
  background:linear-gradient(180deg, rgba(245,239,230,0) 0%, var(--crema) 100%);
  pointer-events:none;
}

/* Botón Ver más */
.res-more-wrap{
  max-width:var(--max);
  margin:2.5rem auto 0;
  display:flex;justify-content:center;
}
.res-more{
  display:inline-flex;align-items:center;gap:.8rem;
  background:transparent;
  border:1px solid var(--tinta);
  color:var(--tinta);
  font-family:var(--sans);
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:lowercase;
  font-weight:500;
  padding:1.05rem 2rem;
  cursor:pointer;
  min-height:48px;
  transition:background .3s ease, color .3s ease, transform .3s ease;
}
.res-more:hover{
  background:var(--tinta);
  color:var(--crema);
  transform:translateY(-2px);
}
.rm-arrow{
  display:inline-block;
  font-size:.95rem;
  transition:transform .35s cubic-bezier(.2,.7,.2,1);
}
.res-more[aria-expanded="true"] .rm-arrow{
  transform:rotate(180deg);
}
.res-card{
  background:var(--crema);
  padding:0 0 1.5rem;
  display:flex;flex-direction:column;gap:.85rem;
  border:1px solid rgba(26,26,26,.05);
  overflow:hidden;
}
.res-photo{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  display:block;
  background:var(--beige);
}
.res-card .res-card-stars{padding:1.25rem 1.5rem 0}
.res-card .res-body{padding:0 1.5rem}
.res-card .res-foot{padding:0 1.5rem}
.res-card-stars{
  font-size:1rem;
  color:var(--taupe);
  letter-spacing:.15em;
  line-height:1;
}
.res-card-stars .star-empty{color:rgba(168,155,138,.3)}
.res-body{
  font-size:.92rem;
  line-height:1.65;
  color:var(--tinta);
  flex:1;
}
.res-foot{
  display:flex;flex-direction:column;gap:.2rem;
  padding-top:.85rem;
  border-top:1px solid rgba(26,26,26,.08);
  margin-top:.4rem;
}
.res-name{
  font-family:var(--serif);
  font-weight:400;
  font-size:.95rem;
  color:var(--tinta);
}
.res-meta{
  font-size:.72rem;
  color:var(--taupe);
  letter-spacing:.04em;
}

@media (max-width:900px){
  .res-grid{grid-template-columns:repeat(2, 1fr);gap:1rem}
  .res-title{font-size:clamp(1.8rem, 5vw, 2.8rem)}
}
@media (max-width:560px){
  .res-grid{grid-template-columns:1fr;gap:.9rem}
  .res-card{padding:1.5rem 1.25rem 1.25rem}
}

/* ============ CIERRE actualizado ============ */
.cierre-cta{
  display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap;
  margin-bottom:3rem;
}
.cierre-link{
  font-size:.85rem;
  color:rgba(245,239,230,.85);
  text-decoration:underline;
  text-underline-offset:6px;
  text-decoration-color:rgba(245,239,230,.4);
  letter-spacing:.04em;
}
.cierre-link:hover{color:var(--crema);text-decoration-color:var(--crema)}

.cierre-divider{
  width:60px;height:1px;
  background:rgba(245,239,230,.25);
  margin:1.5rem auto 2.5rem;
}
.cierre-news{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.05rem;
  color:rgba(245,239,230,.85);
  line-height:1.5;
  max-width:30rem;
  margin:0 auto 1.5rem;
}

/* ============ A11Y FOCUS RINGS ============ */
a:focus-visible,
button:focus-visible,
input:focus-visible,
summary:focus-visible,
.swatch:focus-visible{
  outline:2px solid var(--tinta);
  outline-offset:3px;
  border-radius:1px;
}
.cierre-form input:focus-visible,
.cierre-form button:focus-visible{outline-color:var(--crema)}

/* ============ MOBILE STICKY CTA ============ */
.sticky-cta{
  position:fixed;left:.6rem;right:.6rem;bottom:.6rem;z-index:60;
  background:rgba(245,239,230,.92);
  backdrop-filter:blur(18px) saturate(1.15);
  -webkit-backdrop-filter:blur(18px) saturate(1.15);
  border:1px solid rgba(26,26,26,.08);
  border-radius:14px;
  padding:.55rem .6rem .55rem .55rem;
  display:none;align-items:center;gap:.7rem;
  transform:translateY(140%);
  transition:transform .4s cubic-bezier(.2,.7,.2,1);
  box-shadow:0 14px 38px -12px rgba(26,26,26,.28), 0 2px 6px -3px rgba(26,26,26,.08);
}
.sticky-cta.is-visible{transform:translateY(0)}
.sc-thumb{
  width:46px;height:46px;
  border-radius:10px;
  object-fit:cover;
  background:#e8e2d5;
  flex-shrink:0;
  border:1px solid rgba(26,26,26,.08);
}
.sc-info{display:flex;flex-direction:column;gap:.1rem;min-width:0;flex:1}
.sc-name{
  font-family:var(--serif);font-size:.92rem;color:var(--tinta);font-weight:400;
  letter-spacing:-.005em;line-height:1.1;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.sc-price{
  font-size:.78rem;color:var(--tinta);font-variant-numeric:tabular-nums;
  display:inline-flex;align-items:baseline;gap:.4rem;
}
.sc-price strong{font-weight:500;font-size:.95rem}
.sc-price s{color:var(--taupe);font-weight:400;font-size:.7rem;opacity:.7}
.sc-off{
  background:var(--tinta);color:var(--crema);
  font-size:.6rem;letter-spacing:.06em;
  padding:.12rem .4rem;border-radius:3px;
  font-weight:600;font-variant-numeric:tabular-nums;
}
.sc-btn{
  flex-shrink:0;
  padding:.85rem 1.2rem;
  background:var(--tinta);color:var(--crema) !important;
  font-size:.72rem;letter-spacing:.18em;text-transform:lowercase;
  font-weight:500;
  border-radius:10px;
  display:inline-flex;align-items:center;gap:.5rem;
  white-space:nowrap;
  box-shadow:0 4px 12px -4px rgba(26,26,26,.35);
  -webkit-tap-highlight-color:transparent;
  user-select:none;
  outline:none;
}
.sc-btn span{color:var(--crema)}
.sc-btn svg{opacity:.85;flex-shrink:0;color:var(--crema)}
@media (hover:hover){
  .sc-btn{transition:background .25s ease}
  .sc-btn:hover{background:var(--taupe-deep)}
}

@media (max-width:768px){
  .sticky-cta{display:flex}
  body{padding-bottom:80px}
}
@media (max-width:380px){
  .sc-thumb{width:42px;height:42px}
  .sc-btn{padding:.75rem .9rem;font-size:.66rem;letter-spacing:.12em}
  .sc-btn span{display:none}
  .sc-name{font-size:.85rem}
}

/* ============ SCROLL PROGRESS ============ */
.scroll-progress{
  position:fixed;top:0;left:0;width:0%;height:2px;
  background:var(--tinta);z-index:70;
  transition:width .1s linear;pointer-events:none;
}

/* ============ REVEAL ON SCROLL ============ */
[data-reveal]{
  opacity:0;transform:translateY(24px);
  transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1);
}
[data-reveal].is-visible{opacity:1;transform:none}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
  [data-reveal]{opacity:1;transform:none}
}

/* ============ 0. INTRO SCROLL-SCRUB ============
   Pin sticky + vídeo all-intra. Scroll mueve currentTime del vídeo.
   Título "Women Essential" en Fraunces se desvanece al primer scroll.
   Fade crema al final → transición suave al hero magazine. */
.intro-scrub{
  position:relative;
  width:100%;
  height:250vh;            /* 1 viewport pinned + 150vh de scroll efectivo */
  background:var(--crema);
  isolation:isolate;
  z-index:0;               /* el hero magazine entra por encima con z-index:5 */
}
.intro-sticky{
  position:sticky;top:0;
  width:100%;
  height:100vh;
  height:100svh;
  overflow:hidden;
  background:var(--crema);
}
.intro-video{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  object-position:center center;
  background:var(--crema);
  display:block;
  pointer-events:none;
}
.intro-vignette{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(26,26,26,.22) 0%, rgba(26,26,26,0) 30%, rgba(26,26,26,0) 70%, rgba(26,26,26,.30) 100%),
    radial-gradient(120% 80% at 50% 50%, rgba(0,0,0,0) 55%, rgba(0,0,0,.25) 100%);
  pointer-events:none;
  z-index:2;
}
.intro-title{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%, -50%);
  z-index:3;
  font-family:var(--serif);
  font-weight:300;
  text-align:center;
  color:var(--crema);
  letter-spacing:-.015em;
  line-height:.95;
  text-shadow:0 2px 40px rgba(0,0,0,.35);
  display:flex;flex-direction:column;align-items:center;gap:.05em;
  opacity:var(--intro-title-opacity, 1);
  transition:opacity .15s linear;
  padding:0 var(--gutter);
  pointer-events:none;
  white-space:nowrap;
}
.intro-word-1{
  font-size:clamp(2.4rem, 9vw, 7rem);
  font-style:normal;
}
.intro-word-2{
  font-size:clamp(2.4rem, 9vw, 7rem);
  font-style:italic;
  font-weight:300;
}
.intro-hint{
  position:absolute;
  left:50%;bottom:clamp(1.5rem, 4vw, 3rem);
  transform:translateX(-50%);
  z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  color:var(--crema);
  opacity:var(--intro-title-opacity, 1);
  transition:opacity .15s linear;
  pointer-events:none;
}
.intro-hint-text{
  font-size:.7rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  font-weight:500;
  opacity:.85;
}
.intro-hint-line{
  width:1px;height:36px;
  background:var(--crema);
  opacity:.65;
  animation:introHintPulse 2.4s ease-in-out infinite;
}
@keyframes introHintPulse{
  0%,100%{transform:scaleY(0.3);transform-origin:top;opacity:.3}
  50%{transform:scaleY(1);transform-origin:top;opacity:.85}
}
.intro-fade{
  position:absolute;inset:0;
  background:var(--crema);
  opacity:var(--intro-fade-opacity, 0);
  z-index:4;
  pointer-events:none;
}

/* Nav oculto mientras la intro está activa (controlado por html.intro-active) */
html.intro-active .nav{
  opacity:0;
  pointer-events:none;
  transform:translateY(-100%);
  transition:opacity .35s ease, transform .35s ease;
}
.nav{
  transition:opacity .45s ease, transform .45s ease, background .35s ease, padding .35s ease, border-color .35s ease, backdrop-filter .35s ease;
}

/* Bloquea scroll-snap molestoso en algunos navegadores durante el scrub */
html.intro-active{
  scroll-behavior:auto;
}

@media (prefers-reduced-motion: reduce){
  .intro-hint-line{animation:none}
}

/* ============ PROD INFO COMPACT (desktop) ============
   Comprime espaciados de la columna derecha para que encaje
   visualmente en paralelo a la foto del producto.
   Solo aplica en grid de 2 columnas (≥901px). */
@media (min-width:901px){
  .prod-info{padding-top:0}
  .prod-tag{margin-bottom:.55rem}
  .prod-name{
    font-size:clamp(1.55rem, 2.6vw, 2.05rem);
    margin-bottom:.85rem;
  }
  .prod-claim{
    font-size:1.1rem;
    margin-bottom:.55rem;
  }
  .prod-desc{margin-bottom:1.1rem}
  .prod-price{
    padding:1rem 0;
    margin-bottom:1.1rem;
  }
  .pp-now{font-size:2.1rem}
  .pp-bundle{margin-top:.55rem}
  .prod-meta{
    margin-bottom:1.1rem;
    padding-bottom:1rem;
    gap:.9rem;
  }
  .prod-options{gap:1rem;margin-bottom:1rem}
  .opt-block{gap:.5rem}
  .size-table{margin-bottom:.9rem}
  .size-table summary{padding:.7rem 0}
  .prod-selection{
    padding:.7rem 0;
    margin-bottom:.55rem;
  }
  .prod-stock{margin-top:.55rem}
}

/* =========================================
   FIXES MOBILE — compactar hero/producto/reseñas
   ========================================= */
@media (max-width:640px){
  /* === HERO FOLIOS: apilar uno sobre otro, dejar el de la derecha oculto === */
  .mag-folio-tl{
    top:5rem;left:0;right:0;
    width:max-content;margin:0 auto;
    text-align:center;
    letter-spacing:.22em;font-size:.55rem;
    gap:.45rem;
    padding-bottom:.35rem;
  }
  .mag-folio-tr{display:none}

  /* === PRODUCTO: comprimir y reordenar (botones arriba, descripción abajo) === */
  .producto{padding:3rem 1rem !important}
  .prod-head{margin-bottom:1.4rem}
  .prod-grid{gap:1.2rem}
  .prod-info{
    padding-top:0;
    display:flex;flex-direction:column;
    gap:.7rem;
  }
  .prod-info > *{margin:0 !important}

  /* Reordenar con CSS order — banner verde + stock + talla/cantidad pegados a swatches */
  .prod-price{display:contents}  /* libera bundle-banner, pp-now y pp-sub */
  .bundle-banner{order:1;margin-top:.2rem !important}
  .prod-stock{order:2;margin:.4rem 0 .2rem !important;font-size:.7rem}
  .prod-options{order:3;gap:.7rem !important;margin:.3rem 0 .5rem !important}
  #ctaBtn{order:4;margin-top:.4rem !important}
  #cartBtn{order:5;margin-top:.3rem !important}
  .prod-tag{order:6;font-size:.6rem !important;margin-top:.8rem !important}
  .prod-name{order:7;font-size:1.45rem !important;line-height:1.1}
  .prod-claim{order:8;font-size:.95rem !important}
  .prod-desc{order:9;font-size:.82rem !important;line-height:1.5}
  .pp-now{order:10;font-size:1.85rem !important;margin-top:.5rem !important;display:block}
  .pp-sub{order:11;display:block}
  .prod-meta{order:12;margin-top:.4rem !important;padding-bottom:0 !important;border:0 !important}
  .opt-block{gap:.35rem !important}
  .opt-label{font-size:.62rem !important;letter-spacing:.2em}
  .size-chips{gap:.35rem}
  .size-chips .chip{padding:.55rem 1rem;font-size:.78rem;min-width:42px}
  .qty-stepper{padding:.2rem .4rem}
  .qty-btn{width:30px;height:30px;font-size:1rem}
  .qty-val{font-size:.85rem;padding:0 .4rem}
  .size-table{order:15;margin:.4rem 0 0 !important}
  .size-table summary{padding:.55rem 0 !important;font-size:.72rem}
  .prod-selection{order:13;padding:.5rem 0 !important;margin:0 !important;font-size:.75rem}
  /* CTA principal queda al final por defecto */

  /* === RESEÑAS: comprimir título y header === */
  .res-block,
  section[aria-label*="reseñas"],
  section[aria-label*="Reseñas"]{padding:2.5rem 1rem !important}
  .res-title{
    font-size:1.65rem !important;
    line-height:1.05;
    margin-bottom:1.2rem !important;
  }
  .res-summary{margin-bottom:1.8rem;padding-bottom:1.4rem}
  .res-meta{gap:1rem}
  .res-score{font-size:1.5rem;margin-top:.2rem}
  .res-score strong{font-size:1.85rem}
  .res-score span{font-size:.95rem}
  .res-score-label{font-size:.62rem;letter-spacing:.18em;margin-top:.15rem}
  .res-count{padding-top:.2rem}
  .res-count em{font-size:1.1rem}
  .res-count-sub{font-size:.6rem;letter-spacing:.18em;margin-top:.3rem}

  /* Grid 2 columnas, ocultar 4ª, cards más compactas */
  .res-grid{grid-template-columns:repeat(2,1fr) !important;gap:.7rem !important}
  .res-grid > .res-card:nth-child(4){display:none}
  .res-card{padding:0 0 .85rem !important}
  .res-photo{aspect-ratio:1/1;width:100%;height:auto !important}
  .res-card-stars{font-size:.85rem;padding:.5rem .7rem 0}
  .res-body{font-size:.75rem;line-height:1.4;padding:.35rem .7rem .55rem !important}
  .res-foot{padding:0 .7rem !important;font-size:.7rem}
  .res-name{font-size:.8rem !important}
  .res-meta{font-size:.6rem !important}

  /* === DETALLE / FICHA: título arriba de imagen + compactar === */
  .detalle{padding:3rem 1rem !important}
  .detalle-grid{display:flex;flex-direction:column;gap:1.4rem !important}
  .det-info{order:0;display:contents}  /* dejar que sus hijos hereden orden flex */
  .det-info .section-num{order:1;margin-bottom:.3rem !important;font-size:.6rem !important}
  .det-info .section-title{order:2;font-size:1.65rem !important;line-height:1.05;margin-bottom:1rem !important}
  .det-img{order:3;max-width:340px;margin:0 auto}
  .det-list{order:4;margin-top:.2rem}
  .det-list > div{padding:.65rem 0 !important;grid-template-columns:1fr !important;gap:.2rem !important}
  .det-list dt{font-size:.58rem !important;letter-spacing:.2em;margin:0}
  .det-list dd{font-size:.85rem !important;line-height:1.4;margin:0}

  /* === HANNA: orden mobile = título → foto → texto === */
  .hanna{padding:3rem 1rem !important}
  .hanna-grid{display:flex;flex-direction:column;gap:1.2rem !important}
  .hanna-text{display:contents}  /* libera hijos al flujo del grid */
  .hanna-text .section-num{order:1;margin-bottom:.3rem !important;font-size:.6rem !important}
  .hanna-text .section-title{order:2;font-size:1.65rem !important;line-height:1.05;margin-bottom:.4rem !important}
  .hanna-img{order:3;max-width:300px;margin:0 auto}
  .hanna-text p{order:4}
  .hanna-text .section-num{margin-bottom:.3rem !important;font-size:.6rem !important}
  .hanna-text .section-title{font-size:1.65rem !important;line-height:1.05;margin-bottom:1rem !important}
  .hanna-text p{
    font-size:.85rem !important;
    line-height:1.55 !important;
    margin-bottom:.7rem !important;
  }
}

/* =========================================
   Lightbox para fotos de reseñas
   ========================================= */
.rev-lightbox{
  position:fixed;inset:0;z-index:9999;
  background:rgba(20,18,16,.94);
  display:none;align-items:center;justify-content:center;
  opacity:0;transition:opacity .25s ease;
  padding:2rem;
}
.rev-lightbox.is-open{display:flex;opacity:1}
.rev-lightbox-img{
  max-width:min(72vw,640px);max-height:78vh;
  object-fit:contain;
  border-radius:4px;
  box-shadow:0 20px 60px rgba(0,0,0,.5);
  cursor:zoom-out;
  user-select:none;
}
.rev-lightbox-close,
.rev-lightbox-prev,
.rev-lightbox-next{
  width:44px;height:44px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);
  border-radius:50%;
  color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s ease;
  flex-shrink:0;
}
.rev-lightbox-close:hover,
.rev-lightbox-prev:hover,
.rev-lightbox-next:hover{background:rgba(255,255,255,.22)}
.rev-lightbox-close{position:absolute;top:1.4rem;right:1.4rem}
.rev-lightbox-prev{margin-right:1rem}
.rev-lightbox-next{margin-left:1rem}
.rev-lightbox-counter{
  position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.72);
  background:rgba(0,0,0,.35);
  padding:.45rem 1rem;border-radius:999px;
}
/* Pointer en miniaturas para indicar clicable */
.rev-card-imgs img,
.res-photo{cursor:zoom-in}

@media (max-width:640px){
  .rev-lightbox{padding:.6rem}
  .rev-lightbox-img{max-height:80vh}
  .rev-lightbox-close{top:.6rem;right:.6rem;width:38px;height:38px}
  .rev-lightbox-prev,
  .rev-lightbox-next{width:38px;height:38px}
  .rev-lightbox-prev{margin-right:.4rem}
  .rev-lightbox-next{margin-left:.4rem}
  .rev-lightbox-counter{bottom:.6rem;font-size:.7rem}
}
