:root{
  --sage:#87AE73;
  --sage-deep:#5C7A4F;
  --sage-soft:#D4E0C7;
  --sage-wash:#E7EEDD;
  --ink:#1F2419;
  --ink-2:#4A5340;
  --cream:#F7F4EC;
  --cream-2:#EDE8DA;
  --cream-3:#E2DAC5;
  --white:#FFFFFF;
  --gold:#C9A96E;
  --orange:#FE5F03;
  --orange-deep:#D94F00;
  --orange-soft:#FFE2CF;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* NAV */
.nav{
  position:sticky;top:0;z-index:50;
  background:var(--cream);
  border-bottom:1px solid rgba(31,36,25,0.08);
}
.nav-inner{
  max-width:1240px;margin:0 auto;padding:18px 28px;
  display:flex;align-items:center;justify-content:space-between;
}
.logo{font-size:20px;font-weight:700;letter-spacing:-0.02em;color:var(--ink);display:flex;align-items:center}
.logo em{font-style:normal;color:var(--sage-deep);font-weight:500}
.logo img{height:42px;width:auto;display:block}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--ink-2);transition:color .2s;position:relative}
.nav-links a:hover{color:var(--sage-deep)}
.nav-links a.active{color:var(--sage-deep);font-weight:600}
.nav-links a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-22px;
  height:2px;background:var(--orange);
}
.nav-cta{
  padding:11px 22px;background:var(--ink);color:var(--cream);
  border-radius:999px;font-weight:600;font-size:14px;
  transition:background .2s,transform .2s;
}
.nav-cta:hover{background:var(--orange);transform:translateY(-1px)}
.burger{display:none}

/* mobile drawer */
.mobile-drawer{
  position:fixed;inset:0;
  background:var(--cream);z-index:100;
  padding:28px;display:flex;flex-direction:column;
  opacity:0;visibility:hidden;transform:translateX(100%);
  transition:opacity .35s ease,transform .4s cubic-bezier(.22,1,.36,1),visibility .4s;
}
.mobile-drawer.open{opacity:1;visibility:visible;transform:translateX(0)}
.mobile-drawer-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:60px}
.mobile-links{display:flex;flex-direction:column;gap:30px}
.mobile-links a{
  font-size:28px;font-weight:600;color:var(--ink);letter-spacing:-0.02em;
  opacity:0;transform:translateY(14px);
}
.mobile-drawer.open .mobile-links a{animation:drawer-link-in .5s cubic-bezier(.22,1,.36,1) forwards}
.mobile-drawer.open .mobile-links a:nth-child(1){animation-delay:.12s}
.mobile-drawer.open .mobile-links a:nth-child(2){animation-delay:.18s}
.mobile-drawer.open .mobile-links a:nth-child(3){animation-delay:.24s}
.mobile-drawer.open .mobile-links a:nth-child(4){animation-delay:.30s}
.mobile-drawer.open .mobile-links a:nth-child(5){animation-delay:.36s}
.mobile-drawer.open .nav-cta{animation:drawer-link-in .5s cubic-bezier(.22,1,.36,1) .42s forwards;opacity:0}
@keyframes drawer-link-in{to{opacity:1;transform:translateY(0)}}
.mobile-links a.active{color:var(--sage-deep)}
.mobile-drawer .nav-cta{margin-top:auto;text-align:center;padding:18px 28px;font-size:15px}

