/* ================================================
   OCEAN CLINIC & SPA — Kalm Moments inspired
   Paleta: Sage · Beige · Nude · Blush · Champagne
   v=20260601
================================================ */

:root {
  /* Backgrounds — ivory luminoso, cálido, aireado */
  --c-bg:      #faf6f0;   /* warm ivory principal */
  --c-bg2:     #f3ece2;   /* arena cálida */
  --c-bg3:     #e9dccf;   /* nude más profundo */
  --c-surface: #fffefb;   /* blanco cálido para cards */

  /* Tinta — espresso suave con jerarquía */
  --c-ink:     #2a2420;   /* near-black cálido */
  --c-ink2:    #5f4e44;   /* marrón medio */
  --c-mute:    #9d8b81;   /* muted cálido */
  --c-light:   #cabfb6;   /* muy suave */

  /* Acentos — sage verde + tonos naturales (Kalm Moments) */
  --c-blush:   #7a8b79;   /* sage verde principal (antes blush) */
  --c-blush2:  #6b7c6a;   /* sage oscuro (acentos/CTA) */
  --c-blush-bg:#f1f4ed;   /* sage velado para fondos */
  --c-gold:    #9d8b6f;   /* dorado cálido natural */
  --c-sage:    #7a8b79;   /* sage verde suave */

  /* Líneas */
  --c-line:    rgba(42,36,32,.09);
  --c-line2:   rgba(196,151,141,.28);

  /* Type */
  --f-serif:   'Cormorant Garamond', Georgia, serif;
  --f-sans:    'DM Sans', system-ui, sans-serif;

  --ease:      cubic-bezier(.22,1,.36,1);
  --ease-io:   cubic-bezier(.65,0,.35,1);
  --nav-h:     70px;
}

/* ── Base ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; overflow-x: clip; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body { background: var(--c-bg); color: var(--c-ink); font-family: var(--f-sans); font-size: 16px; line-height: 1.6; overflow-x: clip; -webkit-font-smoothing: antialiased; }
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; border: none; background: none; font: inherit; color: inherit; }

/* ── Type ── */
.eyebrow { display: block; font-family: var(--f-serif); font-size: .68rem; font-weight: 400; letter-spacing: .18em; text-transform: uppercase; color: var(--c-blush2); margin-bottom: 1.3rem; opacity: .9; }
.h2 { font-family: var(--f-serif); font-size: clamp(2.1rem,4.2vw,3.8rem); font-weight: 300; line-height: 1.1; letter-spacing: -.015em; color: var(--c-ink); }
.h2 em { font-style: italic; font-weight: 400; color: var(--c-blush); }
.body { font-size: .95rem; color: var(--c-ink2); line-height: 1.8; opacity: .88; }

/* ── Buttons ── */
.btn-dark { display: inline-flex; align-items: center; gap: .5rem; padding: .875rem 2rem; background: var(--c-ink); color: var(--c-surface); font-size: .72rem; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; border-radius: 2px; transition: background .3s var(--ease), transform .2s var(--ease), box-shadow .3s; }
.btn-dark:hover { background: var(--c-ink2); transform: translateY(-2px); box-shadow: 0 8px 28px rgba(35,30,26,.18); }
.btn-ghost-dark { display: inline-flex; align-items: center; padding: .875rem 2rem; border: 1px solid var(--c-line); color: var(--c-mute); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; border-radius: 2px; transition: border-color .25s, color .25s, transform .2s var(--ease); }
.btn-ghost-dark:hover { border-color: var(--c-blush); color: var(--c-blush2); transform: translateY(-2px); }
.lnk { font-size: .75rem; color: var(--c-blush2); letter-spacing: .08em; transition: color .2s; }
.lnk:hover { color: var(--c-blush); }
.w100 { width: 100%; justify-content: center; }

/* ── Reveal ── */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .75s var(--ease), transform .75s var(--ease); }
.reveal.is-on { opacity: 1; transform: none; }
.fade-up { opacity: 0; transform: translateY(22px); animation: fadeUp .8s var(--ease) both; animation-delay: var(--d, 0s); }
@keyframes fadeUp { to { opacity: 1; transform: none; } }

/* ================================================
   SPLASH
================================================ */
.splash {
  position: fixed; inset: 0; z-index: 9999;
  background: var(--c-bg);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1.25rem;
  transition: opacity .9s var(--ease-io), clip-path .9s var(--ease-io);
  animation: splashKill .01s 4.5s forwards;
}
.splash.gone { opacity: 0; pointer-events: none; clip-path: inset(0 0 100% 0); }
@keyframes splashKill { to { opacity:0; pointer-events:none; clip-path:inset(0 0 100% 0); } }
.splash-svg { overflow: visible; }
/* Splash logo elements animate in sequence */
.logo-c1   { animation: logoFadeIn .6s var(--ease) .2s forwards; }
.logo-c2   { animation: logoFadeIn .6s var(--ease) .5s forwards; }
.logo-wave-a { stroke-dasharray: 120; stroke-dashoffset: 120; animation: waveDraw .9s var(--ease) .7s forwards; }
.logo-wave-b { stroke-dasharray: 80; stroke-dashoffset: 80; animation: waveDraw .7s var(--ease) 1.1s forwards; }
.logo-text1 { animation: logoFadeIn .6s var(--ease) 1.3s forwards; }
.logo-text2 { animation: logoFadeIn .6s var(--ease) 1.5s forwards; }
@keyframes waveDraw { to { stroke-dashoffset: 0; opacity: 1; } }
@keyframes logoFadeIn { to { opacity: 1; } }
.splash-label { display: none; }

/* ================================================
   NAV
================================================ */
/* ── NAV ── */
.nav {
  position: fixed; inset: 0 0 auto; z-index: 100; height: var(--nav-h);
  display: grid;
  grid-template-columns: 1fr auto 1fr auto;
  align-items: center;
  padding: 0 2.5rem;
  gap: 1rem;
  transition: background .4s, box-shadow .4s, backdrop-filter .4s;
}
.nav.on {
  background: rgba(250,246,240,.92);
  backdrop-filter: blur(20px) saturate(1.2); -webkit-backdrop-filter: blur(20px) saturate(1.2);
  box-shadow: 0 1px 0 var(--c-line), 0 8px 30px rgba(42,36,32,.04);
}

/* Left links */
.nav-left { display: flex; align-items: center; gap: 2rem; justify-content: flex-end; }

