*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--grafito);background:var(--white);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;text-rendering:optimizeLegibility}
:root{
  --rosa:#C26E80;
  --rosa-acc:#A3576A;
  --blush:#E8B4BE;
  --rosa-med:#D4899A;
  --nude:#F5EDE8;
  --warm:#EDD9D0;
  --cream:#FAF7F5;
  --white:#FFFFFF;
  --grafito:#3A2E2C;
  --gris:#7A6562;
  --wa:#128C7E;
  --font-serif:'Playfair Display',Georgia,serif;
  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-body:'DM Sans',sans-serif;
  --ease: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-soft: cubic-bezier(0.22, 1, 0.36, 1);
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:1120px;margin:0 auto;padding:0 2rem}
.section{padding:5rem 2rem}
.section-header{text-align:center;margin-bottom:3.5rem}
.section-eyebrow{display:block;font-family:var(--font-body);font-size:11px;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;color:var(--rosa-acc);margin-bottom:0.75rem}
.section-title{font-family:var(--font-serif);font-size:clamp(28px, 4vw, 36px);font-weight:400;line-height:1.2;color:var(--grafito)}
.section-title em{font-style:italic}
.section-body{font-size:clamp(14px, 2vw, 15px);color:var(--gris);line-height:1.8;max-width:520px;margin:1rem auto 0;font-weight:300}

/* ===================== SCROLL REVEAL ===================== */
.js .reveal{opacity:0;transform:translateY(24px);transition:opacity 0.9s var(--ease-soft),transform 0.9s var(--ease-soft)}
.js .reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:0.1s}
.reveal-delay-2{transition-delay:0.2s}
.reveal-delay-3{transition-delay:0.3s}
.reveal-delay-4{transition-delay:0.4s}
.reveal-delay-5{transition-delay:0.5s}

/* ===================== HERO ENTRANCE ===================== */
.js .hero-entrance{opacity:0;transform:translateY(30px)}
.js .hero-entrance.visible{animation:heroSlide 0.9s var(--ease-soft) forwards}
.hero-entrance.d1{animation-delay:0s}
.hero-entrance.d2{animation-delay:0.15s}
.hero-entrance.d3{animation-delay:0.3s}
.hero-entrance.d4{animation-delay:0.45s}
.hero-entrance.d5{animation-delay:0.6s}
.hero-entrance.d6{animation-delay:0.8s}
@keyframes heroSlide{
  0%{opacity:0;transform:translateY(30px)}
  100%{opacity:1;transform:translateY(0)}
}

/* ===================== FLOATING DECORATIVE ===================== */
.float-el{position:absolute;border-radius:50%;pointer-events:none;opacity:0.35}
.float-el--petal{width:12px;height:12px;background:var(--blush)}
.float-el--petal-lg{width:20px;height:20px;background:var(--blush);opacity:0.2}
.float-el--dot{width:6px;height:6px;background:var(--rosa);opacity:0.15}
@keyframes floatA{
  0%,100%{transform:translate(0,0) rotate(0deg)}
  25%{transform:translate(6px,-8px) rotate(3deg)}
  50%{transform:translate(-4px,-14px) rotate(-2deg)}
  75%{transform:translate(8px,-6px) rotate(4deg)}
}
@keyframes floatB{
  0%,100%{transform:translate(0,0) rotate(0deg)}
  33%{transform:translate(-8px,-6px) rotate(-3deg)}
  66%{transform:translate(4px,-12px) rotate(2deg)}
}
.float-el--1{animation:floatA 14s var(--ease-soft) infinite;top:12%;left:5%}
.float-el--2{animation:floatB 18s var(--ease-soft) infinite;top:40%;right:3%}
.float-el--3{animation:floatA 16s var(--ease-soft) infinite reverse;bottom:20%;left:8%}
.float-el--4{animation:floatB 12s var(--ease-soft) infinite;top:65%;right:8%}
.float-el--5{animation:floatA 20s var(--ease-soft) infinite reverse;top:18%;right:12%}
.float-el--6{animation:floatB 15s var(--ease-soft) infinite;bottom:35%;left:3%}