/* HERO HOME */
.hero{max-width:1240px;margin:0 auto;padding:80px 28px 100px}
.hero-grid{display:grid;grid-template-columns:1.05fr 0.95fr;gap:80px;align-items:center}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px;background:var(--orange-soft);
  border-radius:999px;font-size:12px;font-weight:600;
  color:var(--orange-deep);letter-spacing:0.1em;text-transform:uppercase;
  margin-bottom:30px;
}
.hero-eyebrow::before{
  content:"";display:block;width:6px;height:6px;
  background:var(--orange);border-radius:50%;
}
.hero h1{
  font-size:clamp(44px,6.5vw,84px);font-weight:300;
  line-height:0.98;letter-spacing:-0.035em;margin-bottom:30px;
}
.hero h1 em{font-style:italic;font-weight:500;color:var(--sage-deep)}
.hero p.lead{font-size:18px;color:var(--ink-2);max-width:480px;margin-bottom:42px;line-height:1.6}
.hero-cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn-primary{
  display:inline-flex;align-items:center;gap:12px;
  padding:17px 30px;background:var(--ink);color:var(--cream);
  border-radius:999px;font-weight:600;font-size:15px;
  transition:transform .2s,background .2s;
}
.btn-primary:hover{background:var(--orange);transform:translateY(-2px)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  padding:17px 22px;color:var(--ink);font-weight:500;font-size:15px;
  transition:color .2s;
}
.btn-ghost:hover{color:var(--sage-deep)}
.opiniones-cta{display:flex;justify-content:center;margin-top:40px}
.btn-google{
  border:1px solid rgba(31,36,25,0.15);
  border-radius:999px;
  background:var(--cream);
  transition:color .2s,border-color .2s,transform .2s;
}
.btn-google:hover{border-color:var(--sage-deep);transform:translateY(-2px)}
.hero-img-wrap{position:relative}
.hero-img{
  position:relative;
  border-radius:220px 220px 26px 26px;
  overflow:hidden;
  aspect-ratio:4/5;
  box-shadow:0 40px 70px -35px rgba(31,36,25,0.45);
  background:var(--cream-3);
}
.hero-img img{width:100%;height:100%;object-fit:cover}
.hero-badge{
  position:absolute;bottom:28px;left:-20px;
  background:var(--cream);padding:16px 22px;
  border-radius:16px;display:flex;align-items:center;gap:14px;
  box-shadow:0 16px 36px rgba(31,36,25,0.18);
  max-width:230px;
}
.hero-badge-num{font-size:30px;font-weight:700;color:var(--ink);line-height:1;letter-spacing:-0.03em}
.hero-badge-txt{font-size:12px;color:var(--ink-2);line-height:1.3;font-weight:500}
.hero-dot{
  position:absolute;top:-16px;right:-10px;
  width:96px;height:96px;border-radius:50%;
  background:var(--sage-soft);z-index:-1;
}

/* CINTA FRASE (divisoria) */
.cinta-frase{background:var(--sage-deep);color:var(--cream)}
.cinta-frase-inner{
  max-width:1000px;margin:0 auto;padding:66px 28px;
  text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px;
}
.cinta-quote{color:var(--orange)}
.cinta-frase blockquote{
  font-size:clamp(21px,2.9vw,33px);font-weight:300;line-height:1.32;
  letter-spacing:-0.02em;font-style:italic;max-width:880px;
}
.cinta-frase cite{
  font-style:normal;font-size:13px;font-weight:700;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--sage-soft);
}

/* HERO SECUNDARIO (servicios, contacto) */
.page-hero{
  background:var(--cream-2);
  border-bottom:1px solid rgba(31,36,25,0.06);
}
.page-hero-inner{
  max-width:1240px;margin:0 auto;padding:90px 28px 70px;
  text-align:center;
}
.page-hero h1{
  font-size:clamp(40px,5.5vw,68px);font-weight:300;
  line-height:1.02;letter-spacing:-0.03em;margin:18px auto 22px;
  max-width:820px;
}
.page-hero h1 em{font-style:italic;font-weight:500;color:var(--sage-deep)}
.page-hero p{
  font-size:17px;color:var(--ink-2);max-width:580px;
  margin:0 auto;line-height:1.65;
}

/* HERO SECUNDARIO SPLIT (servicios con imagen) */
.page-hero-split{
  text-align:left;padding:80px 28px 80px;
}
.page-hero-split .page-hero-grid{
  display:grid;grid-template-columns:1fr 0.85fr;
  gap:70px;align-items:center;
}
.page-hero-split h1{margin:14px 0 22px;max-width:none}
.page-hero-split p{margin:0;max-width:520px}
.page-hero-img{
  position:relative;
  border-radius:24px;overflow:hidden;
  aspect-ratio:4/5;
  background:var(--cream-3);
  box-shadow:0 30px 60px -28px rgba(31,36,25,0.4);
}
.page-hero-img img{width:100%;height:100%;object-fit:cover}
.page-hero-img::before{
  content:"";position:absolute;
  top:-18px;left:-18px;
  width:90px;height:90px;border-radius:50%;
  background:var(--sage-soft);z-index:-1;
}