/* Center logo */
.nav-logo-center {
  display: flex; align-items: center; justify-content: center;
  position: relative;
  color: #fff;
  transition: opacity .25s, color .4s;
}
.nav.on .nav-logo-center { color: #c4a368; }
.nav-logo-center::before {
  content: '';
  position: absolute;
  inset: -12px;
  border-radius: 50%;
  background: radial-gradient(ellipse at center, rgba(255,255,255,.18) 0%, rgba(255,255,255,.06) 50%, transparent 75%); transition: background .4s;
  pointer-events: none;
}
.nav-logo-center:hover { opacity: .7; }
.nav.on .nav-logo-center::before { background: radial-gradient(ellipse at center, rgba(196,163,104,.22) 0%, rgba(196,163,104,.08) 50%, transparent 75%); }
.nav-logo-center svg { display: block; position: relative; z-index: 1; }

/* Right links */
.nav-right-links { display: flex; align-items: center; gap: 2rem; justify-content: flex-start; }

/* All nav links */
.nm-link {
  font-size: .65rem; font-weight: 400; letter-spacing: .14em;
  text-transform: uppercase; color: rgba(255,255,255,.88); position: relative; transition: color .4s;
}
.nav.on .nm-link { color: var(--c-ink2); }
.nm-link::after { content:''; position: absolute; bottom: -3px; left: 0; right: 100%; height: 1px; background: var(--c-blush); transition: right .3s var(--ease); }
.nm-link:hover { color: var(--c-ink); }
.nm-link:hover::after { right: 0; }

/* Utils (lang + reservar + burger) */
.nav-utils { display: flex; align-items: center; gap: 1.25rem; justify-content: flex-end; }
.nm-cta { font-size: .65rem; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; color: var(--c-blush2); border-bottom: 1px solid var(--c-blush2); padding-bottom: 1px; transition: color .2s, border-color .2s; }
.nm-cta:hover { color: var(--c-blush); border-color: var(--c-blush); }
.lang-sw { display: flex; align-items: center; gap: .4rem; }
.lang-sw span { color: var(--c-light); font-size: .6rem; }
.lb { font-size: .6rem; font-weight: 500; letter-spacing: .1em; color: var(--c-light); transition: color .2s; }
.lb.active, .lb:hover { color: var(--c-blush2); }
.burger { display: none; flex-direction: column; gap: 5px; padding: 4px; }
.burger span { display: block; width: 22px; height: 1px; background: var(--c-ink); transition: transform .3s, opacity .3s; }
.burger.x span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.burger.x span:nth-child(2) { opacity: 0; }

/* ================================================
   HERO — FULLWIDTH slideshow de caras (DISRUPTIVO)
================================================ */
.hero {
  position: relative;
  min-height: 100svh;
  overflow: hidden;
  padding-top: var(--nav-h);
}

/* Fullwidth slideshow */
.hero-fullwidth {
  position: relative;
  width: 100%;
  height: calc(100svh - var(--nav-h));
  overflow: hidden;
}

.hero-slides-fullwidth {
  width: 100%; height: 100%;
  position: relative;
}

.hfs-slide {
  position: absolute; inset: 0;
  opacity: 0;
  transition: opacity 1s ease-in-out;
  display: flex; align-items: center; justify-content: center;
}

.hfs-slide.active { opacity: 1; }

.hfs-slide img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  display: block;
  animation: heroZoom 8s ease-in-out infinite;
}

@keyframes heroZoom {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.05); }
}

/* Overlay con gradiente — EDITORIAL KALM MOMENTS */
.hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(
    to bottom,
    transparent 0%,
    rgba(42,36,32,.05) 35%,
    rgba(42,36,32,.6) 68%,
    rgba(42,36,32,.88) 100%
  );
  display: flex; flex-direction: column; align-items: center; justify-content: flex-end;
  padding: 0 4rem 7vh;
  text-align: center;
  color: #fff;
  z-index: 2;
  gap: 2.5rem;
}

.hero-content {
  max-width: 860px;
  display: flex; flex-direction: column; gap: 1.8rem;
  align-items: center;
}

.hero-kicker {
  font-size: .62rem; font-weight: 500;
  letter-spacing: .45em; text-transform: uppercase;
  color: rgba(255,255,255,.65);
  display: block;
}

.hero-h1 {
  font-family: var(--f-serif); font-weight: 300;
  font-size: clamp(3.6rem, 8.5vw, 8rem);
  line-height: .92; letter-spacing: -.035em; color: #fff;
  display: flex; flex-direction: column; gap: .04em;
}

/* Line-by-line hero animation */
.h1-line {
  display: block;
  opacity: 0;
  transform: translateY(40px);
  animation: heroLineIn .9s var(--ease) both;
}
.h1-line:nth-child(1) { animation-delay: .1s; }
.h1-line:nth-child(2) { animation-delay: .22s; }
.h1-line:nth-child(3) { animation-delay: .34s; }
@keyframes heroLineIn { to { opacity:1; transform:none; } }

.hero-h1 em {
  font-style: italic; font-weight: 400;
  color: rgba(255,255,255,.85);
}

.hero-sub {
  font-size: .95rem; color: rgba(255,255,255,.72);
  line-height: 1.85; max-width: 46ch; margin-inline: auto;
  opacity: 0;
  animation: heroLineIn .9s var(--ease) .5s both;
}

.hero-btns {
  display: flex; align-items: center; justify-content: center;
  gap: 1rem; flex-wrap: wrap;
  opacity: 0;
  animation: heroLineIn .9s var(--ease) .65s both;
}

/* Stats badge — top-left editorial */
.hero-badge-top {
  position: absolute; top: calc(var(--nav-h) + 1.75rem); left: 2.5rem;
  display: flex; align-items: center; gap: 1.5rem;
  background: rgba(255,254,251,.1);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 4px;
  padding: .85rem 1.4rem;
  z-index: 3;
  opacity: 0;
  animation: heroLineIn .8s var(--ease) .8s both;
}

.hbb-stat {
  display: flex; flex-direction: column; align-items: center; gap: .15rem;
  text-align: center;
}

.hbb-stat strong {
  font-family: var(--f-serif); font-size: 1.5rem;
  font-weight: 300; color: #fff; line-height: 1;
}

.hbb-stat strong span { font-size: .9rem; }

.hbb-stat small {
  font-size: .55rem; letter-spacing: .2em;
  text-transform: uppercase; color: rgba(255,255,255,.65);
}

.hbb-sep {
  width: 1px; height: 30px; background: rgba(255,255,255,.2);
}

/* Scroll hint */
.hero-scroll-hint {
  position: absolute; bottom: 2.5rem; left: 50%;
  transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: .6rem;
  opacity: 0;
  animation: heroLineIn .8s var(--ease) 1.1s both;
  z-index: 3;
}
.hsh-line {
  width: 1px; height: 40px;
  background: linear-gradient(to bottom, rgba(255,255,255,.6), transparent);
  animation: scrollPulse 2s ease-in-out 1.5s infinite;
}
.hsh-text {
  font-size: .52rem; letter-spacing: .3em; text-transform: uppercase;
  color: rgba(255,255,255,.55);
}
@keyframes scrollPulse { 0%,100%{transform:scaleY(1)} 50%{transform:scaleY(1.3)} }

/* Dots navigation */
.hfs-dots {
  position: absolute; bottom: 2.5rem; right: 2.5rem;
  display: flex; gap: .6rem;
  z-index: 3;
}

.hfs-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,.4);
  border: 1px solid rgba(255,255,255,.6);
  cursor: pointer;
  transition: all .3s ease;
  padding: 0;
}

.hfs-dot:hover {
  background: rgba(255,255,255,.6);
}

.hfs-dot.active {
  background: var(--c-blush);
  border-color: var(--c-blush);
  transform: scale(1.2);
}

/* Mobile hero */
@media (max-width: 900px) {
  .hero-overlay { padding: 0 1.5rem 6vh; }
  .hero-h1 { font-size: clamp(2.8rem, 10vw, 5rem); }
  .hero-sub { font-size: .88rem; }
  .hero-btns { flex-direction: column; gap: .75rem; }
  .hero-btns a { width: 100%; text-align: center; justify-content: center; }
  .hero-badge-top { top: calc(var(--nav-h) + 1rem); left: 1.25rem; padding: .65rem 1rem; gap: 1rem; }
  .hbb-stat strong { font-size: 1.2rem; }
  .hfs-dots { bottom: 1rem; right: 1.25rem; }
  .hero-scroll-hint { display: none; }
}

/* ================================================
   TAPE / MARQUEE
================================================ */
.tape { background: var(--c-bg2); border-top: 1px solid var(--c-line); border-bottom: 1px solid var(--c-line); padding: .9rem 0; overflow: hidden; }
.tape-track { display: flex; gap: 1.5rem; white-space: nowrap; width: max-content; animation: tapeRoll 30s linear infinite; }
.tape-track span { font-size: .65rem; font-weight: 400; letter-spacing: .14em; text-transform: uppercase; color: var(--c-mute); }
.tape-track .bull { color: var(--c-blush); font-size: .5rem; }
@keyframes tapeRoll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ================================================
   PARA LA NOVIA