/* ===================== NAV ===================== */
#main-nav {
  position: sticky;
  top: 0;
  width: 100%;
  z-index: 1000;
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 0.5px solid rgba(194, 110, 128, 0.1);
  transition: all 0.3s var(--ease-soft);
}
#main-nav * {
  box-sizing: border-box;
}
.nav-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0.85rem 2rem;
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center;
  justify-content: space-between;
}
.logo img {
  height: 28px;
  width: auto;
  transition: transform 0.3s var(--ease-soft);
}
.logo:hover img {
  transform: scale(1.05);
}
.nav-links {
  display: flex;
  flex-direction: row;
  gap: 2.2rem;
  align-items: center;
}
.nav-link {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--grafito);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  position: relative;
  transition: color 0.3s;
}
.nav-link::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 0;
  height: 1.5px;
  background: var(--rosa);
  transition: width 0.3s var(--ease-soft);
}
.nav-link:hover {
  color: var(--rosa);
}
.nav-link:hover::after {
  width: 100%;
}
.nav-actions {
  display: flex;
  align-items: center;
  gap: clamp(0.5rem, 2vw, 1.5rem);
}
.nav-cta {
  background: var(--rosa);
  color: white;
  padding: 0.65rem 1.4rem;
  font-family: var(--font-body);
  font-size: 12.5px;
  font-weight: 500;
  border-radius: 100px;
  transition: all 0.3s var(--ease-soft);
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.nav-cta svg {
  flex-shrink: 0;
}
.nav-link:last-child {
  margin-bottom: 0;
}

@media (min-width: 861px) {
  .nav-link:hover {
    color: var(--rosa);
    transform: translateY(-1px);
  }
}
.nav-mobile-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 5px;
  z-index: 1001;
}
.nav-mobile-toggle .bar {
  width: 22px;
  height: 2px;
  background: var(--grafito);
  border-radius: 2px;
  transition: all 0.3s var(--ease-soft);
}

.nav-overlay {
  position: fixed;
  inset: 0;
  background: rgba(58, 46, 44, 0.2);
  backdrop-filter: blur(4px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s var(--ease-soft);
  z-index: 999;
}
.nav-overlay.active {
  opacity: 1;
  pointer-events: auto;
}

/* ===================== HERO ===================== */
.hero{height:calc(100vh - 64px);height:calc(100dvh - 64px);min-height:500px;max-height:850px;display:grid;grid-template-columns:1fr 1fr;background:linear-gradient(135deg,var(--cream) 0%,var(--nude) 100%);position:relative;overflow:hidden}
.hero-left{display:flex;flex-direction:column;justify-content:center;padding:4rem 6rem;position:relative;z-index:2}
.hero-eyebrow{font-family:var(--font-body);font-size:12px;font-weight:500;letter-spacing:0.25em;text-transform:uppercase;color:var(--rosa-acc);margin-bottom:1.5rem;display:block}
.hero-left h1{font-family:var(--font-serif);font-size:clamp(36px,4.5vw,58px);font-weight:400;line-height:1.1;color:var(--grafito);margin-bottom:1.5rem;max-width:520px}
.hero-left h1 em{font-style:italic;color:var(--rosa-acc)}
.hero-left p{font-size:15.5px;color:var(--gris);line-height:1.8;max-width:400px;font-weight:300;margin-bottom:2rem}
.hero-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;position:relative}
.hero-divider{width:60px;height:1.5px;background:var(--blush);margin:1.5rem 0}
.hero-note{display:block;margin-top:0.75rem;font-size:12px;color:var(--gris);font-weight:300}
.hero-right{position:relative;overflow:hidden;background:var(--warm);display:flex;align-items:flex-end;justify-content:center}
.hero-image{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform 1.5s var(--ease-soft)}
.hero-image:hover{transform:scale(1.03)}
.hero-image-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(237,217,208,0.3) 0%,rgba(245,237,232,0.1) 100%);pointer-events:none}
.hero-image-label{position:absolute;bottom:1.5rem;left:1.5rem;font-size:10px;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;color:rgba(58,46,44,0.5);background:rgba(255,255,255,0.5);backdrop-filter:blur(4px);padding:0.35rem 0.7rem;border-radius:100px}
.hero-scroll {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  color: var(--gris);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  opacity: 0.6;
}
.hero-scroll::after {
  content: '';
  width: 1px;
  height: 40px;
  background: linear-gradient(to bottom, var(--rosa), transparent);
  animation: scrollLine 2s infinite;
}
@keyframes scrollLine {
  0% { transform: scaleY(0); transform-origin: top; }
  50% { transform: scaleY(1); transform-origin: top; }
  50.1% { transform: scaleY(1); transform-origin: bottom; }
  100% { transform: scaleY(0); transform-origin: bottom; }
}