/* GENERAL SECTION */
.section{max-width:1240px;margin:0 auto;padding:110px 28px}
.section-label{
  display:block;font-size:12px;font-weight:700;
  color:var(--orange);letter-spacing:0.14em;text-transform:uppercase;
  margin-bottom:22px;
}
.section h2{
  font-size:clamp(36px,4.8vw,58px);font-weight:300;letter-spacing:-0.025em;
  max-width:820px;line-height:1.04;color:var(--ink);
}
.section h2 em{font-style:italic;color:var(--sage-deep);font-weight:500}

/* NOSOTROS */
.nosotros-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;margin-top:60px;
}
.nosotros-copy p{font-size:16.5px;color:var(--ink-2);line-height:1.75;margin-bottom:18px}
.nosotros-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:30px 40px;margin-top:44px;
  padding-top:34px;border-top:1px solid rgba(31,36,25,0.12);
}
.stat-num{font-size:42px;font-weight:300;color:var(--ink);line-height:1;letter-spacing:-0.035em}
.stat-num em{font-style:normal;color:var(--orange);font-weight:400}
.stat-lbl{font-size:13.5px;color:var(--ink-2);margin-top:8px;line-height:1.4}
.nosotros-imgs{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.nosotros-imgs .img-a{aspect-ratio:4/5;border-radius:16px;overflow:hidden;margin-top:48px;background:var(--cream-3)}
.nosotros-imgs .img-b{aspect-ratio:4/5;border-radius:16px;overflow:hidden;background:var(--cream-3)}
.nosotros-imgs img{width:100%;height:100%;object-fit:cover}

/* SERVICIOS / DISCIPLINAS */
.servicios{background:var(--cream-2)}
.servicios-inner{max-width:1240px;margin:0 auto;padding:120px 28px}
.servicios-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px}
.servicios-head p{max-width:380px;color:var(--ink-2);font-size:16px;line-height:1.6}
.servicios-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:60px}
.servicio{
  background:var(--cream);
  border-radius:20px;position:relative;
  border:1px solid rgba(31,36,25,0.06);
  transition:transform .25s,box-shadow .25s,border-color .25s;
  overflow:hidden;cursor:pointer;
  display:flex;flex-direction:column;
}
.servicio:hover{transform:translateY(-4px);box-shadow:0 20px 44px -20px rgba(31,36,25,0.22);border-color:rgba(254,95,3,0.35)}
.servicio:focus-visible{outline:2px solid var(--orange);outline-offset:2px}
.servicio-img{aspect-ratio:4/3;overflow:hidden;background:var(--cream-3)}
.servicio-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.servicio:hover .servicio-img img{transform:scale(1.05)}
.servicio-body{padding:26px 28px 30px;display:flex;flex-direction:column;flex:1}
.servicio-num{
  font-size:11.5px;font-weight:700;letter-spacing:0.12em;
  color:var(--orange);margin-bottom:14px;display:block;
}
.servicio h3{
  font-size:20px;font-weight:600;margin-bottom:10px;line-height:1.2;
  letter-spacing:-0.01em;
}
.servicio p{font-size:14.5px;color:var(--ink-2);line-height:1.55;margin-bottom:18px}
.servicio-mas{
  margin-top:auto;display:inline-flex;align-items:center;gap:7px;
  font-size:13.5px;font-weight:700;color:var(--orange-deep);
  letter-spacing:0.01em;transition:gap .2s;
}
.servicio:hover .servicio-mas{gap:11px}