================================================ */
.novia { display: grid; grid-template-columns: 1fr 1fr; min-height: 55vh; }
.novia-img { overflow: hidden; position: relative; }
.novia-img img { width: 100%; height: 100%; object-fit: cover; object-position: center top; filter: saturate(.82); transition: transform .9s var(--ease), filter .5s; }
.novia:hover .novia-img img { transform: scale(1.04); filter: saturate(.9); }
.novia-copy { display: flex; flex-direction: column; justify-content: center; gap: 1.5rem; padding: 3rem 5rem; background: var(--c-bg2); }
.novia-copy .h2 { margin-bottom: .5rem; }
.novia-copy .btn-dark { align-self: flex-start; margin-top: .5rem; }

/* ================================================
   SERVICIOS — GRID VISUAL + COMBOS PREMIUM
================================================ */
.servicios { padding: 4rem 6rem; }
.servicios-head { margin-bottom: 3rem; text-align: center; }

/* Section labels -->  <div class="srv-section-label"> */
.srv-section-label {
  font-family: var(--f-serif);
  font-size: 1.2rem;
  font-weight: 400;
  color: var(--c-ink);
  letter-spacing: .1em;
  margin-bottom: 2rem;
  margin-top: 3rem;
  text-align: center;
  position: relative;
  padding-bottom: 1rem;
}

.srv-section-label::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 40px;
  height: 2px;
  background: var(--c-gold);
}

.srv-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 2rem;
  max-width: 1200px;
  margin-inline: auto;
}

.srv-row {
  border: none;
  padding: 0;
  cursor: pointer;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--c-blush) 0%, var(--c-gold) 100%);
  opacity: 0.85;
  transition: all .35s var(--ease);
  overflow: hidden;
  position: relative;
  min-height: 320px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 2rem;
  color: #fff;
}

.srv-row:hover {
  opacity: 1;
  transform: translateY(-8px);
  box-shadow: 0 20px 50px rgba(168,116,104,.3);
}

.srv-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-direction: column;
  gap: 1rem;
}

.srv-l {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  flex-direction: column;
}

.srv-n {
  font-family: var(--f-serif);
  font-size: 2.8rem;
  font-weight: 300;
  color: rgba(255,255,255,.4);
  min-width: auto;
  line-height: 1;
}

.srv-l h3 {
  font-family: var(--f-serif);
  font-size: 1.35rem;
  font-weight: 400;
  color: #fff;
}

.srv-l small {
  display: block;
  font-size: .7rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: rgba(255,255,255,.7);
  margin-top: 0;
}

.srv-r {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  align-self: flex-end;
  margin-top: auto;
}

.srv-price {
  font-family: var(--f-serif);
  font-size: 1.5rem;
  font-weight: 300;
  color: #fff;
}

.srv-plus {
  width: 32px;
  height: 32px;
  border: 1.5px solid rgba(255,255,255,.8);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  color: #fff;
  transition: all .3s var(--ease);
  background: transparent;
}

.srv-row:hover .srv-plus {
  transform: scale(1.15) rotate(45deg);
  background: rgba(255,255,255,.2);
}

.srv-body {
  display: none;
  padding: 0;
  margin-top: auto;
}

.srv-body p {
  font-size: .9rem;
  color: rgba(255,255,255,.85);
  line-height: 1.6;
  margin-bottom: .75rem;
}

.srv-row.open .srv-body {
  display: block;
}

.srv-row:last-child {
  border-bottom: none;
}

/* COMBOS STYLING */
.srv-combo {
  background: linear-gradient(135deg, var(--c-blush) 0%, var(--c-gold) 100%) !important;
  min-height: 180px;
  display: flex;
  flex-direction: row;
  padding: 2.5rem !important;
  position: relative;
  overflow: hidden;
}

.srv-combo::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 30% 70%, rgba(255,255,255,.1), transparent);
  pointer-events: none;
}

.srv-combo .srv-top {
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  position: relative;
  z-index: 1;
  gap: 2rem;
}

.srv-combo .srv-l {
  flex-direction: row;
  gap: 1.5rem;
  align-items: center;
}

.srv-combo .srv-badge {
  font-size: 3rem;
  line-height: 1;
  flex-shrink: 0;
}

.srv-combo h3 {
  font-family: var(--f-serif);
  font-size: 1.6rem;
  font-weight: 400;
  color: #fff;
  margin: 0;
}

.srv-combo small {
  color: rgba(255,255,255,.8);
  font-size: .8rem;
}

.srv-desc-combo {
  color: rgba(255,255,255,.85);
  font-size: .95rem;
  line-height: 1.5;
  margin-top: .5rem;
  margin-bottom: 0;
}

.srv-combo .srv-r {
  margin-top: 0;
}

.srv-combo .srv-price {
  color: #fff;
  font-size: 2.2rem;
  text-shadow: 0 2px 8px rgba(35,30,26,.2);
}

/* Combo premium (most expensive) */
.srv-combo-premium {
  box-shadow: 0 20px 60px rgba(196,151,141,.35);
  transform: scale(1.02);
}

.srv-combo-premium:hover {
  transform: scale(1.04) translateY(-8px);
  box-shadow: 0 30px 80px rgba(196,151,141,.4);
}

/* Combo mid-tier */
.srv-combo-mid {
  opacity: 0.95;
  box-shadow: 0 15px 40px rgba(196,151,141,.25);
}

.srv-combo-mid:hover {
  opacity: 1;
  transform: translateY(-6px);
  box-shadow: 0 20px 60px rgba(196,151,141,.3);
}

/* ================================================
   RITUAL BUILDER
================================================ */
.ritual { padding: 3.5rem 4rem; background: var(--c-bg2); }
.ritual-head { text-align: center; margin-bottom: 2.5rem; }
.ritual-head .h2 { margin-bottom: 0; }