/* ===================== BUTTONS ===================== */
.btn{background:var(--rosa);color:white;border:none;padding:0.85rem 1.8rem;font-family:var(--font-body);font-size:14px;font-weight:500;border-radius:100px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:transform 0.3s var(--ease-soft),box-shadow 0.3s var(--ease-soft),background 0.25s}
.btn:hover{background:var(--rosa-med);transform:scale(1.03);box-shadow:0 6px 20px rgba(194,110,128,0.3)}
.btn:active{transform:scale(0.98)}
.btn-ghost{font-size:13px;font-weight:500;color:var(--rosa-acc);border-bottom:1px solid rgba(163,87,106,0.3);padding-bottom:2px;transition:color 0.25s,border-color 0.25s,transform 0.3s var(--ease-soft);display:inline-block}
.btn-ghost:hover{border-color:var(--rosa-acc);transform:translateX(3px)}

/* ===================== PROMESA ===================== */
.promesa{background:var(--white);text-align:center;padding:5rem 2rem;max-width:680px;margin:0 auto;position:relative}
.promesa-tag{font-family:var(--font-serif);font-size:14px;font-style:italic;color:var(--rosa-acc);margin-bottom:1rem;display:block}
.promesa h2{font-family:var(--font-serif);font-size:clamp(28px,3.5vw,40px);font-weight:400;line-height:1.3;color:var(--grafito);margin-bottom:1.5rem}
.promesa h2 em{font-style:italic;color:var(--rosa-acc)}
.promesa p{font-size:15.5px;color:var(--gris);line-height:1.9;font-weight:300}

/* ===================== SERVICIOS ===================== */
.servicios{background:var(--cream)}
.servicios-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:900px;margin:0 auto}
.servicio-card{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:1.5rem;
  padding:2rem;
  background:var(--white);
  border:0.5px solid rgba(194,110,128,0.1);
  border-radius:20px;
  transition:all 0.4s var(--ease-soft);
  position:relative;
}
.servicio-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 30px rgba(194,110,128,0.08);
  border-color:rgba(194,110,128,0.3);
}
.servicio-icon{width:48px;height:48px;background:var(--nude);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform 0.4s var(--ease-soft),background 0.3s}
.servicio-card:hover .servicio-icon{transform:scale(1.12);background:var(--warm)}
.servicio-icon svg{width:24px;height:24px;transition:transform 0.4s var(--ease-soft)}
.servicio-card:hover .servicio-icon svg{transform:scale(1.1)}
.servicio-name{font-family:var(--font-serif);font-size:17px;font-weight:400;color:var(--grafito);margin-bottom:0.3rem}
.servicio-desc{font-size:13.5px;color:var(--gris);line-height:1.6;font-weight:300}

/* ===================== SERVICIOS — CARD GRID ===================== */
.container-sv{
  max-width: 100% !important;  
}

.sv-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
  max-width: 1200px;
  margin: 0 auto;
}
.sv-card {
  background: var(--white);
  border: 0.5px solid rgba(200,160,160,0.20);
  border-radius: 16px;
  padding: 1.5rem;
  cursor: pointer;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  font-family: inherit;
  transition: box-shadow 0.3s var(--ease-soft), border-color 0.3s;
  width: 100%;
}
.sv-card:hover {
  box-shadow: 0 4px 20px rgba(194,110,128,0.10);
  border-color: #D4899A;
}
.sv-icon {
  width: 50px;
  height: 50px;
  background: var(--nude);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.6rem;
  flex-shrink: 0;
  transition: background 0.3s;
}
.sv-card:hover .sv-icon { background: var(--warm); }
.sv-icon-img {
  width: 81%;
  height: 81%;
  object-fit: contain;
  display: block;
}
/* Foto realista en tarjetas de servicio */
.sv-photo {
  width: 100%;
  aspect-ratio: 4/3;
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 0.85rem;
  flex-shrink: 0;
}
.sv-photo-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.6s var(--ease-soft);
}
.sv-card:hover .sv-photo-img {
  transform: scale(1.06);
}
.sv-name {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 400;
  color: #3A2E2C;
  line-height: 1.3;
}
.sv-price {
  font-family: var(--font-serif);
  font-size: 20px;
  font-weight: 400;
  color: #C26E80;
  line-height: 1.2;
}
.sv-price--tbd {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 300;
  color: var(--gris);
}
.sv-desc {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 300;
  color: #7A6562;
  line-height: 1.5;
}
.sv-link {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: #A3576A;
  margin-top: auto;
  padding-top: 0.75rem;
  display: block;
}