/* MODAL DISCIPLINA */
.disc-modal{
  position:fixed;inset:0;z-index:200;display:none;
  align-items:center;justify-content:center;padding:32px 20px;
}
.disc-modal.open{display:flex}
.disc-modal-overlay{position:absolute;inset:0;background:rgba(15,18,12,0.6);backdrop-filter:blur(3px);animation:lb-in .2s ease}
.disc-modal-card{
  position:relative;z-index:1;background:var(--cream);
  border-radius:24px;overflow:hidden;
  max-width:920px;width:100%;max-height:90vh;
  display:grid;grid-template-columns:1fr 1fr;
  box-shadow:0 40px 90px -30px rgba(0,0,0,0.55);
  animation:disc-pop .3s cubic-bezier(.22,1,.36,1);
}
@keyframes disc-pop{from{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:none}}
.disc-modal-media{background:var(--cream-3);overflow:hidden}
.disc-modal-media img{width:100%;height:100%;object-fit:cover;display:block}
.disc-modal-content{padding:42px 40px;overflow-y:auto;display:flex;flex-direction:column}
.disc-modal-eyebrow{
  font-size:11.5px;font-weight:700;color:var(--orange);
  letter-spacing:0.14em;text-transform:uppercase;margin-bottom:12px;
}
.disc-modal-content h2{font-size:28px;font-weight:600;letter-spacing:-0.02em;line-height:1.15;margin-bottom:18px}
.disc-modal-text p{font-size:15px;color:var(--ink-2);line-height:1.7;margin-bottom:14px}
.disc-modal-cta{margin-top:18px;align-self:flex-start}
.disc-modal-close{
  position:absolute;top:16px;right:16px;z-index:2;
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,0.9);color:var(--ink);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 14px rgba(0,0,0,0.18);transition:transform .2s,background .2s;
}
.disc-modal-close:hover{transform:scale(1.08);background:#fff}

/* MODAL RESERVAS (BoxMagic) */
.reserva-modal{
  position:fixed;inset:0;z-index:260;display:none;
  align-items:center;justify-content:center;padding:28px 18px;
}
.reserva-modal.open{display:flex}
.reserva-modal-overlay{position:absolute;inset:0;background:rgba(15,18,12,0.6);backdrop-filter:blur(3px);animation:lb-in .2s ease}
.reserva-modal-card{
  position:relative;z-index:1;background:var(--cream);
  border-radius:24px;overflow:hidden;
  width:100%;max-width:560px;max-height:92vh;
  display:flex;flex-direction:column;
  box-shadow:0 40px 90px -30px rgba(0,0,0,0.55);
  animation:disc-pop .3s cubic-bezier(.22,1,.36,1);
}
.reserva-modal-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 14px 16px 22px;border-bottom:1px solid var(--cream-3);
}
.reserva-modal-title{font-size:16px;font-weight:700;color:var(--ink);letter-spacing:-0.01em}
.reserva-modal-close{
  width:38px;height:38px;border-radius:50%;flex-shrink:0;
  background:var(--cream-3);color:var(--ink);
  display:flex;align-items:center;justify-content:center;
  transition:transform .2s,background .2s,color .2s;
}
.reserva-modal-close:hover{transform:scale(1.08);background:var(--orange);color:#fff}
.reserva-modal-body{flex:1;overflow:hidden;background:#fff;min-height:0}
.reserva-modal-body iframe{display:block;width:100%;height:min(900px,78vh);border:0}
@media (max-width:600px){
  .reserva-modal{padding:0}
  .reserva-modal-card{max-width:none;height:100%;max-height:100%;border-radius:0}
  .reserva-modal-body iframe{height:100%}
}

/* GALERIA UNIFORME + LIGHTBOX */
.galeria-section{background:var(--cream)}
.galeria-inner{max-width:1240px;margin:0 auto;padding:120px 28px}
.galeria-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;margin-bottom:50px}
.galeria-head p{max-width:380px;color:var(--ink-2);font-size:16px;line-height:1.6}
.galeria-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.g-item{
  aspect-ratio:4/5;
  border-radius:16px;overflow:hidden;
  background:var(--cream-3);position:relative;
  cursor:zoom-in;
  transition:transform .25s;
}
.g-item:hover{transform:translateY(-3px)}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.g-item:hover img{transform:scale(1.06)}
.g-item::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,0) 60%,rgba(0,0,0,0.18) 100%);
  pointer-events:none;
  opacity:0;transition:opacity .25s;
}
.g-item:hover::after{opacity:1}
.g-zoom{
  position:absolute;top:14px;right:14px;
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,0.92);
  display:flex;align-items:center;justify-content:center;
  color:var(--ink);
  opacity:0;transform:translateY(-4px);
  transition:opacity .25s,transform .25s;
}
.g-item:hover .g-zoom{opacity:1;transform:translateY(0)}