/* Progress */
.progress-bar { display: flex; align-items: center; justify-content: center; margin-bottom: 3.5rem; gap: 0; }
.pb-step { display: flex; flex-direction: column; align-items: center; gap: .4rem; opacity: .35; transition: opacity .3s; }
.pb-step.active, .pb-step.done { opacity: 1; }
.pb-dot { width: 34px; height: 34px; border-radius: 50%; border: 1px solid var(--c-line); display: flex; align-items: center; justify-content: center; font-size: .65rem; font-weight: 500; color: var(--c-mute); transition: border-color .3s, background .3s, color .3s; }
.pb-step.active .pb-dot { border-color: var(--c-blush); background: var(--c-blush); color: #fff; }
.pb-step.done .pb-dot { border-color: var(--c-blush); color: var(--c-blush); }
.pb-step p { font-size: .58rem; letter-spacing: .12em; text-transform: uppercase; color: var(--c-mute); }
.pb-line { flex: 1; max-width: 72px; height: 1px; background: var(--c-line); margin-bottom: 1.4rem; }

/* Panels */
.step { display: none; max-width: 700px; margin-inline: auto; animation: panelIn .4s var(--ease); }
.step.active { display: block; }
@keyframes panelIn { from { opacity:0; transform: translateY(12px); } to { opacity:1; transform: none; } }
.step-title { font-family: var(--f-serif); font-size: 1.55rem; font-weight: 400; color: var(--c-ink); text-align: center; margin-bottom: 2.25rem; }
.step-nav { display: flex; align-items: center; justify-content: space-between; margin-top: 2rem; }
.sum-nav { justify-content: center; gap: 1.5rem; flex-wrap: wrap; }
.btn-next { padding: .875rem 2rem; background: var(--c-ink); color: #fff; font-size: .7rem; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; border-radius: 2px; transition: background .25s, transform .2s var(--ease); }
.btn-next:hover:not(:disabled) { background: var(--c-ink2); transform: translateY(-2px); }
.btn-next:disabled { opacity: .3; cursor: not-allowed; }
.btn-prev { font-size: .7rem; letter-spacing: .1em; text-transform: uppercase; color: var(--c-mute); transition: color .2s; }
.btn-prev:hover { color: var(--c-ink); }

/* Occasion */
.occ-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; margin-bottom: 1.75rem; }
.occ { display: flex; flex-direction: column; align-items: center; gap: .4rem; padding: 1.75rem 1.25rem; background: var(--c-surface); border: 1px solid var(--c-line); border-radius: 4px; text-align: center; transition: border-color .25s, background .25s, transform .2s var(--ease); }
.occ:hover { border-color: var(--c-blush); transform: translateY(-2px); }
.occ.sel { border-color: var(--c-blush); background: var(--c-blush-bg); }
.occ-em { font-size: 1.75rem; }
.occ b { font-family: var(--f-serif); font-size: 1.05rem; font-weight: 400; color: var(--c-ink); }
.occ small { font-size: .72rem; color: var(--c-mute); }

/* Pick list (services) */
.pick-list { display: flex; flex-direction: column; gap: .4rem; margin-bottom: 1.25rem; }
.pick-row { display: block; cursor: pointer; }
.pick-row input { appearance: none; position: absolute; opacity: 0; pointer-events: none; }
.pr-inner { display: flex; align-items: center; gap: 1.1rem; padding: 1rem 1.25rem; background: var(--c-surface); border: 1px solid var(--c-line); border-radius: 4px; transition: border-color .2s, background .2s; cursor: pointer; }
.pr-inner:hover { border-color: var(--c-light); }
.pick-row input:checked + .pr-inner { border-color: var(--c-blush); background: var(--c-blush-bg); }
.pr-num { font-family: var(--f-serif); font-size: .95rem; font-weight: 300; color: var(--c-light); min-width: 2rem; }
.pr-info { flex: 1; }
.pr-info b { display: block; font-family: var(--f-serif); font-size: 1rem; font-weight: 400; color: var(--c-ink); }
.pr-info small { font-size: .6rem; letter-spacing: .12em; text-transform: uppercase; color: var(--c-mute); }
.pr-price { font-family: var(--f-serif); font-size: 1.15rem; font-weight: 300; color: var(--c-ink2); }
.pr-chk { display: none; width: 20px; height: 20px; border-radius: 50%; background: var(--c-blush); color: #fff; font-size: .65rem; align-items: center; justify-content: center; flex-shrink: 0; }
.pick-row input:checked + .pr-inner .pr-chk { display: flex; }

/* Extras */
.ext-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .75rem; margin-bottom: 1.25rem; }
.ext-card { display: block; cursor: pointer; }
.ext-card input { appearance: none; position: absolute; opacity: 0; pointer-events: none; }
.ec-inner { display: flex; flex-direction: column; align-items: center; gap: .35rem; padding: 1.4rem 1rem; background: var(--c-surface); border: 1px solid var(--c-line); border-radius: 4px; text-align: center; transition: border-color .2s, background .2s, transform .2s var(--ease); cursor: pointer; }
.ec-inner:hover { border-color: var(--c-light); transform: translateY(-2px); }
.ext-card input:checked + .ec-inner { border-color: var(--c-blush); background: var(--c-blush-bg); }
.ec-inner > span { font-size: 1.6rem; }
.ec-inner b { font-family: var(--f-serif); font-size: .9rem; font-weight: 400; color: var(--c-ink); }
.ec-inner small { font-size: .78rem; color: var(--c-blush2); font-family: var(--f-serif); }

/* Running total */
.running { display: flex; align-items: center; justify-content: space-between; padding: .875rem 1.25rem; background: var(--c-surface); border: 1px solid var(--c-line2); border-radius: 4px; margin-bottom: 1.75rem; font-size: .78rem; color: var(--c-mute); }
.running b { font-family: var(--f-serif); font-size: 1.75rem; font-weight: 300; color: var(--c-blush); }

/* Summary */
.summary { background: var(--c-surface); border: 1px solid var(--c-line); border-radius: 4px; padding: 2rem; margin-bottom: 2rem; display: flex; flex-direction: column; gap: 1.4rem; }
.sum-row { display: flex; flex-direction: column; gap: .3rem; }
.sum-block { display: flex; flex-direction: column; gap: .5rem; }
.sum-k { font-size: .6rem; letter-spacing: .2em; text-transform: uppercase; color: var(--c-blush2); }
.sum-v { font-family: var(--f-serif); font-size: 1rem; color: var(--c-ink); }
.summary ul { list-style: none; display: flex; flex-direction: column; gap: .3rem; }
.summary li { display: flex; justify-content: space-between; font-size: .88rem; color: var(--c-mute); padding-bottom: .3rem; border-bottom: 1px solid var(--c-line); }
.sum-total { display: flex; justify-content: space-between; align-items: center; padding-top: 1rem; border-top: 1px solid var(--c-line2); font-size: .65rem; letter-spacing: .15em; text-transform: uppercase; color: var(--c-mute); }
.sum-total big { font-family: var(--f-serif); font-size: 2.2rem; font-weight: 300; color: var(--c-blush); }

/* ================================================
   GALERÍA — Masonry Grid (no horizontal scroll)
================================================ */
.galeria {
  padding: 3.5rem 6rem;
  background: var(--c-bg);
}

.gal-head {
  margin-bottom: 4rem;
  text-align: center;
}

.gal-scroll {
  overflow-x: visible;
  overflow-y: visible;
  padding-bottom: 0;
  cursor: auto;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
  max-width: 1400px;
  margin-inline: auto;
}

.gal-scroll:active {
  cursor: auto;
}

.gal-track {
  display: contents;
}

.gal-fig {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  flex-shrink: unset;
  scroll-snap-align: unset;
  height: 320px;
  width: 100%;
  cursor: pointer;
}

.gal-fig.gal-tall {
  width: auto;
  height: 400px;
}

.gal-fig.gal-wide {
  width: auto;
  grid-column: span 2;
  height: 280px;
}

.gal-fig img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: saturate(.85) brightness(1);
  transition: transform .6s var(--ease), filter .4s;
}

.gal-fig:hover img {
  transform: scale(1.08);
  filter: saturate(1) brightness(1.05);
}

.gal-fig figcaption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 1.5rem;
  background: linear-gradient(to top, rgba(35,30,26,.7) 0%, transparent 100%);
  font-family: var(--f-serif);
  font-size: 1rem;
  font-style: italic;
  color: rgba(248,244,239,.95);
  opacity: 0;
  transition: opacity .35s;
}

.gal-fig:hover figcaption {
  opacity: 1;
}

/* ================================================
   TESTIMONIOS — Cards Grid (no carousel)
================================================ */
.testi { padding: 3.5rem 5rem; background: var(--c-bg); }
.testi-head { text-align: center; margin-bottom: 3rem; }

.testi-track {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 2.5rem;
  max-width: 1300px;
  margin-inline: auto;
}

.tc {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  background: linear-gradient(135deg, rgba(168,116,104,.08) 0%, rgba(196,163,104,.06) 100%);
  border: 1px solid rgba(168,116,104,.15);
  border-radius: 12px;
  padding: 2.5rem;
  backdrop-filter: blur(4px);
  transition: all .4s var(--ease);
  position: relative;
  overflow: hidden;
}

.tc::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--c-blush) 0%, var(--c-gold) 50%, transparent 100%);
  border-radius: 12px 12px 0 0;
}

.tc:hover {
  transform: translateY(-8px);
  background: linear-gradient(135deg, rgba(168,116,104,.12) 0%, rgba(196,163,104,.1) 100%);
  border-color: rgba(168,116,104,.25);
  box-shadow: 0 20px 50px rgba(168,116,104,.15);
}

.tc.active {
  display: flex;
}

@keyframes tcIn { from { opacity:0; transform: translateX(18px); } to { opacity:1; transform: none; } }

.tc-stars {
  color: var(--c-gold);
  letter-spacing: .22em;
  font-size: 1.05rem;
  font-weight: 500;
}