/* ===================== SERVICE MODAL ===================== */
.sv-overlay {
  position: fixed;
  inset: 0;
  background: rgba(58,46,44,0.55);
  z-index: 2000;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
}
.sv-overlay.active {
  opacity: 1;
  pointer-events: auto;
}
.sv-modal {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -46%);
  z-index: 2001;
  background: #fff;
  border-radius: 20px;
  padding: 2rem;
  width: 92%;
  max-width: 540px;
  max-height: 88vh;
  overflow-y: auto;
  box-shadow: 0 8px 40px rgba(58,46,44,0.15);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.sv-modal.active {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, -50%);
}
.sv-modal-inner { display: flex; flex-direction: column; }
.sv-modal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}
.sv-modal-title {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 400;
  color: #3A2E2C;
  line-height: 1.2;
}
.sv-modal-sub {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 300;
  color: #7A6562;
  margin-top: 0.3rem;
}
.sv-modal-close {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.2rem;
  color: var(--grafito);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  border-radius: 4px;
  transition: color 0.2s, background 0.2s;
}
.sv-modal-close:hover { color: var(--rosa); background: var(--nude); }
.sv-modal-divider {
  height: 0.5px;
  background: rgba(200,160,160,0.20);
  margin: 1rem 0;
}
.sv-modal-list { display: flex; flex-direction: column; }
.sv-modal-item {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
  padding: 0.9rem 0;
  border-bottom: 0.5px solid rgba(200,160,160,0.15);
}
.sv-modal-item:last-child { border-bottom: none; }
.sv-modal-item-left { flex: 1; min-width: 0; }
.sv-modal-item-name {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 400;
  color: #3A2E2C;
  margin-bottom: 0.15rem;
}
.sv-modal-item-desc {
  font-family: var(--font-body);
  font-size: 12.5px;
  font-weight: 300;
  color: #7A6562;
  line-height: 1.4;
}
.sv-modal-item-price {
  font-family: var(--font-serif);
  font-size: 18px;
  font-weight: 400;
  color: #C26E80;
  white-space: nowrap;
  flex-shrink: 0;
}
.sv-modal-empty {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 300;
  color: var(--gris);
  text-align: center;
  padding: 1.5rem 0;
  font-style: italic;
}
.sv-modal-foot { padding-top: 0.5rem; text-align: center; }
.sv-modal-wa {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #128C7E;
  color: white;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 500;
  padding: 0.8rem 1.6rem;
  border-radius: 100px;
  text-decoration: none;
  transition: background 0.25s, transform 0.3s var(--ease-soft), box-shadow 0.3s;
}
.sv-modal-wa:hover {
  background: #0e6b5c;
  transform: scale(1.03);
  box-shadow: 0 4px 16px rgba(18,140,126,0.25);
}

/* ===================== PROMOS ===================== */
.promos{background:var(--nude);padding:5rem 2rem}
.promos-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;max-width:800px;margin:0 auto;align-items:stretch}
.promo-card{background:var(--white);border-radius:20px;padding:2.5rem 2rem;text-align:center;transition:transform 0.5s var(--ease-soft),box-shadow 0.5s var(--ease-soft);display:flex;flex-direction:column;align-items:center}
.promo-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(180,120,130,0.12)}
.promo-card.featured{background:var(--grafito);color:white;position:relative}
.promo-card.featured:hover{box-shadow:0 12px 36px rgba(58,46,44,0.2)}
.promo-card.featured .promo-label{background:var(--rosa);color:white}
.promo-label{display:inline-block;font-size:10px;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;padding:0.35rem 0.8rem;border-radius:100px;color:var(--rosa-acc);background:var(--nude);margin-bottom:1rem}
.promo-card-title{font-family:var(--font-serif);font-size:20px;font-weight:400;margin-bottom:0.5rem}
.promo-card.featured .promo-card-title{color:white}
.promo-card.featured .promo-desc{color:rgba(255,255,255,0.7)}
.promo-desc{font-size:13px;color:var(--gris);line-height:1.6;font-weight:300;margin-bottom:1.25rem}
.promo-list{text-align:left;display:flex;flex-direction:column;gap:0.4rem;margin-bottom:1.5rem;width:100%}
.promo-item{display:flex;align-items:center;gap:0.5rem;font-size:13px;font-weight:300}
.promo-bottom{margin-top:auto;padding-top:1.5rem;text-align:center;width:100%}
.promo-card.featured .promo-item{color:rgba(255,255,255,0.8)}
.promo-dot{width:5px;height:5px;background:var(--blush);border-radius:50%;flex-shrink:0}
.promo-card.featured .promo-dot{background:var(--blush)}
.promo-price{font-family:var(--font-serif);font-size:44px;font-weight:400;color:var(--rosa);line-height:1;margin-bottom:0.25rem}
.promo-card.featured .promo-price{color:var(--blush)}
.promo-price-note{font-size:11px;color:var(--gris);font-weight:300}
.promo-card.featured .promo-price-note{color:rgba(255,255,255,0.6)}
.promo-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-top: 1rem;
  background: var(--rosa);
  color: white;
  border: none;
  padding: 0.65rem 1.4rem;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  border-radius: 100px;
  cursor: pointer;
  transition: transform 0.3s var(--ease-soft), box-shadow 0.3s var(--ease-soft), background 0.25s;
  text-decoration: none;
}
.promo-cta:hover{background:var(--rosa-med);transform:scale(1.06);box-shadow:0 4px 14px rgba(194,110,128,0.25)}
.promo-cta:active{transform:scale(0.97)}