/* LIGHTBOX */
.lightbox{
  position:fixed;inset:0;z-index:200;
  background:rgba(15,18,12,0.96);
  display:none;align-items:center;justify-content:center;
  padding:40px 80px;
  animation:lb-in .2s ease;
}
.lightbox.open{display:flex}
@keyframes lb-in{from{opacity:0}to{opacity:1}}
.lightbox-img-wrap{
  position:relative;max-width:100%;max-height:100%;
  display:flex;align-items:center;justify-content:center;
}
.lightbox-img{
  max-width:100%;max-height:88vh;object-fit:contain;
  border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,0.5);
  background:#0f120c;
}
.lightbox-caption{
  position:absolute;left:0;right:0;bottom:-36px;
  text-align:center;color:rgba(247,244,236,0.7);
  font-size:13px;font-weight:500;letter-spacing:0.01em;
}
.lb-btn{
  position:absolute;
  background:rgba(255,255,255,0.08);color:#fff;
  border:1px solid rgba(255,255,255,0.12);
  width:48px;height:48px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:background .2s,transform .2s,border-color .2s;
}
.lb-btn:hover{background:rgba(255,255,255,0.18);border-color:rgba(255,255,255,0.25);transform:scale(1.06)}
.lb-close{top:22px;right:22px}
.lb-prev{left:22px;top:50%;transform:translateY(-50%)}
.lb-next{right:22px;top:50%;transform:translateY(-50%)}
.lb-prev:hover,.lb-next:hover{transform:translateY(-50%) scale(1.06)}
.lb-counter{
  position:absolute;top:32px;left:50%;transform:translateX(-50%);
  color:rgba(247,244,236,0.7);font-size:13px;font-weight:500;
  letter-spacing:0.06em;
}

/* POR QUÉ */
.porque-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:60px}
.porque-item{padding:36px 0 0;border-top:1px solid rgba(31,36,25,0.18)}
.porque-icon{
  width:54px;height:54px;background:var(--orange-soft);
  border-radius:14px;display:flex;align-items:center;justify-content:center;
  color:var(--orange-deep);margin-bottom:28px;
}
.porque-item h3{font-size:18.5px;font-weight:600;margin-bottom:10px;letter-spacing:-0.01em}
.porque-item p{font-size:14.5px;color:var(--ink-2);line-height:1.55}

/* OPINIONES */
.opiniones{background:var(--ink);color:var(--cream)}
.opiniones-inner{max-width:1240px;margin:0 auto;padding:120px 28px}
.opiniones .section-label{color:var(--orange)}
.opiniones h2{color:var(--cream)}
.opiniones h2 em{color:var(--sage-soft)}
.opiniones-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:60px}
.opinion{
  background:rgba(255,255,255,0.04);padding:34px 30px;
  border-radius:18px;border:1px solid rgba(255,255,255,0.08);
  display:flex;flex-direction:column;gap:18px;
}
.stars{display:flex;gap:3px;color:#F5C45C}
.opinion p{font-size:15.5px;color:rgba(247,244,236,0.9);line-height:1.7;flex:1}
.opinion-foot{
  display:flex;align-items:center;gap:12px;
  padding-top:20px;border-top:1px solid rgba(255,255,255,0.1);
}
.opinion-name{font-size:14.5px;font-weight:600;color:var(--cream);display:flex;align-items:center;gap:8px}

/* PAGOS */
.pagos-inner{max-width:1240px;margin:0 auto;padding:90px 28px}
.pagos-head{text-align:center;margin-bottom:40px}
.pagos-head span{
  display:inline-block;font-size:12px;font-weight:700;
  color:var(--sage-deep);letter-spacing:0.14em;text-transform:uppercase;margin-bottom:12px;
}
.pagos-head h3{font-size:30px;font-weight:300;color:var(--ink);letter-spacing:-0.02em}
.pagos-list{display:flex;justify-content:center;align-items:center;gap:14px;flex-wrap:wrap}
.pago{
  padding:18px 26px;border:1px solid rgba(31,36,25,0.12);
  border-radius:14px;display:flex;align-items:center;gap:12px;
  font-weight:500;font-size:15px;background:var(--white);
}
.pago svg{color:var(--sage-deep);flex-shrink:0}

/* UBICACIÓN */
.ubicacion{background:var(--cream-2)}
.ubicacion-inner{max-width:1240px;margin:0 auto;padding:120px 28px}
.ubicacion-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:stretch;margin-top:50px}
.mapa{border-radius:20px;overflow:hidden;aspect-ratio:4/3;box-shadow:0 24px 44px -24px rgba(31,36,25,0.25);background:var(--cream-3)}
.mapa iframe{width:100%;height:100%;border:0;display:block}
.ubicacion-data h3{font-size:22px;font-weight:600;margin-bottom:8px;letter-spacing:-0.01em}
.ubicacion-data > p{color:var(--ink-2);font-size:15.5px;margin-bottom:18px;line-height:1.6}
.data-row{display:flex;gap:18px;padding:22px 0;border-bottom:1px solid rgba(31,36,25,0.1)}
.data-row:last-child{border-bottom:none}
.data-icon{flex-shrink:0;width:44px;height:44px;background:var(--orange-soft);border-radius:11px;display:flex;align-items:center;justify-content:center;color:var(--orange-deep)}
.data-label{font-size:11.5px;font-weight:700;color:var(--sage-deep);letter-spacing:0.12em;text-transform:uppercase;margin-bottom:4px}
.data-value{font-size:15.5px;color:var(--ink);font-weight:500;line-height:1.45}
.data-value a:hover{color:var(--sage-deep)}