.tc blockquote {
  font-family: var(--f-serif);
  font-size: 1.15rem;
  font-style: italic;
  font-weight: 300;
  color: var(--c-ink);
  line-height: 1.8;
  margin: 0;
}

.tc footer {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  margin-top: .5rem;
  padding-top: 1.5rem;
  border-top: 1px solid rgba(168,116,104,.1);
}

.tc-av {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--c-blush) 0%, var(--c-gold) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--f-serif);
  font-size: 1.4rem;
  font-weight: 400;
  color: #fff;
  flex-shrink: 0;
  box-shadow: 0 4px 16px rgba(168,116,104,.2);
}

.tc footer small {
  font-size: .8rem;
  color: var(--c-mute);
  font-weight: 400;
  letter-spacing: .04em;
}

.testi-ctrl {
  display: none;
}

.tc-btn { display: none; }
.tc-dots { display: none; }

/* ================================================
   CONTACTO — Premium action buttons
================================================ */
.contacto {
  padding: 3.5rem 6rem;
  background: var(--c-bg);
}

.contacto-in {
  max-width: 600px;
  margin-inline: auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.4rem;
}

.contacto-in .h2 {
  margin-bottom: .5rem;
  font-size: clamp(2.2rem, 3vw, 3rem);
}

.contacto-in .body {
  max-width: 100%;
  font-size: 1rem;
  color: var(--c-ink2);
  margin-bottom: 1rem;
}

.c-actions {
  width: 100%;
  margin-top: 2.5rem;
  border-top: 1px solid var(--c-line);
}

.c-action {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  padding: 1.5rem 0;
  border: none;
  border-bottom: 1px solid var(--c-line);
  background: transparent;
  cursor: pointer;
  text-decoration: none;
  color: var(--c-ink);
  width: 100%;
  text-align: left;
  transition: padding-left .3s var(--ease);
}

.c-action:hover { padding-left: .75rem; }
.c-action:hover .ca-arr { transform: translateX(5px); color: var(--c-blush); }


.ca-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: .2rem;
}

.ca-body b {
  font-family: var(--f-serif);
  font-size: 1.2rem;
  font-weight: 400;
  color: var(--c-ink);
  letter-spacing: .01em;
}

.ca-body small {
  font-size: .72rem;
  color: var(--c-mute);
  letter-spacing: .05em;
  font-weight: 400;
}

.ca-arr {
  font-size: 1.1rem;
  color: var(--c-gold);
  transition: transform .3s var(--ease), color .3s;
  flex-shrink: 0;
}

/* ================================================
   MAQUILLADORES — Partnership Section
================================================ */
.maquilladores {
  padding: 3.5rem 6rem;
  background: var(--c-bg);
  border-top: 1px solid rgba(122,139,121,.1);
}

.maq-in {
  max-width: 900px;
  margin-inline: auto;
}

.maq-content {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2.5rem;
}

.maq-desc {
  font-size: 1.05rem;
  max-width: 500px;
  color: var(--c-ink2);
  line-height: 1.85;
}

.maq-benefits {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 2rem;
  margin: 1rem 0;
  width: 100%;
}

.maq-b {
  padding: 2rem;
  background: linear-gradient(135deg, rgba(122,139,121,.06) 0%, rgba(122,139,121,.03) 100%);
  border: 1px solid rgba(122,139,121,.12);
  border-radius: 12px;
  transition: all .3s var(--ease);
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: center;
  text-align: center;
}

.maq-b:hover {
  transform: translateY(-6px);
  background: linear-gradient(135deg, rgba(122,139,121,.1) 0%, rgba(122,139,121,.06) 100%);
  border-color: rgba(122,139,121,.25);
  box-shadow: 0 12px 32px rgba(122,139,121,.1);
}

.maq-icon {
  font-size: 2.2rem;
  display: block;
}

.maq-b h4 {
  font-family: var(--f-serif);
  font-size: 1.1rem;
  font-weight: 400;
  color: var(--c-ink);
  margin: 0;
}

.maq-b p {
  font-size: .9rem;
  color: var(--c-mute);
  margin: 0;
  line-height: 1.6;
}

.maq-cta {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  align-items: center;
  margin-top: 1rem;
}

.maq-cta p {
  font-family: var(--f-serif);
  font-size: 1.2rem;
  color: var(--c-ink);
  font-weight: 400;
  margin: 0;
}

/* ================================================
   FOOTER
================================================ */
.footer { padding: 4rem; background: var(--c-bg2); border-top: 1px solid var(--c-line); display: flex; flex-direction: column; align-items: center; gap: 1.5rem; text-align: center; }
.footer-logo-svg { color: var(--c-blush2); }
.footer-tag { font-family: var(--f-serif); font-size: 1rem; color: var(--c-blush2); }
.footer-nav { display: flex; gap: 2rem; flex-wrap: wrap; justify-content: center; }
.footer-nav a { font-size: .65rem; letter-spacing: .12em; text-transform: uppercase; color: var(--c-mute); transition: color .2s; }
.footer-nav a:hover { color: var(--c-blush2); }
.footer-copy { font-size: .65rem; color: var(--c-light); }