/* ===== FEATURED CARD — rediseño ===== */
.promo-divider-line {
  width: 100%;
  height: 0.5px;
  background: rgba(255,255,255,0.12);
  margin: 1rem 0;
}
.promo-list--featured .promo-item {
  color: rgba(255,255,255,0.88);
  gap: 0.6rem;
}
.promo-check {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(232,180,190,0.20);
  border: 1px solid rgba(232,180,190,0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--blush);
}
.promo-price-block {
  margin-bottom: 0.5rem;
}
.promo-bottom {
  margin-top: auto;
  padding-top: 1.25rem;
  text-align: center;
  width: 100%;
  border-top: 0.5px solid rgba(255,255,255,0.10);
}

/* ===== PROMO CARD GRUPO — rediseño ===== */
.promo-card--group {
  background: linear-gradient(145deg, var(--nude) 0%, #fff 60%);
  border: 1px solid rgba(194,110,128,0.15);
  position: relative;
  overflow: hidden;
}
.promo-card--group::before {
  content: '';
  position: absolute;
  top: -40px;
  right: -40px;
  width: 130px;
  height: 130px;
  background: radial-gradient(circle, rgba(194,110,128,0.10) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.promo-discount-badge {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 2px;
  font-family: var(--font-serif);
  font-size: 72px;
  font-weight: 400;
  color: var(--rosa);
  line-height: 1;
  margin: 0.5rem 0 0.25rem;
}
.promo-discount-pct {
  font-size: 36px;
  color: var(--rosa-acc);
}
.promo-discount-off {
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.12em;
  color: var(--rosa-acc);
  align-self: flex-end;
  padding-bottom: 10px;
}
.promo-perks {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin: 1rem 0 1.5rem;
  width: 100%;
  text-align: left;
}
.promo-perk {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  font-size: 13px;
  font-weight: 300;
  color: var(--grafito);
}
.promo-perk-icon {
  width: 28px;
  height: 28px;
  background: rgba(194,110,128,0.10);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--rosa-acc);
}

/* ===================== GALERIA ===================== */
.galeria{background:var(--white);padding:5rem 2rem;overflow:hidden}
.galeria-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;max-width:1000px;margin:2rem auto 0}
.galeria-figure{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:4/5;cursor:default}
.galeria-figure img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease-soft);will-change:transform}
.galeria-figure:hover img{transform:scale(1.06)}
.galeria-figure::after{content:'';position:absolute;inset:0;background:linear-gradient(0deg,rgba(58,46,44,0.08) 0%,transparent 50%);pointer-events:none;transition:opacity 0.5s}
.galeria-figure:hover::after{opacity:0}
.galeria-label{position:absolute;bottom:1rem;left:1rem;font-size:10px;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;color:rgba(255,255,255,0.7);background:rgba(58,46,44,0.2);backdrop-filter:blur(4px);padding:0.3rem 0.65rem;border-radius:100px;pointer-events:none;z-index:2}
/* Slideshow — all slides stack absolutely inside the aspect-ratio figure */
.galeria-slideshow .galeria-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 0.6s ease}
.galeria-slideshow .galeria-slide.active{opacity:1}