/* CONTACTO PAGE */
.contacto-page{max-width:1100px;margin:0 auto;padding:90px 28px 110px}
.contacto-grid{display:grid;grid-template-columns:1.05fr 0.95fr;gap:60px;align-items:start}
.contacto-single{max-width:1100px;margin:0 auto}
.contacto-head{text-align:center;max-width:680px;margin:0 auto 56px}
.contacto-head h2{
  font-size:clamp(30px,3.8vw,44px);font-weight:300;
  letter-spacing:-0.025em;margin-bottom:14px;line-height:1.08;
}
.contacto-head h2 em{font-style:italic;color:var(--sage-deep);font-weight:500}
.contacto-head p{color:var(--ink-2);font-size:16.5px;line-height:1.65}

.contacto-cards-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
}
.contacto-card{
  background:var(--cream-2);
  border:1px solid rgba(31,36,25,0.06);
  border-radius:20px;padding:32px 28px;
  display:flex;flex-direction:column;
  transition:transform .25s,box-shadow .25s,border-color .25s;
  min-height:200px;
}
.contacto-card:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 38px -22px rgba(31,36,25,0.22);
  border-color:rgba(135,174,115,0.4);
}
.contacto-card-icon{
  width:48px;height:48px;background:var(--sage-soft);
  border-radius:13px;display:flex;align-items:center;justify-content:center;
  color:var(--sage-deep);margin-bottom:22px;
}
.contacto-card-label{
  font-size:11.5px;font-weight:700;color:var(--sage-deep);
  letter-spacing:0.12em;text-transform:uppercase;margin-bottom:6px;
}
.contacto-card-value{
  font-size:16.5px;color:var(--ink);font-weight:600;line-height:1.35;
}
.contacto-card-value a{
  color:inherit;border-bottom:1px solid transparent;
  transition:border-color .2s,color .2s;
}
.contacto-card-value a:hover{border-bottom-color:var(--sage-deep);color:var(--sage-deep)}
.contacto-card-sub{
  font-size:13.5px;color:var(--ink-2);margin-top:auto;padding-top:10px;
  line-height:1.45;font-weight:400;
}
.contacto-info h2{
  font-size:clamp(30px,3.5vw,40px);font-weight:300;letter-spacing:-0.02em;
  margin-bottom:14px;line-height:1.1;
}
.contacto-info h2 em{font-style:italic;color:var(--sage-deep);font-weight:500}
.contacto-info > p{color:var(--ink-2);font-size:16px;line-height:1.65;margin-bottom:36px}
.contacto-data-row{
  display:flex;gap:16px;padding:20px 0;
  border-bottom:1px solid rgba(31,36,25,0.1);
}
.contacto-data-row:last-child{border-bottom:none}
.contacto-data-icon{
  flex-shrink:0;width:46px;height:46px;background:var(--sage-soft);
  border-radius:12px;display:flex;align-items:center;justify-content:center;
  color:var(--sage-deep);
}
.contacto-data-label{font-size:11.5px;font-weight:700;color:var(--sage-deep);letter-spacing:0.12em;text-transform:uppercase;margin-bottom:4px}
.contacto-data-value{font-size:16px;color:var(--ink);font-weight:500;line-height:1.45}
.contacto-data-value a{color:inherit;border-bottom:1px solid transparent;transition:border-color .2s}
.contacto-data-value a:hover{border-bottom-color:var(--sage-deep);color:var(--sage-deep)}
.contacto-data-sub{font-size:13.5px;color:var(--ink-2);margin-top:3px;font-weight:400}