/* ================================================
   WHATSAPP
================================================ */
.wa { position: fixed; bottom: 2rem; right: 2rem; z-index: 200; width: 54px; height: 54px; border-radius: 50%; background: #25d366; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 20px rgba(37,211,102,.4); transition: transform .3s var(--ease), box-shadow .3s; }
.wa:hover { transform: scale(1.1) translateY(-3px); box-shadow: 0 10px 34px rgba(37,211,102,.5); }
.wa-ring { position: absolute; inset: 0; border-radius: 50%; background: #25d366; animation: waRing 2.5s ease-out infinite; }
@keyframes waRing { 0% { transform: scale(1); opacity:.6; } 100% { transform: scale(1.85); opacity:0; } }

/* ================================================
   PAY MODAL
================================================ */
.pay-modal {
  border: none;
  border-left: 3px solid var(--c-gold);
  background: var(--c-bg);
  color: var(--c-ink);
  padding: 3rem 2.75rem;
  max-width: 440px;
  width: calc(100% - 2rem);
  position: fixed;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  z-index: 500;
  box-shadow: -16px 0 60px rgba(42,36,32,.06), 0 40px 80px rgba(42,36,32,.14);
}

.pay-modal[open] { display: block; }

.pm-x {
  position: absolute;
  top: 1.5rem; right: 1.5rem;
  color: var(--c-mute);
  font-size: 1.4rem;
  font-weight: 200;
  line-height: 1;
  transition: color .2s;
  background: none; border: none; cursor: pointer;
}

.pm-x:hover { color: var(--c-ink); }

.pm-head { margin-bottom: 2rem; }
.pm-head .eyebrow { margin-bottom: .75rem; }

.pay-modal h3 {
  font-family: var(--f-serif);
  font-size: 2.4rem;
  font-weight: 300;
  margin-bottom: .5rem;
  letter-spacing: -.01em;
}

.pay-modal .pm-head p {
  font-size: .78rem;
  color: var(--c-mute);
  letter-spacing: .04em;
  margin-bottom: 0;
}

.pm-list {
  border-top: 1px solid var(--c-line);
  margin-bottom: 2.5rem;
}

.pm-row {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  padding: 1.15rem 0;
  border-bottom: 1px solid var(--c-line);
}

.pm-num {
  font-family: var(--f-serif);
  font-size: .68rem;
  color: var(--c-blush);
  letter-spacing: .15em;
  min-width: 1.6rem;
  opacity: .55;
  flex-shrink: 0;
}

.pm-info {
  display: flex;
  flex-direction: column;
  gap: .2rem;
}

.pm-info b {
  font-size: .88rem;
  font-weight: 500;
  color: var(--c-ink);
  letter-spacing: .01em;
}

.pm-info small {
  font-size: .7rem;
  color: var(--c-mute);
  letter-spacing: .04em;
}
.pay-bg { display: none; position: fixed; inset: 0; background: rgba(35,30,26,.3); backdrop-filter: blur(4px); z-index: 490; }
.pay-bg.show { display: block; }

/* ================================================
   RESPONSIVE
================================================ */
@media (max-width: 900px) {
  :root { --nav-h: 60px; }
  .nav { padding: 0 1.25rem; grid-template-columns: auto 1fr auto; }
  .nav-left { display: none; }
  .nav-right-links { display: none; }
  .nav-logo-center { justify-self: center; }
  .nav-utils .nm-cta { display: none; }

  /* Mobile menu overlay */
  .nav-left.open, .nav-right-links.open {
    display: flex; position: fixed; inset: var(--nav-h) 0 0;
    background: rgba(250,246,240,.97); backdrop-filter: blur(20px);
    flex-direction: column; align-items: center; justify-content: center;
    gap: 2.5rem; z-index: 99;
  }
  .nav-left.open .nm-link, .nav-right-links.open .nm-link { font-size: 1.3rem; letter-spacing: .1em; }
  .burger { display: flex; }

  .hero { grid-template-columns: 1fr; min-height: auto; }
  .hero-txt { padding: 3.5rem 1.5rem; }
  .hero-media { height: 65vw; }
  .hero-img { height: 100%; }
  .hb-item { padding: 0 1.25rem; }

  .novia { grid-template-columns: 1fr; }
  .novia-img { height: 65vw; }
  .novia-copy { padding: 3.5rem 1.5rem; }

  .servicios { padding: 5rem 1.5rem; }
  .srv-body { padding-left: 1rem; }

  .ritual { padding: 5rem 1.5rem; }
  .occ-grid { grid-template-columns: 1fr 1fr; }
  .ext-grid { grid-template-columns: 1fr 1fr; }
  .pb-step p { display: none; }
  .pb-line { max-width: 32px; }

  .galeria { padding: 5rem 0 5rem 1.5rem; }
  .gal-head { padding-right: 1.5rem; }
  .gal-track { padding-right: 1.5rem; }
  .gal-fig { width: 240px; height: 320px; }
  .gal-fig.gal-tall { width: 210px; height: 380px; }
  .gal-fig.gal-wide { width: 420px; height: 280px; }

  .testi { padding: 5rem 1.5rem; }
  .contacto { padding: 5rem 1.5rem; }



  .footer { padding: 3rem 1.5rem; }

}

@media (max-width: 480px) {
  .hero-h1 { font-size: clamp(2.6rem,10.5vw,3.5rem); }
  .occ-grid { grid-template-columns: 1fr; }
  .ext-grid { grid-template-columns: 1fr; }
  .step-nav { flex-direction: column; gap: .75rem; align-items: stretch; text-align: center; }
  .btn-next, .btn-prev { width: 100%; }
  .hb-item { padding: 0 .75rem; }
}

/* ================================================
   KALM MOMENTS INTERACTIONS — Custom Cursor
================================================ */
@media (hover: hover) {
  *, cursor: none !important; }
}

#cursor {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9998;
  opacity: 0;
  transition: opacity .4s;
}
#cursor.ready { opacity: 1; }

.cur-dot {
  position: absolute;
  top: 0; left: 0;
  width: 8px; height: 8px;
  margin: -4px 0 0 -4px;
  border-radius: 50%;
  background: var(--c-blush);
  will-change: transform;
  transition: transform .08s, background .3s, opacity .2s;
}

.cur-ring {
  position: absolute;
  top: 0; left: 0;
  width: 40px; height: 40px;
  margin: -20px 0 0 -20px;
  border-radius: 50%;
  border: 1.5px solid var(--c-blush);
  will-change: transform;
  transition: width .35s var(--ease), height .35s var(--ease),
              margin .35s var(--ease), border-color .35s, background .35s, opacity .2s;
}

/* Link hover state */
body.cur-link .cur-ring {
  width: 64px; height: 64px;
  margin: -32px 0 0 -32px;
  border-color: rgba(122,139,121,.6);
  background: rgba(122,139,121,.08);
}
body.cur-link .cur-dot {
  opacity: 0;
  transform: scale(0);
}

/* Pressed */
body.cur-pressed .cur-ring {
  width: 28px; height: 28px;
  margin: -14px 0 0 -14px;
  background: rgba(122,139,121,.15);
}

/* ================================================
   KALM MOMENTS — Hover Image Reveal
================================================ */
.hov-img {
  position: fixed;
  top: 0; left: 0;
  width: 220px; height: 280px;
  border-radius: 4px;
  overflow: hidden;
  pointer-events: none;
  z-index: 9000;
  opacity: 0;
  transform: scale(.88) rotate(-4deg) translate3d(0,0,0);
  transition: opacity .45s var(--ease), transform .45s var(--ease);
  will-change: transform, opacity;
  box-shadow: 0 24px 64px rgba(42,36,32,.22), 0 4px 16px rgba(42,36,32,.1);
}
.hov-img.is-on {
  opacity: 1;
  transform: scale(1) rotate(0deg) translate3d(0,0,0);
}
.hov-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(.88);
  display: block;
}
@media (hover: none) { .hov-img { display: none; } }

/* ================================================
   KALM MOMENTS — Novia hover reveal (subtle)
================================================ */
.novia-img { cursor: auto; }
.novia-img[data-img]:hover { filter: none; }

/* ================================================
   KALM MOMENTS — Service card hover (enhanced)
================================================ */
.srv-row[data-img] { cursor: auto; }

/* ================================================
   KALM MOMENTS — Magnetic button wrapper
================================================ */
[data-mag] {
  transition: transform .4s var(--ease);
  will-change: transform;
}

/* ================================================
   KALM MOMENTS — Enhanced section reveals
================================================ */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .85s var(--ease), transform .85s var(--ease);
}
.reveal.is-on {
  opacity: 1;
  transform: none;
}

/* Stagger siblings */
.reveal:nth-child(2) { transition-delay: .08s; }
.reveal:nth-child(3) { transition-delay: .16s; }
.reveal:nth-child(4) { transition-delay: .24s; }

/* ================================================
   KALM MOMENTS — Gallery parallax items
================================================ */
.gal-fig {
  will-change: transform;
}
.gal-fig img {
  will-change: transform;
}

/* ================================================
   KALM MOMENTS — Smooth scroll (Lenis removes default)
================================================ */
html { scroll-behavior: auto; }

/* ================================================
   KALM MOMENTS — Section decorative lines
================================================ */
.servicios-head::after,
.testi-head::after,
.gal-head::after {
  content: '';
  display: block;
  width: 40px;
  height: 1px;
  background: var(--c-blush);
  margin: 2rem auto 0;
  opacity: .5;
}

/* ================================================
   KALM MOMENTS — Enhanced testimonial card animation
================================================ */
.tc {
  transition: transform .5s var(--ease), box-shadow .5s var(--ease),
              background .5s, border-color .5s;
}

/* ================================================
   KALM MOMENTS — Hero btn ghost update for dark bg
================================================ */
.btn-ghost-dark {
  border-color: rgba(255,255,255,.35);
  color: rgba(255,255,255,.8);
}
.btn-ghost-dark:hover {
  border-color: rgba(255,255,255,.7);
  color: #fff;
  transform: translateY(-2px);
}

/* ================================================
   KALM MOMENTS — Novia section enhancement
================================================ */
.novia {
  position: relative;
}
.novia-copy {
  position: relative;
}
.novia-copy::before {
  content: '';
  position: absolute;
  top: 6rem; left: 0;
  width: 2px; height: 60px;
  background: linear-gradient(to bottom, var(--c-blush), transparent);
  opacity: .5;
}

/* ================================================
   KALM MOMENTS — Tape enhanced
================================================ */
.tape {
  position: relative;
  overflow: hidden;
}
.tape::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, var(--c-bg2) 0%, transparent 5%, transparent 95%, var(--c-bg2) 100%);
  z-index: 1;
  pointer-events: none;
}