/* ===================== REELS ===================== */
.reels-section {
  background: var(--cream);
  padding: 5rem 2rem;
}
.reels-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 3rem;
  max-width: 1000px;
  margin: 3rem auto 0;
}
.reel-item {
  flex: 0 1 400px;
  display: flex;
  justify-content: center;
  background: var(--white);
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 15px 45px rgba(58, 46, 44, 0.08);
  transition: transform 0.5s var(--ease-soft), box-shadow 0.5s var(--ease-soft);
  padding: 0;
}
.reel-item:hover {
  transform: translateY(-10px);
  box-shadow: 0 20px 55px rgba(194, 110, 128, 0.15);
}
.reel-item blockquote {
  margin: 0 !important;
  width: 100% !important;
  border-radius: 28px !important;
}
.reel-item iframe {
  border-radius: 0 !important;
  border: none !important;
  box-shadow: none !important;
}

/* ===================== PARAVOS ===================== */
.paravos{background:var(--white);padding:5rem 2rem}
.paravos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;max-width:900px;margin:2rem auto 0}
.paravos-card{padding:1.5rem 0;border-top:1.5px solid var(--blush);transition:border-color 0.3s,transform 0.3s var(--ease-soft)}
.paravos-card:hover{border-top-color:var(--rosa);transform:translateY(-2px)}
.paravos-num{font-family:var(--font-display);font-size:14px;font-weight:400;color:var(--rosa-acc);margin-bottom:0.75rem;letter-spacing:0.1em}
.paravos-title{font-family:var(--font-serif);font-size:17px;font-weight:400;color:var(--grafito);margin-bottom:0.5rem}
.paravos-desc{font-size:13.5px;color:var(--gris);line-height:1.7;font-weight:300}

/* ===================== EXPERIENCIA ===================== */
.experiencia{background:var(--grafito);text-align:center;padding:5rem 2rem;position:relative;overflow:hidden}
.experiencia h2{font-family:var(--font-serif);font-size:clamp(28px,3.5vw,38px);font-weight:400;color:white;line-height:1.4;max-width:520px;margin:0 auto 1rem}
.experiencia h2 em{font-style:italic;color:var(--blush)}
.experiencia p{font-size:14.5px;color:rgba(255,255,255,0.7);line-height:1.8;max-width:460px;margin:0 auto 2rem;font-weight:300}
.exp-tags{display:flex;flex-wrap:wrap;gap:0.6rem;justify-content:center;margin-bottom:2rem}
.exp-tag{border:0.5px solid rgba(255,255,255,0.2);padding:0.4rem 1rem;border-radius:100px;font-size:13px;color:rgba(255,255,255,0.7);font-weight:300;transition:background 0.3s,color 0.3s,border-color 0.3s;cursor:default}
.exp-tag:hover{background:rgba(255,255,255,0.08);color:white;border-color:rgba(255,255,255,0.35)}

/* ===================== UBICACION ===================== */
.ubicacion{background:var(--cream);padding:2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;border-top:0.5px solid rgba(200,160,160,0.2)}
.ubicacion-info{display:flex;flex-direction:column;gap:0.15rem}
.ubicacion-name{font-family:var(--font-serif);font-size:15px;font-weight:400;color:var(--grafito)}
.ubicacion-addr{font-size:13px;color:var(--gris);font-weight:300}
.ubicacion-addr-link {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  color: inherit;
  margin-top: 0.25rem;
}
.ubicacion-addr-link:hover .ubicacion-addr {
  color: var(--rosa-acc) !important;
  border-bottom-color: var(--rosa-acc) !important;
}
.ubicacion-social{font-size:12px;color:var(--rosa-acc);font-weight:500}
.ubicacion-social:hover{text-decoration:underline}