.form-card{
  background:var(--cream-2);
  border:1px solid rgba(31,36,25,0.06);
  border-radius:22px;padding:38px 34px;
}
.form-card h3{font-size:22px;font-weight:600;margin-bottom:8px;letter-spacing:-0.01em}
.form-card > p{font-size:14.5px;color:var(--ink-2);margin-bottom:26px}
.form-row{margin-bottom:18px}
.form-label{
  display:block;font-size:12px;font-weight:600;color:var(--ink-2);
  letter-spacing:0.06em;text-transform:uppercase;margin-bottom:8px;
}
.form-input,.form-textarea,.form-select{
  width:100%;padding:14px 16px;
  border:1px solid rgba(31,36,25,0.14);
  border-radius:12px;background:var(--white);
  font-family:inherit;font-size:15px;color:var(--ink);
  transition:border-color .2s,box-shadow .2s;
}
.form-input:focus,.form-textarea:focus,.form-select:focus{
  outline:none;border-color:var(--sage-deep);
  box-shadow:0 0 0 3px rgba(135,174,115,0.18);
}
.form-textarea{resize:vertical;min-height:120px}
.form-submit{
  width:100%;padding:16px 28px;background:var(--ink);color:var(--cream);
  border-radius:999px;font-weight:600;font-size:15px;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  transition:background .2s,transform .2s;
  cursor:pointer;
}
.form-submit:hover{background:var(--sage-deep);transform:translateY(-1px)}
.form-note{
  font-size:12.5px;color:var(--ink-2);text-align:center;
  margin-top:14px;line-height:1.5;
}

/* CTA grande para servicios.html */
.cta-banner{background:var(--ink);color:var(--cream)}
.cta-banner-inner{max-width:900px;margin:0 auto;padding:110px 28px;text-align:center}
.cta-banner h2{
  font-size:clamp(34px,4.5vw,50px);font-weight:300;
  letter-spacing:-0.025em;line-height:1.05;margin-bottom:20px;
  color:var(--cream);
}
.cta-banner h2 em{font-style:italic;color:var(--sage-soft);font-weight:500}
.cta-banner p{
  font-size:17px;color:rgba(247,244,236,0.78);
  max-width:560px;margin:0 auto 36px;line-height:1.6;
}
.cta-banner-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-banner-btns a{
  display:inline-flex;align-items:center;gap:10px;
  padding:17px 28px;border-radius:999px;font-weight:600;font-size:15px;
  transition:transform .2s,background .2s;
}
.cta-wa-light{background:var(--cream);color:var(--ink)}
.cta-wa-light:hover{transform:translateY(-2px);background:var(--white)}
.cta-ghost-light{
  color:var(--cream);border:1px solid rgba(247,244,236,0.25);
}
.cta-ghost-light:hover{background:rgba(247,244,236,0.08);transform:translateY(-2px)}

/* FOOTER */
footer{background:var(--ink);color:rgba(247,244,236,0.7);padding:64px 28px 34px}
.foot-inner{max-width:1240px;margin:0 auto}
.foot-top{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:28px;padding-bottom:38px;border-bottom:1px solid rgba(255,255,255,0.08)}
.foot-logo{font-size:24px;font-weight:700;color:var(--cream);letter-spacing:-0.02em}
.foot-logo em{font-style:normal;color:var(--sage);font-weight:500}
.foot-logo img{height:54px;width:auto;display:block}
.foot-social{display:flex;gap:12px}
.foot-social a{
  width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,0.06);
  display:flex;align-items:center;justify-content:center;
  color:var(--cream);transition:background .2s,transform .2s;
}
.foot-social a:hover{background:var(--sage-deep);transform:translateY(-2px)}
.foot-bot{padding-top:30px;font-size:13px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}
.foot-bot a{color:inherit;text-decoration:none}
.foot-bot a:hover{color:var(--sage-soft)}