/* ================================================
   KALM MOMENTS — Services section line list style
================================================ */
.servicios {
  position: relative;
}
.servicios::before {
  content: '';
  position: absolute;
  top: 0; left: 6rem;
  width: 1px; height: 100%;
  background: linear-gradient(to bottom, transparent, var(--c-line) 10%, var(--c-line) 90%, transparent);
  pointer-events: none;
}
@media (max-width: 900px) { .servicios::before { display: none; } }

/* ================================================
   KALM MOMENTS — Footer enhancement
================================================ */
.footer {
  position: relative;
}
.footer::before {
  content: '';
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: 60px; height: 1px;
  background: var(--c-blush);
  opacity: .4;
}

/* ================================================
   EXPERIENCE — Unified 4-step ritual builder
================================================ */
.experience {
  padding: 3.5rem 4rem;
  background: var(--c-bg2);
  min-height: 100svh;
}

.exp-head {
  text-align: center;
  margin-bottom: 3.5rem;
}
.exp-head .eyebrow { margin-bottom: 1rem; }

/* ── Step tabs ── */
.exp-tabs {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  margin-bottom: 4rem;
  flex-wrap: wrap;
}
.et-sep {
  color: var(--c-light);
  font-size: .75rem;
  padding: 0 .25rem;
}
.exp-tab {
  display: flex;
  align-items: baseline;
  gap: .55rem;
  padding: .55rem 1.1rem;
  border: 1px solid var(--c-line);
  border-radius: 2px;
  background: transparent;
  cursor: pointer;
  transition: border-color .25s, background .25s, color .25s;
  color: var(--c-mute);
}
.exp-tab .et-n {
  font-family: var(--f-serif);
  font-size: .9rem;
  font-weight: 300;
  line-height: 1;
}
.exp-tab .et-l {
  font-size: .62rem;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.exp-tab.active {
  border-color: var(--c-blush);
  background: var(--c-surface);
  color: var(--c-ink);
}
.exp-tab.done {
  border-color: var(--c-blush);
  color: var(--c-blush2);
}

/* ── Panels ── */
.exp-panel {
  display: none;
  max-width: 860px;
  margin-inline: auto;
  animation: panelIn .4s var(--ease);
}
.exp-panel.active { display: block; }

.exp-ptitle {
  font-family: var(--f-serif);
  font-size: 1.45rem;
  font-weight: 400;
  color: var(--c-ink);
  text-align: center;
  margin-bottom: 2.5rem;
}

/* ── Package cards ── */
.pkg-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
  margin-bottom: 2.5rem;
}

.pkg-card {
  display: flex;
  flex-direction: column;
  background: var(--c-surface);
  border: 1.5px solid var(--c-line);
  border-radius: 6px;
  padding: 0;
  cursor: pointer;
  transition: border-color .3s var(--ease), transform .3s var(--ease), box-shadow .3s;
  text-align: left;
  overflow: hidden;
  position: relative;
}
.pkg-card:hover {
  border-color: var(--c-blush);
  transform: translateY(-5px);
  box-shadow: 0 14px 40px rgba(122,139,121,.18);
}
.pkg-card.sel {
  border-color: var(--c-blush);
  background: var(--c-blush-bg);
}
.pkg-card.sel .pkg-sel { opacity: 1; }

.pkg-featured {
  border-color: var(--c-blush);
  position: relative;
}
.pkg-featured::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--c-blush);
}

.pkg-top {
  padding: 1.75rem 1.75rem 1.25rem;
  border-bottom: 1px solid var(--c-line);
}
.pkg-badge {
  font-size: .58rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--c-blush2);
  margin-bottom: .6rem;
  opacity: .9;
}
.pkg-top h4 {
  font-family: var(--f-serif);
  font-size: 1.2rem;
  font-weight: 400;
  color: var(--c-ink);
  letter-spacing: .05em;
  margin-bottom: .35rem;
}
.pkg-time {
  font-size: .68rem;
  letter-spacing: .08em;
  color: var(--c-mute);
}

.pkg-includes {
  list-style: none;
  padding: 1.25rem 1.75rem;
  display: flex;
  flex-direction: column;
  gap: .5rem;
  flex: 1;
}
.pkg-includes li {
  font-size: .8rem;
  color: var(--c-ink2);
  display: flex;
  align-items: center;
  gap: .55rem;
}
.pkg-includes li::before {
  content: '—';
  color: var(--c-blush);
  font-size: .7rem;
  flex-shrink: 0;
}

.pkg-price {
  font-family: var(--f-serif);
  font-size: 2rem;
  font-weight: 300;
  color: var(--c-ink);
  padding: 1.25rem 1.75rem;
  border-top: 1px solid var(--c-line);
}

.pkg-sel {
  position: absolute;
  top: 1rem; right: 1rem;
  background: var(--c-blush);
  color: #fff;
  font-size: .58rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: .3rem .65rem;
  border-radius: 2px;
  opacity: 0;
  transition: opacity .25s;
}

/* ── OR separator ── */
.or-sep {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  margin: 2.5rem 0;
  color: var(--c-mute);
  font-size: .65rem;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.or-sep::before, .or-sep::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--c-line);
}

/* ── Individual service picks ── */
.spick-list {
  display: flex;
  flex-direction: column;
  gap: .35rem;
  margin-bottom: 1.5rem;
}
.spick {
  display: block;
  cursor: pointer;
}
.spick input {
  appearance: none;
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.sp-inner {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: .9rem 1.25rem;
  background: var(--c-surface);
  border: 1px solid var(--c-line);
  border-radius: 4px;
  transition: border-color .2s, background .2s;
  cursor: pointer;
}
.sp-inner:hover { border-color: var(--c-light); }
.spick input:checked + .sp-inner {
  border-color: var(--c-blush);
  background: var(--c-blush-bg);
}
.sp-n {
  font-family: var(--f-serif);
  font-size: .85rem;
  font-weight: 300;
  color: var(--c-light);
  min-width: 1.8rem;
}
.sp-info { flex: 1; }
.sp-info b {
  display: block;
  font-family: var(--f-serif);
  font-size: .98rem;
  font-weight: 400;
  color: var(--c-ink);
}
.sp-info small {
  font-size: .6rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--c-mute);
}
.sp-price {
  font-family: var(--f-serif);
  font-size: 1.05rem;
  font-weight: 300;
  color: var(--c-ink2);
}
.sp-chk {
  display: none;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--c-blush);
  color: #fff;
  font-size: .6rem;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.spick input:checked + .sp-inner .sp-chk { display: flex; }

/* ── Running total ── */
.exp-running {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .875rem 1.25rem;
  background: var(--c-surface);
  border: 1px solid var(--c-line2);
  border-radius: 4px;
  margin-bottom: 1.75rem;
  font-size: .75rem;
  color: var(--c-mute);
  letter-spacing: .08em;
}
.exp-running strong {
  font-family: var(--f-serif);
  font-size: 1.75rem;
  font-weight: 300;
  color: var(--c-blush);
}

/* ── Panel footer nav ── */
.exp-foot {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin-top: 1.5rem;
}
.exp-foot-2 {
  justify-content: space-between;
}
.exp-prev {
  font-size: .68rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--c-mute);
  transition: color .2s;
  padding: .5rem 0;
}
.exp-prev:hover { color: var(--c-ink); }

/* ── Occasion grid (step 2) ── */
.occ-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .75rem;
  margin-bottom: 1.75rem;
}

/* ── Ext grid (step 3) ── */
.ext-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .75rem;
  margin-bottom: 1.25rem;
}