/* ===================== CTA ===================== */
.cta-wa{background:var(--white);text-align:center;padding:5rem 2rem;border-top:0.5px solid rgba(200,160,160,0.15)}
.cta-wa h2{font-family:var(--font-serif);font-size:32px;font-weight:400;color:var(--grafito);margin-bottom:0.5rem}
.cta-wa h2 em{font-style:italic}
.cta-wa p{font-size:14.5px;color:var(--gris);margin-bottom:1.5rem;font-weight:300;max-width:400px;margin-left:auto;margin-right:auto}
.btn-wa{background:var(--wa);color:white;border:none;padding:0.9rem 2rem;font-family:var(--font-body);font-size:14.5px;font-weight:500;border-radius:100px;cursor:pointer;display:inline-flex;align-items:center;gap:10px;transition:transform 0.3s var(--ease-soft),box-shadow 0.3s var(--ease-soft),background 0.25s;margin-bottom:1rem}
.btn-wa:hover{background:#0e6b5c;transform:scale(1.03);box-shadow:0 6px 20px rgba(18,140,126,0.25)}
.btn-wa:active{transform:scale(0.98)}
.btn-wa svg{transition:transform 0.3s var(--ease-soft)}
.btn-wa:hover svg{transform:rotate(-5deg) scale(1.1)}
.wa-msg{max-width:520px;margin:1.5rem auto 0;background:var(--cream);border-radius:12px;padding:1rem 1.25rem;text-align:left;border:0.5px solid rgba(200,160,160,0.2);font-size:13px;color:var(--gris);line-height:1.7;font-weight:300;transition:box-shadow 0.3s var(--ease-soft);position:relative}
.wa-msg:hover{box-shadow:0 4px 16px rgba(180,120,130,0.08)}
.wa-msg strong{color:var(--grafito);font-weight:500}
.wa-msg-label{font-size:10px;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;color:var(--rosa-acc);margin-bottom:0.5rem;display:block}

/* ===================== GOOGLE CALENDAR HERO BUTTON ===================== */
.btn-gcal-hero{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:0.5px solid rgba(194,110,128,0.2);
  border-radius:100px;
  padding:0.55rem 1.1rem 0.55rem 0.75rem;
  text-decoration:none;
  box-shadow:0 4px 20px rgba(58,46,44,0.12);
  transition:transform 0.35s var(--ease-soft),box-shadow 0.35s var(--ease-soft),background 0.25s;
  z-index:10;
  width: max-content;
}
.btn-gcal-hero:hover{
  transform:scale(1.04) translateY(-2px);
  box-shadow:0 8px 28px rgba(194,110,128,0.22);
  background:rgba(255,255,255,0.98);
}
@media (min-width: 861px) {
  .btn-gcal-hero {
    position: absolute;
    left: calc(50vw - 6rem + 1.5rem);
    top: 50%;
    transform: translateY(-50%);
  }
  .btn-gcal-hero:hover {
    transform: scale(1.04) translateY(-50%) translateY(-2px);
    box-shadow:0 8px 28px rgba(194,110,128,0.22);
    background:rgba(255,255,255,0.98);
  }
}
.btn-gcal-hero svg{flex-shrink:0}
.btn-gcal-hero-text{display:flex;flex-direction:column;line-height:1.1}
.btn-gcal-hero-label{font-size:9px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--rosa-acc)}
.btn-gcal-hero-sub{font-family:var(--font-serif);font-size:15px;font-weight:400;font-style:italic;color:var(--grafito)}

/* ===================== AGENDAR SECTION ===================== */
.agendar-section{
  background: #f8efec;
  padding: 5rem 2rem;
  position: relative;
  overflow: hidden;
  border-top: 0.5px solid rgba(200,160,160,0.15);
}
.agendar-inner{
  max-width: 1120px;  
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.agendar-card{
  background: #ffffff;
  border-radius: 24px;
  padding: 2.5rem 2rem 2rem;
  box-shadow: 
    0 15px 40px rgba(58, 46, 44, 0.04),
    0 1px 3px rgba(58, 46, 44, 0.02);
  border: 1px solid rgba(220, 205, 200, 0.4);
  text-align: center;
  transition: all 0.4s var(--ease-soft);
}
.agendar-card:hover{
  transform: translateY(-2px);
  box-shadow: 
    0 25px 55px rgba(58, 46, 44, 0.07),
    0 1px 4px rgba(58, 46, 44, 0.02);
}
.agendar-gcal-icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #f8efec;
  border-radius: 50%;
  width: 52px;
  height: 52px;
  margin-bottom: 0.75rem;
  transition: transform 0.4s var(--ease-soft);
}
.agendar-card:hover .agendar-gcal-icon{
  transform: scale(1.05);
}
.agendar-gcal-title{
  font-family: var(--font-serif);
  font-size: 20px;
  font-weight: 400;
  color: var(--grafito);
  margin-bottom: 0.25rem;
}
.agendar-gcal-desc{
  font-size: 13px;
  color: var(--gris);
  font-weight: 300;
  line-height: 1.6;
  margin-bottom: 2rem;
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
}
.agendar-gcal-wrapper {
  background: var(--white);
  border: 1px solid rgba(220, 205, 200, 0.45);
  border-radius: 16px;
  max-width: 100%;  margin: 0 auto;
  height: 600px;
  overflow: hidden;
  transition: border-color 0.3s, box-shadow 0.3s;
}
.agendar-gcal-wrapper iframe {
  width: 89.3%;
  height: 89.3%;
  transform: scale(1.12);
  transform-origin: top left;
  border: none;
  display: block;
}
.agendar-gcal-wrapper:hover {
  border-color: rgba(194, 110, 128, 0.25);
  box-shadow: 0 4px 15px rgba(194, 110, 128, 0.04);
}
.agendar-secure {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-top: 1.5rem;
  color: var(--gris);
  font-size: 11px;
  font-weight: 400;
  opacity: 0.85;
}
.agendar-secure svg {
  color: var(--rosa-acc);
  flex-shrink: 0;
}