/* WA FLOTANTE */
.wa-float{
  position:fixed;bottom:24px;right:24px;z-index:40;
  height:60px;padding:0 20px;background:#25D366;
  border-radius:30px;
  display:flex;align-items:center;justify-content:center;gap:11px;
  color:white;
  box-shadow:0 12px 34px rgba(37,211,102,0.45);
  transition:transform .2s;
}
.wa-float:hover{transform:scale(1.04)}
.wa-float-label{font-size:14.5px;font-weight:600;white-space:nowrap;letter-spacing:-0.01em}
.wa-float svg{flex-shrink:0}
@media (max-width:600px){
  .wa-float{width:62px;height:62px;padding:0;border-radius:50%}
  .wa-float-label{display:none}
}

/* FADE IN */
.fade-up{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* RESPONSIVE */
@media (max-width:960px){
  .nav-links,.nav-inner > .nav-cta{display:none}
  .burger{display:flex;width:44px;height:44px;align-items:center;justify-content:center;color:var(--ink)}
  .hero{padding:50px 20px 70px}
  .hero-grid{grid-template-columns:1fr;gap:50px}
  .hero-img{aspect-ratio:5/6;border-radius:140px 140px 20px 20px}
  .hero-badge{left:auto;right:20px;bottom:20px}
  .page-hero-inner{padding:60px 20px 50px}
  .page-hero-split{padding:60px 20px 60px}
  .page-hero-split .page-hero-grid{grid-template-columns:1fr;gap:36px}
  .page-hero-img{aspect-ratio:5/6;max-width:480px;margin:0 auto}
  .section{padding:80px 20px}
  .nosotros-grid{grid-template-columns:1fr;gap:50px}
  .nosotros-imgs .img-a{margin-top:0}
  .nosotros-stats{grid-template-columns:1fr 1fr;gap:24px}
  .servicios-inner,.opiniones-inner,.ubicacion-inner,.pagos-inner,.galeria-inner,.cta-banner-inner{padding:80px 20px}
  .servicios-head,.galeria-head{flex-direction:column;align-items:flex-start}
  .servicios-grid{grid-template-columns:1fr;gap:14px}
  .disc-modal{padding:0}
  .disc-modal-card{grid-template-columns:1fr;max-height:100vh;height:100%;border-radius:0;grid-template-rows:auto 1fr}
  .disc-modal-media{aspect-ratio:16/10}
  .disc-modal-content{padding:28px 24px 36px}
  .disc-modal-content h2{font-size:24px}
  .galeria-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .porque-grid{grid-template-columns:1fr 1fr;gap:30px 20px}
  .opiniones-grid{grid-template-columns:1fr;gap:16px}
  .ubicacion-grid{grid-template-columns:1fr;gap:30px;justify-items:center}
  .mapa{width:100%;margin-inline:auto}
  .ubicacion-data{width:100%}
  .contacto-page{padding:60px 20px 80px}
  .contacto-grid{grid-template-columns:1fr;gap:48px}
  .contacto-head{margin-bottom:40px}
  .contacto-cards-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .contacto-card{padding:26px 22px;min-height:auto}
  .form-card{padding:30px 24px}
  .lightbox{padding:60px 20px}
  .lb-close{top:14px;right:14px}
  .lb-prev{left:10px}
  .lb-next{right:10px}
  .lb-btn{width:42px;height:42px}
  .foot-top{flex-direction:column;align-items:flex-start}
  .foot-bot{flex-direction:column;align-items:flex-start}
}
@media (max-width:560px){
  .hero h1{font-size:46px}
  .section h2{font-size:34px}
  .porque-grid{grid-template-columns:1fr}
  .stat-num{font-size:34px}
  .pagos-list .pago{flex:1 1 calc(50% - 7px);justify-content:center;padding:16px 14px}
  .cta-banner-btns a{width:100%;justify-content:center}
  .contacto-cards-grid{grid-template-columns:1fr}
}