/* ── Summary (step 4) ── */
.exp-summary {
  background: var(--c-surface);
  border: 1px solid var(--c-line);
  border-radius: 6px;
  padding: 2rem;
  margin-bottom: 2rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.es-section { display: flex; flex-direction: column; gap: .4rem; }
.es-k {
  font-size: .58rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--c-blush2);
}
.es-v {
  font-family: var(--f-serif);
  font-size: 1.05rem;
  color: var(--c-ink);
}
.es-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .35rem;
}
.es-list li {
  display: flex;
  justify-content: space-between;
  font-size: .83rem;
  color: var(--c-mute);
  padding-bottom: .35rem;
  border-bottom: 1px solid var(--c-line);
}
.es-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 1rem;
  border-top: 1.5px solid var(--c-line2);
  font-size: .62rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--c-mute);
}
.es-total big {
  font-family: var(--f-serif);
  font-size: 2.4rem;
  font-weight: 300;
  color: var(--c-blush);
}

/* ── Actions (step 4) ── */
.exp-actions {
  display: flex;
  flex-direction: column;
  gap: .75rem;
  margin-bottom: 1.5rem;
}
.ea-btn {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  padding: 1.5rem 2rem;
  border: 1.5px solid var(--c-line);
  border-radius: 6px;
  background: var(--c-surface);
  cursor: pointer;
  transition: border-color .25s var(--ease), transform .25s var(--ease), box-shadow .25s;
  text-decoration: none;
  color: var(--c-ink);
}
.ea-btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 30px rgba(42,36,32,.1);
}
.ea-pay { border-color: var(--c-blush); }
.ea-pay:hover { border-color: var(--c-blush2); box-shadow: 0 10px 30px rgba(122,139,121,.25); }
.ea-wa { border-color: #25d366; background: #f4fdf6; }
.ea-wa:hover { border-color: #25d366; box-shadow: 0 10px 30px rgba(37,211,102,.2); }
.ea-icon { font-size: 1.8rem; flex-shrink: 0; }
.ea-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: .25rem;
  text-align: left;
}
.ea-info b {
  font-family: var(--f-serif);
  font-size: 1.1rem;
  font-weight: 400;
  color: var(--c-ink);
}
.ea-info small {
  font-size: .75rem;
  color: var(--c-mute);
}
.ea-arr {
  font-size: 1.2rem;
  color: var(--c-blush);
  flex-shrink: 0;
}

/* ── Contacto section ── */
.contacto {
  padding: 3.5rem 4rem;
  background: var(--c-bg);
  border-top: 1px solid var(--c-line);
}
.contacto-in {
  max-width: 680px;
  margin-inline: auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
}
.contacto-in .body { max-width: 46ch; }


/* ── Dual currency display ── */
.pkg-price { display: flex; flex-direction: column; gap: .2rem; }
.pkg-price b { font-family: var(--f-serif); font-size: 2rem; font-weight: 300; color: var(--c-ink); }
.cur-mx { font-size: .6rem; letter-spacing: .12em; text-transform: uppercase; color: var(--c-ink2); font-family: var(--f-sans); }
.cur-usd { font-size: .72rem; color: var(--c-ink2); font-family: var(--f-sans); }

.sp-price { display: flex; flex-direction: column; gap: .05rem; align-items: flex-end; }
.sp-curr { font-size: .55rem; letter-spacing: .1em; text-transform: uppercase; color: var(--c-ink2); }
.sp-usd { font-size: .65rem; color: var(--c-ink2); }

.ec-usd { display: block; font-size: .65rem; color: var(--c-mute); opacity: .7; margin-top: .1rem; }

/* ── Responsive: experience ── */
@media (max-width: 900px) {
  .experience { padding: 4rem 1.5rem; }
  .pkg-grid { grid-template-columns: 1fr; }
  .ext-grid { grid-template-columns: repeat(2, 1fr); }
  .occ-grid { grid-template-columns: 1fr 1fr; }
  .exp-tabs { gap: .25rem; }
  .et-sep { display: none; }
  .exp-tab { padding: .45rem .75rem; }
  .exp-tab .et-l { display: none; }
  .exp-panel { max-width: 100%; }
  .contacto { padding: 4rem 1.5rem; }
  .c-actions { max-width: 100%; }
}
@media (max-width: 480px) {
  .occ-grid { grid-template-columns: 1fr; }
  .ext-grid { grid-template-columns: 1fr 1fr; }
}

/* ── Email action button ── */
.ea-email { background: var(--c-bg); border: 1.5px solid var(--c-blush); color: var(--c-dark); }
.ea-email:hover { background: var(--c-blush); color: #fff; border-color: var(--c-blush); }

/* ── Testimonial names ── */
.tc-info { display: flex; flex-direction: column; gap: .15rem; }
.tc-name { font-family: var(--f-serif); font-size: 1rem; font-weight: 400; color: var(--c-blush); letter-spacing: .03em; }

/* ── Hide hover-reveal images when builder is active ── */
body.builder-active .hov-img,
body.builder-active [data-img]:hover::after { display: none !important; pointer-events: none; }

/* ================================================
   EMAIL RESERVATION MODAL
================================================ */
.email-modal {
  border: none;
  border-left: 3px solid var(--c-gold);
  background: var(--c-bg);
  color: var(--c-ink);
  padding: 2.75rem;
  max-width: 520px;
  width: calc(100% - 2rem);
  max-height: 90vh;
  overflow-y: auto;
  position: fixed;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  z-index: 500;
  box-shadow: -16px 0 60px rgba(42,36,32,.06), 0 40px 80px rgba(42,36,32,.14);
}
.email-modal[open] { display: block; }

.em-head { margin-bottom: 1.5rem; }
.em-head .eyebrow { margin-bottom: .6rem; }
.em-head h3 { font-family: var(--f-serif); font-size: 2rem; font-weight: 300; margin-bottom: .35rem; letter-spacing: -.01em; }
.em-sub { font-size: .76rem; color: var(--c-mute); letter-spacing: .04em; }

.em-summary {
  background: var(--c-bg2);
  border-left: 2px solid var(--c-blush);
  padding: .85rem 1rem;
  margin-bottom: 1.5rem;
  font-size: .8rem;
  color: var(--c-ink2);
  line-height: 1.6;
}
.em-summary b { font-family: var(--f-serif); font-size: .9rem; color: var(--c-ink); }

.em-form { display: flex; flex-direction: column; gap: 1rem; }

.em-row { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }

.em-field { display: flex; flex-direction: column; gap: .35rem; }
.em-field label { font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--c-mute); font-family: var(--f-sans); }
.em-req { color: var(--c-blush); }
.em-opt { font-size: .65rem; color: var(--c-mute); text-transform: none; letter-spacing: 0; }

.em-field input,
.em-field textarea {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--c-line);
  padding: .55rem 0;
  font-family: var(--f-sans);
  font-size: .88rem;
  color: var(--c-ink);
  outline: none;
  transition: border-color .25s;
  width: 100%;
}
.em-field input[type="date"] { cursor: pointer; }
.em-field input:focus,
.em-field textarea:focus { border-bottom-color: var(--c-blush); }
.em-field textarea { resize: vertical; min-height: 64px; line-height: 1.5; }
.em-field input::placeholder,
.em-field textarea::placeholder { color: var(--c-mute); opacity: .6; }

.em-radios { display: flex; gap: 1.25rem; flex-wrap: wrap; padding: .35rem 0; }
.em-radio { display: flex; align-items: center; gap: .4rem; cursor: pointer; font-size: .84rem; color: var(--c-ink2); }
.em-radio input[type="radio"] { accent-color: var(--c-blush); width: 1rem; height: 1rem; cursor: pointer; }
.em-radio:has(input:checked) span { color: var(--c-blush); }

.email-bg {
  display: none;
  position: fixed; inset: 0;
  background: rgba(250,246,240,.75);
  backdrop-filter: blur(5px);
  z-index: 499;
}
.email-bg.open { display: block; }

@media (max-width: 540px) {
  .email-modal { padding: 2rem 1.5rem; }
  .em-row { grid-template-columns: 1fr; }
}