/* ===================== FOOTER ===================== */
footer{background:var(--cream);text-align:center;padding:1.5rem 2rem;border-top:0.5px solid rgba(200,160,160,0.1)}
.footer-logo{display:flex;justify-content:center;margin-bottom:0.5rem}
.footer-logo img{height:36px;width:auto;opacity:0.8}
.footer-copy{font-size:11px;color:var(--gris);margin-top:0.25rem;font-weight:300}

/* ===================== DECORATIVE ===================== */
.promesa-divider{width:40px;height:1px;background:var(--blush);margin:1.5rem auto;transition:width 1s var(--ease-soft)}
.promesa-divider.visible{width:80px}
.wave-divider{width:100%;height:40px;display:block;fill:var(--cream);margin-top:-1px}

/* ===================== RESPONSIVE ===================== */
@media(max-width:860px){
  .nav-links {
    position: fixed;
    top: 0;
    right: 0;
  display: none;    
  width: 280px;
    opacity: 1;
    height: 100vh;
    background: var(--white);
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 1.5rem;
  transition: opacity 0.4s var(--ease-soft);    box-shadow: -10px 0 30px rgba(58, 46, 44, 0.05);
    z-index: 1000;
    padding: 2rem;
  }
  .nav-links.active {
  display: flex;
  opacity: 1;  }
  .nav-mobile-toggle {
    display: flex;
  }
  .nav-mobile-toggle.active .bar:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
  }
  .nav-mobile-toggle.active .bar:nth-child(2) {
    opacity: 0;
  }
  .nav-mobile-toggle.active .bar:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
  }
  .nav-actions .nav-cta {
    display: none;
  }
  .nav-links .nav-cta {
    display: inline-block;
    width: 100%;
    text-align: center;
    margin-top: 1rem;
  }
  .agendar-card {
    padding: 2.25rem 1.25rem 1.5rem;
  }
  .agendar-gcal-wrapper {
    height: 580px;
  }
  .agendar-gcal-wrapper iframe {
    width: 100%;
    height: 100%;
    transform: none;
  }
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-left{padding:4rem 2rem 7rem}
  .hero-left h1{font-size:clamp(30px,5vw,40px)}
  .hero-right{min-height:340px;order:-1}
  .hero-image{object-position:center 20%}
  .hero-image-label{display:none}
  .section{padding:3.5rem 1.5rem}
  .sv-grid{grid-template-columns:repeat(2,1fr)}
  .servicios-grid,.promos-grid,.paravos-grid,.reels-grid{grid-template-columns:1fr}
  .galeria-grid{grid-template-columns:repeat(2,1fr)}
  .promos-grid,.galeria-grid,.reels-grid{max-width:100%}
  .galeria-figure{aspect-ratio:4/3}
  .section-title{font-size:28px}
  .ubicacion{flex-direction:column;text-align:center;gap:0.5rem}
}
@media(max-width:480px){
  .sv-grid{grid-template-columns:1fr}
  .galeria-grid{grid-template-columns:1fr}
  nav{padding:1rem}
  .hero-left{padding:2.5rem 1rem}
  .hero-right{min-height:260px}
  .servicio-card{padding:1.25rem 0}
  .promos,.paravos,.galeria,.experiencia,.cta-wa{padding:3rem 1rem}
  .hero-scroll{display:none}
  .container{padding:0 1rem}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important}
  .reveal,.hero-entrance{opacity:1;transform:none}
}
