/* ============================================================
   CBM Estudio — premium romantic editorial. Vanilla CSS.
   Palette sampled from the original PDF design.
   ============================================================ */

:root{
  --cream:#FFF4EB;        /* base background */
  --ivory:#FEFFF2;        /* cards / light surfaces */
  --blush:#F7E7E0;        /* soft pink section */
  --blush-deep:#F1D9D0;
  --rose:#CC8E89;         /* rosa empolvado */
  --rose-soft:#E3B8B2;
  --wine:#593238;         /* bordó */
  --wine-deep:#46262B;
  --ink:#231F20;          /* near-black warm (dark buttons) */
  --text:#5B4A43;         /* warm gray-brown body */
  --heading:#2E2422;      /* warm dark headings */
  --muted:#9A857B;        /* secondary serif accent */
  --gold:#C7A66B;         /* subtle champagne accent */
  --nude:#C8A28D;         /* nude cálido premium (estudio / gran día) */
  --line:rgba(89,50,56,.16);

  --serif:'Cormorant Garamond', Georgia, serif;
  --script:'Pinyon Script', cursive;
  --sans:'Jost', system-ui, sans-serif;

  --wrap:1180px;
  --pad:clamp(1.25rem, 5vw, 4rem);
  --r:14px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html{
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
body{
  margin:0;
  background:var(--cream);
  color:var(--text);
  font-family:var(--sans);
  font-weight:300;
  font-size:clamp(15px,1.05vw,16.5px);
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  font-kerning:normal;
  font-optical-sizing:auto;
  font-feature-settings:"kern" 1,"liga" 1,"calt" 1;
  font-variant-numeric:oldstyle-figures proportional-nums;
}

/* Textura sutil de papel/lino sobre toda la web (premium, casi imperceptible) */
body::before{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.035;mix-blend-mode:multiply;
}

/* Premium OpenType refinements for the display serif */
.display,.hero__lead,.sobre__sign,.card__title,.card__num,.footer__line,.review figcaption strong,.faq__hint{
  font-feature-settings:"kern" 1,"liga" 1,"dlig" 1,"calt" 1,"swsh" 1;
  font-optical-sizing:auto;
}
.display em,.hero__lead,.sobre__sign em{
  font-feature-settings:"kern" 1,"liga" 1,"dlig" 1,"calt" 1,"swsh" 1,"salt" 1;
}
img{display:block;width:100%;height:100%;object-fit:cover}
figure{margin:0}
a{color:inherit;text-decoration:none}
ul{margin:0;padding:0;list-style:none}
em{font-style:italic}

.wrap{max-width:var(--wrap);margin:0 auto;padding-inline:var(--pad)}
.section{padding-block:clamp(4.5rem,10vw,8.5rem)}

/* ---------- Typography helpers ---------- */
.display{
  font-family:var(--serif);
  font-weight:500;
  color:#5B3A37;
  line-height:1.04;
  letter-spacing:.005em;
  font-size:clamp(2.4rem,6vw,4.4rem);
  margin:.2em 0 .35em;
}
.display em{color:var(--muted);font-weight:400}
.display__nude{
  color:var(--nude);
  text-decoration-line:underline;
  text-decoration-color:var(--nude);
  text-decoration-thickness:1px;
  text-underline-offset:.18em;
}
.display em.u{
  color:var(--nude);
  white-space:nowrap;
}
.hero .display{
  font-size:clamp(2.7rem,4.6vw,4.3rem);
  line-height:1.18;
  letter-spacing:0;
  text-align:center;
}
.hero .display::after{
  content:"";display:block;width:130px;height:1px;
  background:var(--nude);margin:.55em auto 0;
}
.display--center{text-align:center}
.display--light{color:var(--ivory)}
.display--light em{color:var(--rose-soft)}

.eyebrow{
  font-family:var(--sans);
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.34em;
  font-size:.72rem;
  color:var(--rose);
  margin:0 0 1rem;
  display:flex;
  align-items:center;
  gap:.95em;
}
.eyebrow::before{
  content:"";
  flex:0 0 auto;
  width:2.6em;
  height:1px;
  background:linear-gradient(90deg, transparent, var(--nude));
}
.eyebrow--center{justify-content:center;text-align:center}
.eyebrow--center::after{
  content:"";
  flex:0 0 auto;
  width:2.6em;
  height:1px;
  background:linear-gradient(90deg, var(--nude), transparent);
}
.eyebrow--light{color:var(--rose-soft)}
.eyebrow--light::before,.eyebrow--light::after{background:linear-gradient(90deg, transparent, var(--nude))}
.eyebrow--light::after{background:linear-gradient(90deg, var(--nude), transparent)}

.section__lead{
  text-align:center;max-width:46ch;margin:0 auto clamp(2rem,4vw,3.2rem);
  font-size:1.05rem;color:var(--text);
}

/* ---------- Buttons (glow + sheen) ---------- */
.btn{
  position:relative;isolation:isolate;
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--sans);font-weight:500;
  text-transform:uppercase;letter-spacing:.16em;font-size:.7rem;
  padding:.95em 1.9em;border-radius:4px;
  border:1px solid transparent;cursor:pointer;
  background-size:230% 100%;background-position:140% 0;
  transition:transform .4s var(--ease),background-color .4s var(--ease),color .4s var(--ease),
             box-shadow .4s var(--ease),letter-spacing .4s var(--ease),background-position .8s var(--ease);
}
.btn:hover{transform:translateY(-3px);letter-spacing:.21em;background-position:-40% 0}
.btn:active{transform:translateY(-1px) scale(.985)}
.btn:focus-visible{outline:2px solid var(--rose);outline-offset:3px}

/* glow halo behind the button */
.btn::before{
  content:"";position:absolute;inset:0;border-radius:inherit;z-index:-1;pointer-events:none;
  box-shadow:0 0 0 0 rgba(204,142,137,0);opacity:0;
  transition:box-shadow .45s var(--ease),opacity .45s var(--ease);
}
.btn:hover::before{opacity:1;box-shadow:0 0 28px 4px rgba(204,142,137,.65)}

/* filled CTAs: soft moving sheen + continuous breathing glow that invites a tap */
.btn--solid,.btn--dark,.btn--nude{
  background-image:linear-gradient(115deg,transparent 38%,rgba(255,255,255,.30) 50%,transparent 62%);
}
.btn--solid::before,.btn--dark::before,.btn--nude::before{
  opacity:1;animation:btnBreath 2.9s ease-in-out infinite;
}
.btn--solid:hover::before,.btn--dark:hover::before,.btn--nude:hover::before{animation-duration:1.3s}
@keyframes btnBreath{
  0%,100%{box-shadow:0 0 13px 0 rgba(204,142,137,.30)}
  50%{box-shadow:0 0 27px 4px rgba(204,142,137,.60)}
}

.btn--solid{background-color:var(--wine);color:var(--ivory)}
.btn--solid:hover{background-color:var(--wine-deep)}
.btn--outline{background-color:transparent;color:var(--heading);border-color:var(--heading)}
.btn--outline:hover{background-color:var(--heading);color:var(--cream)}
.btn--dark{background-color:var(--ink);color:#fff}
.btn--dark:hover{background-color:#000}
.btn--nude{background-color:var(--rose-soft);color:var(--wine-deep)}
.btn--nude:hover{background-color:var(--ivory)}

.link-more{
  font-family:var(--sans);font-weight:500;text-transform:uppercase;
  letter-spacing:.14em;font-size:.66rem;color:var(--heading);
  background:none;border:0;border-bottom:1px solid var(--rose);
  padding:0 0 3px;cursor:pointer;
  align-self:flex-start;transition:color .3s,border-color .3s,letter-spacing .3s;
}
.link-more:hover{color:var(--rose);letter-spacing:.2em}

/* ---- Modal de detalle de servicio ---- */
.modal{
  position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;
  padding:clamp(1rem,5vw,3rem);
}
.modal.show{display:flex}
.modal__backdrop{position:absolute;inset:0;background:rgba(46,36,34,.6);backdrop-filter:blur(4px)}
.modal__box{
  position:relative;z-index:1;background:var(--ivory);border-radius:16px;
  border-top:3px solid var(--nude);
  max-width:560px;width:100%;max-height:88vh;overflow:auto;
  box-shadow:0 40px 90px -30px rgba(46,36,34,.6);
  animation:modalIn .4s var(--ease) both;
}
@keyframes modalIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}
.modal__close{
  position:absolute;top:12px;right:14px;z-index:2;
  width:38px;height:38px;border-radius:50%;border:0;cursor:pointer;
  background:rgba(254,255,242,.9);color:var(--wine);font-size:1.6rem;line-height:1;
}
.modal__close:hover{background:#fff}
.modal__content img{display:block;width:calc(100% - clamp(2.6rem,8vw,3.6rem));margin:1.3rem auto .4rem;border-radius:12px}
.modal__content h3{font-family:var(--serif);font-weight:500;font-size:clamp(1.9rem,4.4vw,2.5rem);color:#5B3A37;letter-spacing:.005em;text-align:center;margin:2rem clamp(1.5rem,4vw,2rem) .2rem}
.modal__content h3::after{content:"";display:block;width:56px;height:1px;background:var(--nude);margin:.85rem auto 0}
.modal__content p{margin:1.1rem clamp(1.5rem,4vw,2rem) 0;font-size:1.02rem;line-height:1.8;color:var(--text)}
.modal__content .btn{display:block;width:fit-content;margin:1.8rem auto 2rem}
.svc-details{margin:1.7rem clamp(1.5rem,4vw,2rem) 0;padding-top:1.5rem;border-top:1px solid var(--line)}
.svc-details__title{font-family:var(--serif);font-weight:500;font-size:1.45rem;color:#5B3A37;margin:0 0 1rem}
.svc-meta{display:flex;flex-wrap:wrap;gap:.6rem 2.4rem;margin:0 0 1.5rem;padding:0;list-style:none}
.svc-meta li{font-size:1rem;color:var(--text)}
.svc-meta li span{display:block;font-family:var(--sans);font-weight:500;text-transform:uppercase;letter-spacing:.16em;font-size:.62rem;color:var(--nude);margin-bottom:.2rem}
.svc-details__sub{font-family:var(--serif);font-weight:500;font-size:1.28rem;color:#5B3A37;margin:1.3rem 0 .9rem}
.svc-group{font-family:var(--serif)!important;font-style:italic;font-size:1.12rem;color:var(--nude);margin:1.1rem 0 .55rem!important}
.svc-list{list-style:none;margin:0 0 .9rem;padding:0;display:flex;flex-direction:column;gap:.65rem}
.svc-list li{position:relative;padding-left:1.05rem;font-size:.95rem;line-height:1.6;color:var(--text)}
.svc-list li::before{content:"";position:absolute;left:0;top:.55em;width:5px;height:5px;border-radius:50%;background:var(--nude)}
.svc-list li strong{color:#5B3A37;font-weight:500}
.modal__content img.svc-photo{width:auto;max-width:240px;margin:1.5rem auto .4rem;border-radius:12px}
.svc-details p{margin-left:0;margin-right:0}
.modal__content p.svc-closing{font-family:var(--serif);font-style:italic;font-size:1.15rem;color:#5B3A37;text-align:center;margin-top:1.9rem}
.svc-subtitle{display:block;font-size:.46em;font-weight:400;color:var(--muted);letter-spacing:.01em;line-height:1.35;margin-top:.5em}
.modal__content h3:has(.svc-subtitle){font-size:clamp(2.3rem,5.6vw,3.2rem);color:#3E2422}
.svc-gallery{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:1.4rem clamp(1.5rem,4vw,2rem) .4rem}
.svc-gallery--three{grid-template-columns:1fr 1fr 1fr}
.modal__content .svc-gallery img{width:100%;height:100%;aspect-ratio:3/4;object-fit:cover;border-radius:12px;display:block;margin:0}
.modal__content .svc-gallery img[src*="svc-maquillaje-1"]{object-position:72% center}
.modal__content .svc-gallery img[src*="svc-peinado-1"]{object-position:center 12%}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease);
  padding:.5rem 0;
}
.nav__inner{
  max-width:1320px;margin:0 auto;padding-inline:var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.nav.scrolled{background:rgba(255,244,235,.92);backdrop-filter:blur(10px);box-shadow:0 1px 0 var(--line)}

.logo{display:inline-flex;flex-direction:column;align-items:center;line-height:.9;color:var(--heading)}
.logo__main{font-family:var(--serif);font-weight:500;letter-spacing:.3em;font-size:1.8rem;padding-left:.3em}
.logo__sub{font-family:var(--serif);font-style:italic;font-weight:500;font-size:1.35rem;color:var(--nude);margin-top:-.06em;line-height:1;letter-spacing:.01em}
.logo--footer{color:var(--ivory)}
.logo--footer .logo__sub{color:var(--nude)}
.nav .logo__sub{transform:translateX(1.97em)}

.nav__links{display:flex;align-items:center;gap:clamp(1rem,2vw,2rem)}
.nav__links a{
  font-family:var(--sans);font-weight:400;text-transform:uppercase;
  letter-spacing:.16em;font-size:.7rem;color:var(--heading);
  position:relative;padding:.3em 0;white-space:nowrap;
}
.nav__links > a:not(.btn)::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--rose);transition:width .35s var(--ease);
}
.nav__links > a:not(.btn):hover::after{width:100%}
.nav__cta-mobile{display:none}
.nav__links a.nav__cta-mobile{color:var(--ivory)}
/* los items del menú aparecen de a uno, en su mismo lugar */
@media (min-width:901px){
  .nav__links a{opacity:0;animation:navItemIn .55s var(--ease) forwards}
  .nav__links a:nth-child(1){animation-delay:.20s}
  .nav__links a:nth-child(2){animation-delay:.35s}
  .nav__links a:nth-child(3){animation-delay:.50s}
  .nav__links a:nth-child(4){animation-delay:.65s}
  .nav__links a:nth-child(5){animation-delay:.80s}
  .nav__links a:nth-child(6){animation-delay:.95s}
}
@keyframes navItemIn{from{opacity:0}to{opacity:1}}

.nav__toggle{display:none;position:relative;z-index:60;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav__toggle span{display:block;width:26px;height:2px;background:var(--heading);transition:transform .35s var(--ease),opacity .25s}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Desktop: logo centrado arriba, menú debajo, CTA a la derecha */
@media (min-width:901px){
  .nav__inner{flex-direction:column;justify-content:center;align-items:center;gap:1.15rem;position:relative}
  .nav__cta{position:absolute;right:0;bottom:.3rem}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  min-height:100svh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:clamp(2.5rem,5vw,3.5rem);
  max-width:1320px;margin:0 auto;padding:8rem var(--pad) 4rem;
  text-align:center;
}
.scroll-cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:6;display:none;color:var(--nude)}
.scroll-cue span{display:block;width:18px;height:18px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;animation:scrollCue 1.9s ease-in-out infinite}
@keyframes scrollCue{0%,100%{transform:rotate(45deg) translate(-3px,-3px);opacity:.35}50%{transform:rotate(45deg) translate(3px,3px);opacity:1}}
@media (min-width:901px){.scroll-cue{display:block}}
.hero__eyebrow{width:100%;margin-bottom:clamp(1.5rem,4vw,3rem)}
.hero__grid{
  display:grid;grid-template-columns:0.9fr 1.1fr;
  align-items:center;gap:clamp(2rem,5vw,4rem);
  width:100%;max-width:1180px;margin:0 auto;
}
.hero__copy{order:1;max-width:38rem;margin-inline:auto;text-align:center}
.hero__grid .hero__slides{order:2}
.hero .eyebrow{margin-bottom:3rem;white-space:nowrap;font-size:clamp(.5rem,1.45vw,.72rem);letter-spacing:clamp(.07em,.5vw,.2em)}
.hero h1{margin-top:.25em}
.hero__lead{font-family:var(--serif);font-size:1.7rem;color:var(--muted);font-style:italic;margin:3rem 0 1.2rem}
.hero__text{margin:0 auto 2rem;max-width:42ch;font-size:1.06rem}

/* Hero slideshow: una foto grande que rota con fundido suave */
.hero__slides{
  position:relative;overflow:hidden;width:100%;max-width:520px;margin-inline:auto;aspect-ratio:4/5;
  -webkit-mask-image:linear-gradient(to right,transparent,#000 13%,#000 87%,transparent),linear-gradient(to bottom,transparent,#000 9%,#000 91%,transparent);
  -webkit-mask-composite:source-in;
  mask-image:linear-gradient(to right,transparent,#000 13%,#000 87%,transparent),linear-gradient(to bottom,transparent,#000 9%,#000 91%,transparent);
  mask-composite:intersect;
}
.hslide{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;
  opacity:0;transform:scale(1.04);transition:opacity 1.3s var(--ease);
}
.hslide.is-active{opacity:1;animation:heroKen 7s ease-out forwards}
@keyframes heroKen{from{transform:scale(1.04)}to{transform:scale(1.11)}}
.hslide[src*="hero-1"]{object-position:center 35%}
.hslide[src*="hero-2"]{object-position:center 28%}
.hslide[src*="hero-3"]{object-position:center 38%}
.hslide[src*="hero-4"]{object-position:center 35%}
.hslide[src*="hero-5"]{object-position:center 22%}

/* ============================================================
   SOBRE NOSOTROS
   ============================================================ */
.sobre{background:var(--cream)}
.sobre__grid{display:flex;flex-direction:column;align-items:center;gap:clamp(2.5rem,5vw,4rem);margin-top:1.5rem}
.sobre__text{text-align:center;max-width:760px}
.sobre__text p{margin:0 auto 1.15rem;max-width:54ch}
.sobre__sign{font-family:var(--serif);font-weight:500;font-size:clamp(1.35rem,2.4vw,1.85rem);color:#5B3A37;margin:0 0 1.4rem;line-height:1.1;white-space:nowrap}
.sobre__sign em{
  color:var(--nude);
  text-decoration-line:underline;
  text-decoration-color:var(--nude);
  text-decoration-thickness:1px;
  text-underline-offset:.18em;
}

.sobre__media{display:flex;align-items:center;justify-content:center;gap:1rem;max-width:720px;width:100%;margin:clamp(2.5rem,5vw,4rem) auto 0}
/* aparición de a una: foto → flecha → foto */
.sobre__before.reveal.in{animation:sobreSeq .9s var(--ease) .1s backwards}
.sobre__arrow.reveal.in{animation:sobreSeq .9s var(--ease) .45s backwards}
.sobre__after.reveal.in{animation:sobreSeq .9s var(--ease) .8s backwards}
@keyframes sobreSeq{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
.sobre__before,.sobre__after{flex:1;border-radius:var(--r);overflow:hidden;aspect-ratio:3/4;
  box-shadow:0 20px 44px -26px rgba(89,50,56,.5);
  transition:transform .55s var(--ease),box-shadow .55s var(--ease)}
.sobre__before img,.sobre__after img{transition:transform 1.2s var(--ease)}
.sobre__before:hover,.sobre__after:hover{transform:translateY(-8px);box-shadow:0 38px 60px -26px rgba(89,50,56,.58)}
.sobre__before:hover img,.sobre__after:hover img{transform:scale(1.06)}
.sobre__after{margin-top:2.5rem}
.sobre__before{margin-bottom:2.5rem}
.sobre__arrow{flex:0 0 56px;color:var(--nude)}
.sobre__arrow svg{width:100%;height:auto}
/* foto principal arriba (full-width) */
.sobre__top{display:block;width:100%;margin:clamp(2.5rem,5vw,4rem) auto 0;border-radius:var(--r);overflow:hidden;aspect-ratio:16/9;box-shadow:0 24px 50px -30px rgba(89,50,56,.5);transition:transform .55s var(--ease),box-shadow .55s var(--ease)}
.sobre__top img{object-position:center 32%;transition:transform 1.2s var(--ease)}
.sobre__top:hover{transform:translateY(-6px);box-shadow:0 38px 64px -28px rgba(89,50,56,.55)}
.sobre__top:hover img{transform:scale(1.04)}

.bts{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:14px}
.bts__item{border-radius:var(--r);overflow:hidden;aspect-ratio:4/3;
  box-shadow:0 14px 36px -28px rgba(89,50,56,.45);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.bts__item img{transition:transform 1.1s var(--ease)}
.bts__item:hover{transform:translateY(-6px);box-shadow:0 30px 52px -28px rgba(89,50,56,.5)}
.bts__item:hover img{transform:scale(1.06)}

.brands{margin-top:clamp(3rem,6vw,5rem);text-align:center}
.brands__title{
  font-family:var(--sans);font-weight:500;text-transform:uppercase;
  letter-spacing:.2em;font-size:.78rem;color:var(--rose);margin:0 0 1.8rem;
}
.brands__list{display:grid;gap:1rem;max-width:760px;margin:0 auto}
.brands__list li{
  position:relative;overflow:hidden;
  display:grid;grid-template-columns:130px 1fr;gap:1rem;align-items:baseline;
  text-align:left;padding:1.15rem 1.5rem 1.15rem 1.7rem;background:var(--ivory);border-radius:14px;
  border:1px solid rgba(200,162,141,.32);
  box-shadow:0 18px 38px -26px rgba(89,50,56,.45), 0 2px 6px -3px rgba(89,50,56,.12);
  transition:transform .45s var(--ease), box-shadow .45s var(--ease), border-color .45s var(--ease);
}
.brands__list li::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(var(--nude), rgba(200,162,141,.25));
}
.brands__list li:hover{
  transform:translateY(-3px);
  border-color:rgba(200,162,141,.6);
  box-shadow:0 26px 50px -24px rgba(89,50,56,.5), 0 3px 8px -3px rgba(89,50,56,.16);
}
.brands__cat{font-family:var(--sans);font-weight:500;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;color:var(--wine)}
.brands__val{font-size:.98rem;color:var(--nude)}

/* ============================================================
   SERVICIOS
   ============================================================ */
.servicios{background:var(--cream)}
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.2rem,2.5vw,2rem);margin-top:clamp(2rem,4vw,3.2rem)}
.card{
  position:relative;
  background:var(--ivory);border-radius:14px;overflow:hidden;
  display:flex;flex-direction:column;border:1px solid rgba(200,162,141,.32);
  box-shadow:0 18px 38px -26px rgba(89,50,56,.45), 0 2px 6px -3px rgba(89,50,56,.12);
}
.card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;z-index:2;
  background:linear-gradient(var(--nude), rgba(200,162,141,.25));
}
/* premium hover + reveal transition (high specificity to win over .reveal) */
.servicios .cards .card{transition:opacity .85s var(--ease),transform .55s var(--ease),box-shadow .55s var(--ease),border-color .55s var(--ease)}
/* aparición en cascada, de a una */
.cards .card:nth-child(2){transition-delay:.16s}
.cards .card:nth-child(3){transition-delay:.32s}
.cards .card:nth-child(4){transition-delay:.48s}
.card:hover{transform:translateY(-10px);border-color:rgba(200,162,141,.6);box-shadow:0 38px 62px -28px rgba(89,50,56,.55)}
.card__img{aspect-ratio:16/11;overflow:hidden}
.card__img img{transition:transform 1.2s var(--ease)}
.card__img img[src*="svc-peinado"]{object-position:center 5%}
.card__img img[src*="svc-maquillaje"]{object-position:center 18%}
.card:hover .card__img img{transform:scale(1.07)}
.card__body{padding:clamp(1.5rem,2.5vw,2.3rem);display:flex;flex-direction:column;gap:.7rem}
.card__num{font-family:var(--serif);font-weight:500;font-size:1.35rem;color:var(--nude);letter-spacing:.14em;line-height:1}
.card__num::after{content:"";display:block;width:26px;height:1px;background:var(--nude);margin-top:.5rem;transition:width .5s var(--ease)}
.card:hover .card__num::after{width:48px}
.card__title{font-family:var(--serif);font-weight:500;font-size:1.95rem;color:#5B3A37;margin:0;line-height:1}
.card__body p{margin:0;font-size:.98rem}

.servicios__cta{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:clamp(2.5rem,5vw,3.5rem)}

/* ============================================================
   PROCESO — LA PRUEBA (bordó)
   ============================================================ */
.proceso{background:var(--wine);color:var(--ivory);position:relative;overflow:hidden}
.proceso::before{
  content:"CBM";position:absolute;right:3%;bottom:-4%;z-index:0;pointer-events:none;
  font-family:var(--serif);font-weight:500;letter-spacing:.04em;
  font-size:clamp(10rem,26vw,26rem);line-height:.8;color:rgba(255,244,235,.05);
}
.proceso__grid{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.proceso__img{
  position:relative;aspect-ratio:3/4;border-radius:11px;overflow:hidden;
  box-shadow:0 30px 58px -20px rgba(0,0,0,.72);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.proceso__img img{transition:transform 1.2s var(--ease)}
.proceso__img:hover{transform:translateY(-4px);box-shadow:0 40px 70px -18px rgba(0,0,0,.78)}
.proceso__img:hover img{transform:scale(1.04)}
.proceso__text p{color:#EBD9D2;margin:0 0 1.2rem;max-width:50ch}
.proceso__text strong{color:var(--nude);font-weight:600;letter-spacing:.01em}
.proceso__text .btn{margin-top:1rem}

/* ============================================================
   GALERÍA (masonry editorial)
   ============================================================ */
.galeria{background:var(--ivory)}
.masonry{display:flex;gap:12px;margin-top:clamp(2rem,4vw,3.2rem);width:min(1460px,94vw);margin-left:50%;transform:translateX(-50%)}
.masonry__item{flex:1 1 0;min-width:0;margin:0;aspect-ratio:2/3;border-radius:10px;overflow:hidden}
.masonry__item img{width:100%;height:100%;object-fit:cover}
.masonry__item img[src*="gallery-5"]{object-position:80% 30%}
.masonry__item img[src*="gallery-4"]{object-position:center 12%}
@media (max-width:760px){
  .masonry{overflow-x:auto;gap:8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:8px}
  .masonry__item{flex:0 0 64%;scroll-snap-align:center}
}
.galeria__cta{text-align:center;margin-top:clamp(2rem,4vw,3rem)}

/* ============================================================
   BANNER MARQUESINA (se desliza lento, premium)
   ============================================================ */
.marquee{
  overflow:hidden;background:var(--ivory);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding-block:clamp(0.7rem,1.6vw,1.25rem);
}
.marquee__track{display:flex;width:max-content;animation:marqueeMove 48s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__group{display:flex;align-items:center;flex:0 0 auto}
.marquee__group > span{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(1.05rem,2.2vw,1.85rem);line-height:1;color:#5B3A37;white-space:nowrap;padding:0 .12em;
}
.marquee__group .marquee__sep{color:var(--nude);font-style:normal;padding:0 .55em}
@keyframes marqueeMove{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.testimonios{background:var(--cream)}
.reviews{columns:3;column-gap:18px}
.review{
  position:relative;overflow:hidden;
  break-inside:avoid;margin:0 0 18px;background:var(--ivory);
  border-radius:14px;padding:1.8rem 1.7rem 1.8rem 1.9rem;
  border:1px solid rgba(200,162,141,.32);
  box-shadow:0 18px 38px -26px rgba(89,50,56,.45), 0 2px 6px -3px rgba(89,50,56,.12);
  transition:transform .45s var(--ease), box-shadow .45s var(--ease), border-color .45s var(--ease);
}
.review::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(var(--nude), rgba(200,162,141,.25));
}
.review:hover{
  transform:translateY(-3px);border-color:rgba(200,162,141,.6);
  box-shadow:0 26px 50px -24px rgba(89,50,56,.5), 0 3px 8px -3px rgba(89,50,56,.16);
}
.review__stars{color:var(--rose);letter-spacing:.18em;font-size:1.1rem;margin-bottom:.8rem}
.review blockquote{margin:0 0 1.3rem;font-size:.96rem;line-height:1.7;color:var(--text)}
.review figcaption{display:flex;align-items:center;gap:.8rem}
.review__avatar{
  width:42px;height:42px;border-radius:50%;background:#ECE3D3;color:var(--wine);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:1.2rem;font-weight:500;flex:0 0 auto;
}
.review figcaption strong{display:block;font-family:var(--serif);font-weight:500;font-size:1.15rem;color:var(--heading);line-height:1.1}
.review__role{font-family:var(--sans);text-transform:uppercase;letter-spacing:.16em;font-size:.62rem;color:var(--rose)}
.testimonios__cta{text-align:center;margin-top:clamp(2rem,4vw,3rem)}

/* ============================================================
   FAQ
   ============================================================ */
.faq{background:var(--cream)}
.faq__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.faq__intro{position:sticky;top:120px}
.faq__lead{margin:1.2rem 0 2rem;max-width:36ch}
.faq__hint{font-family:var(--serif);font-size:1.4rem;color:var(--heading);margin:0 0 1rem}

.faq__list{display:flex;flex-direction:column;gap:14px}
.acc{
  position:relative;background:var(--ivory);border-radius:14px;overflow:hidden;
  border:1px solid rgba(200,162,141,.32);
  box-shadow:0 18px 38px -26px rgba(89,50,56,.45), 0 2px 6px -3px rgba(89,50,56,.12);
  transition:transform .45s var(--ease), box-shadow .45s var(--ease), border-color .45s var(--ease);
}
.acc::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(var(--nude), rgba(200,162,141,.25));
}
.acc:hover{
  transform:translateY(-3px);border-color:rgba(200,162,141,.6);
  box-shadow:0 26px 50px -24px rgba(89,50,56,.5), 0 3px 8px -3px rgba(89,50,56,.16);
}
.acc.open{box-shadow:0 26px 50px -24px rgba(89,50,56,.5), 0 3px 8px -3px rgba(89,50,56,.16)}
.acc__head{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  background:none;border:0;cursor:pointer;text-align:left;
  padding:1.35rem 1.5rem;font-family:var(--sans);font-weight:500;
  text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;color:var(--heading);
}
.acc__icon{position:relative;flex:0 0 24px;height:24px}
.acc__icon::before,.acc__icon::after{
  content:"";position:absolute;top:50%;left:50%;background:var(--rose);border-radius:2px;
  transform:translate(-50%,-50%);transition:transform .4s var(--ease);
}
.acc__icon::before{width:18px;height:2.5px}
.acc__icon::after{width:2.5px;height:18px}
.acc.open .acc__icon::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.acc__panel{height:0;overflow:hidden;transition:height .42s var(--ease)}
.acc__inner{padding:0 1.5rem 1.5rem}
.acc__inner p{margin:0;font-size:.98rem}
.acc__inner em{color:var(--rose);font-size:.86rem}

/* ============================================================
   CONTACTO
   ============================================================ */
.contacto{background:var(--cream)}
.contacto__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.contacto__text p{max-width:46ch}
.contact-list{margin-top:2rem;display:flex;flex-direction:column;gap:.6rem}
.contact-list a,.contact-list__static{
  display:flex;align-items:center;gap:1rem;padding:.85rem 1rem;border-radius:12px;
  transition:background .35s var(--ease),transform .35s var(--ease);
}
.contact-list a:hover{background:var(--ivory);transform:translateX(4px)}
.contact-list__ic{
  flex:0 0 46px;height:46px;border-radius:50%;background:var(--ivory);color:var(--rose);
  display:flex;align-items:center;justify-content:center;border:1px solid var(--line);
}
.contact-list__ic svg{width:22px;height:22px}
.contact-list__txt{display:flex;flex-direction:column;line-height:1.3}
.contact-list__txt strong{font-family:var(--sans);font-weight:500;text-transform:uppercase;letter-spacing:.14em;font-size:.66rem;color:var(--rose)}
.contact-list__txt span{font-size:1.02rem;color:var(--heading)}
.contacto__img{
  overflow:hidden;aspect-ratio:3/4;
  -webkit-mask-image:linear-gradient(to right,transparent,#000 13%,#000 87%,transparent),linear-gradient(to bottom,transparent,#000 9%,#000 91%,transparent);
  -webkit-mask-composite:source-in;
  mask-image:linear-gradient(to right,transparent,#000 13%,#000 87%,transparent),linear-gradient(to bottom,transparent,#000 9%,#000 91%,transparent);
  mask-composite:intersect;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:var(--wine-deep);color:var(--ivory);text-align:center;
  padding:clamp(3.5rem,7vw,5.5rem) var(--pad);
  display:flex;flex-direction:column;align-items:center;gap:1.4rem;
}
.logo--footer .logo__main{font-size:2.4rem;letter-spacing:.3em}
.logo--footer .logo__sub{font-size:2.1rem;margin-top:-.15em;transform:translateX(2.05em)}
.footer__line{margin:0;font-family:var(--serif);font-size:1.25rem;color:#E4CFC8;letter-spacing:.02em}
.footer__ig{font-family:var(--sans);text-transform:uppercase;letter-spacing:.3em;font-size:.74rem;color:var(--rose-soft);transition:color .3s}
.footer__ig:hover{color:var(--ivory)}
.footer__legal{margin:.2rem auto 0;max-width:62ch;font-family:var(--sans);font-size:.72rem;line-height:1.7;letter-spacing:.02em;color:rgba(254,255,242,.55)}
.footer__terms{margin:.6rem auto 0;background:none;border:0;cursor:pointer;font-family:var(--sans);text-transform:uppercase;letter-spacing:.2em;font-size:.66rem;color:var(--rose-soft);border-bottom:1px solid transparent;padding-bottom:2px;transition:color .3s,border-color .3s}
.footer__terms:hover{color:var(--ivory);border-bottom-color:var(--nude)}

/* ---------- WhatsApp float ---------- */
.wa-float{
  position:fixed;right:18px;bottom:18px;z-index:60;
  width:56px;height:56px;border-radius:50%;background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 28px -8px rgba(0,0,0,.4);
  transition:transform .35s var(--ease);
  animation:waPulse 2.4s ease-in-out infinite;
}
.wa-float svg{width:30px;height:30px}
.wa-float:hover{transform:scale(1.1);animation-play-state:paused;box-shadow:0 12px 30px -6px rgba(0,0,0,.45),0 0 0 8px rgba(37,211,102,.18)}
@keyframes waPulse{
  0%{box-shadow:0 12px 28px -8px rgba(0,0,0,.4),0 0 0 0 rgba(37,211,102,.55)}
  70%{box-shadow:0 12px 28px -8px rgba(0,0,0,.4),0 0 0 16px rgba(37,211,102,0)}
  100%{box-shadow:0 12px 28px -8px rgba(0,0,0,.4),0 0 0 0 rgba(37,211,102,0)}
}

/* ---- Instagram float (al lado del de WhatsApp, mismo tamaño y hover) ---- */
.ig-float{
  position:fixed;right:86px;bottom:18px;z-index:60;
  width:56px;height:56px;border-radius:50%;color:#fff;
  background:radial-gradient(circle at 30% 107%, #fdf497 0%, #fdf497 5%, #fd5949 45%, #d6249f 60%, #285AEB 90%);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 28px -8px rgba(0,0,0,.4);
  transition:transform .35s var(--ease);
  animation:igPulse 2.4s ease-in-out infinite;
}
.ig-float svg{width:28px;height:28px}
.ig-float:hover{transform:scale(1.1);animation-play-state:paused;box-shadow:0 12px 30px -6px rgba(0,0,0,.45),0 0 0 8px rgba(214,41,118,.18)}
@keyframes igPulse{
  0%{box-shadow:0 12px 28px -8px rgba(0,0,0,.4),0 0 0 0 rgba(214,41,118,.5)}
  70%{box-shadow:0 12px 28px -8px rgba(0,0,0,.4),0 0 0 16px rgba(214,41,118,0)}
  100%{box-shadow:0 12px 28px -8px rgba(0,0,0,.4),0 0 0 0 rgba(214,41,118,0)}
}

/* ---- Gallery lightbox ---- */
.masonry__item img{cursor:default;pointer-events:none}
.lightbox{
  position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;
  padding:clamp(1rem,5vw,4rem);background:rgba(46,36,34,.92);backdrop-filter:blur(4px);
  opacity:0;visibility:hidden;transition:opacity .35s var(--ease),visibility .35s;cursor:zoom-out;
}
.lightbox.show{opacity:1;visibility:visible}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:10px;box-shadow:0 30px 80px -20px rgba(0,0,0,.6)}
.lightbox__close{
  position:absolute;top:16px;right:22px;width:44px;height:44px;border:0;background:none;color:#fff;
  font-size:2rem;line-height:1;cursor:pointer;opacity:.85;transition:opacity .25s,transform .25s;
}
.lightbox__close:hover{opacity:1;transform:scale(1.1)}

/* ---- Mobile sticky CTA bar ---- */
.mobile-cta{display:none}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.js .reveal.in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:860px){
  .hero{padding-top:7rem;min-height:auto;gap:2.5rem}
  .hero__grid{grid-template-columns:1fr;gap:2.5rem}
  .hero__copy{max-width:none}
  .sobre__grid,.proceso__grid,.contacto__grid,.faq__grid{grid-template-columns:1fr}
  .faq__intro{position:static}
  .proceso__img{order:-1;max-width:460px;width:100%;margin-inline:auto}
  .contacto__img{max-width:460px;width:100%;margin-inline:auto}
  .reviews{columns:2}
  .cards{gap:1.2rem}
}

@media (max-width:900px){
  .nav__cta{display:none}
  .nav__toggle{display:flex}
  .nav__links{
    position:fixed;top:0;right:0;left:auto;height:100dvh;width:min(82vw,330px);z-index:55;
    background:var(--cream);flex-direction:column;align-items:flex-start;justify-content:center;
    gap:1.6rem;padding:5.5rem 2.2rem 2rem;overflow-y:auto;
    transform:translateX(100%);transition:transform .45s var(--ease);
    box-shadow:-20px 0 50px -20px rgba(89,50,56,.4);
  }
  .nav__links.open{transform:translateX(0)}
  .nav__links a{font-size:.9rem}
  .nav__links a.nav__cta-mobile{display:inline-flex;width:100%;justify-content:center;
    margin-top:.8rem;font-size:.68rem;letter-spacing:.1em;padding:1.05em .8em}
}

.nav__backdrop{
  position:fixed;inset:0;z-index:49;background:rgba(46,36,34,.38);
  backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s;
}
.nav__backdrop.show{opacity:1;visibility:visible}

@media (max-width:680px){
  .hero__gallery{gap:10px}
  .cards{grid-template-columns:1fr}
  .reviews{columns:1}
  .bts{grid-template-columns:1fr 1fr}
  .brands__list li{grid-template-columns:1fr;gap:.2rem}
  .sobre__before{margin-bottom:1.2rem}
  .sobre__after{margin-top:1.2rem}
  .sobre__arrow{flex-basis:34px}

  /* sticky booking bar */
  body{padding-bottom:3.6rem}
  .mobile-cta{
    display:flex;align-items:center;justify-content:center;
    position:fixed;left:0;right:0;bottom:0;z-index:90;
    background:var(--wine);color:var(--ivory);
    font-family:var(--sans);font-weight:500;text-transform:uppercase;
    letter-spacing:.14em;font-size:.72rem;padding:1.05em 1rem;
    box-shadow:0 -6px 22px -10px rgba(89,50,56,.6);
  }
  .wa-float{bottom:76px}
  .ig-float{bottom:76px}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
}
