/* ─── RESET & VARIABLES ─────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --blue:      #1b4fc4;
  --blue-dark: #153ea0;
  --blue-soft: #2563eb;
  --sky:       #38aadc;
  --sky-light: #d0eaf8;
  --white:     #ffffff;
  --offwhite:  #f4f7ff;
  --cream:     #f8f9fc;
  --text:      #111827;
  --muted:     #5a6a8a;
  --border:    #dce6f5;
  --radius:    10px;
  --radius-lg: 16px;
  --shadow:    0 2px 8px rgba(27,79,196,0.07), 0 6px 24px rgba(27,79,196,0.06);
  --shadow-sm: 0 1px 4px rgba(27,79,196,0.08);
}
html { scroll-behavior: smooth; }
a:focus-visible, button:focus-visible, .btn-p:focus-visible, .btn-s:focus-visible, .btn-nav:focus-visible, .cpill:focus-visible, .map-btn:focus-visible { outline:2px solid var(--blue); outline-offset:3px; border-radius:4px; }
::selection { background:rgba(56,170,220,.25); }
.skip-link{ position:absolute; left:-999px; top:8px; z-index:9999; background:var(--blue); color:#fff; padding:10px 18px; border-radius:6px; font-size:13px; font-weight:600; text-decoration:none; }
.skip-link:focus{ left:8px; }
html { overflow-x:clip; }
body { font-family: 'Barlow', sans-serif; background: var(--white); color: var(--text); overflow-x:clip; max-width:100vw; -webkit-font-smoothing: antialiased; }

/* ─── ANIMACIONES ───────────────────────────────── */
@keyframes fadeUp { from { opacity:0; transform:translateY(22px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }
.a1 { animation: fadeUp .65s cubic-bezier(.22,.8,.36,1) .05s both; }
.a2 { animation: fadeUp .65s cubic-bezier(.22,.8,.36,1) .16s both; }
.a3 { animation: fadeUp .65s cubic-bezier(.22,.8,.36,1) .27s both; }
.a4 { animation: fadeUp .65s cubic-bezier(.22,.8,.36,1) .38s both; }
.a5 { animation: fadeUp .65s cubic-bezier(.22,.8,.36,1) .48s both; }
.aR { animation: fadeIn .8s cubic-bezier(.22,.8,.36,1) .2s both; }
.reveal { opacity:0; transform:translateY(18px); transition: opacity .6s cubic-bezier(.22,.8,.36,1), transform .6s cubic-bezier(.22,.8,.36,1); }
.reveal.in { opacity:1; transform:translateY(0); }

/* ─── LAYOUT ────────────────────────────────────── */
.wrap { width:100%; max-width:1100px; margin:0 auto; padding:0 48px; }
.section { padding: 72px 0; scroll-margin-top:80px; }
/* Evita el "vacío doble" cuando dos secciones del mismo color van seguidas */
.section + .section:not(.section-alt){ padding-top:0; }
.section-alt + .section-alt, .section-soft + .section-alt, .section-alt + .section-soft{ padding-top:0; }
#contacto, #ubicacion, #niveles, #nosotros, #tea, #horarios, #tarifas, #noticias, #galeria, #calculadora, #comunidad, #testimonios, #faq, #adultos, #empezar { scroll-margin-top:80px; }
.section-alt { background: var(--offwhite); }
.section-soft { background:linear-gradient(180deg, var(--white) 0%, var(--offwhite) 100%); }

.sec-head { text-align:center; margin-bottom:42px; }
.sec-tag {
  display:inline-flex; align-items:center; gap:8px;
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--blue); font-weight:600; margin-bottom:14px;
}
.sec-tag::before, .sec-tag::after { content:''; width:20px; height:2px; background:var(--blue); border-radius:2px; }
.sec-h2 {
  font-family:'Barlow Condensed', sans-serif;
  font-size:clamp(36px, 3.8vw, 52px);
  font-weight:900; line-height:1; text-transform:uppercase;
  color:var(--text); letter-spacing:-.01em;
}
.sec-h2 em { font-style:normal; color:var(--blue); }
.sec-sub {
  font-size:16px; font-weight:300; color:var(--muted);
  line-height:1.75; margin-top:16px; max-width:560px;
  margin-left:auto; margin-right:auto; text-align:center;
}

/* ─── NAV ───────────────────────────────────────── */
nav {
  position:sticky; top:0; z-index:200;
  height:64px;
  background:rgba(255,255,255,.97);
  border-bottom:1px solid var(--border);
  backdrop-filter:blur(10px);
}
.nav-inner { height:100%; display:flex; align-items:center; justify-content:space-between; }
.nav-brand { display:flex; align-items:center; gap:10px; text-decoration:none; }
.nav-icon {
  width:44px; height:44px; border-radius:50%;
  border:1.5px solid var(--border);
  background:var(--white); overflow:hidden; padding:5px;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.nav-icon img { width:100%; height:100%; object-fit:contain; }
.nav-icon-placeholder {
  width:100%; height:100%;
  background:linear-gradient(135deg, var(--blue) 0%, var(--sky) 100%);
  display:flex; align-items:center; justify-content:center;
  font-family:'Barlow Condensed', sans-serif;
  font-size:14px; font-weight:900; color:#fff; letter-spacing:.04em;
}
.nav-name-wrap { display:flex; flex-direction:column; line-height:1; }
.nav-name {
  font-family:'Barlow Condensed', sans-serif;
  font-weight:900; font-size:15px; letter-spacing:.06em;
  text-transform:uppercase; color:var(--blue);
}
.nav-sub { font-size:9px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-top:2px; }

.nav-links { display:flex; gap:24px; }
.nav-links a { font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); text-decoration:none; font-weight:500; transition:color .2s; }
.nav-links a:hover { color:var(--blue); }

.btn-nav {
  padding:9px 20px; background:var(--blue); color:#fff;
  font-size:11px; letter-spacing:.1em; text-transform:uppercase; font-weight:700;
  text-decoration:none; border-radius:8px;
  transition:background .2s, transform .15s;
  box-shadow:0 4px 14px rgba(27,79,196,.25);
}
.btn-nav:hover { background:var(--blue-soft); transform:translateY(-1px); }

.burger { display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:6px; }
.burger span { display:block; width:22px; height:2px; background:var(--text); border-radius:2px; transition:transform .3s, opacity .3s; }
.burger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2) { opacity:0; }
.burger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.mobile-menu {
  display:none; position:fixed; top:64px; inset:64px 0 0 0;
  background:rgba(255,255,255,.98); backdrop-filter:blur(14px);
  z-index:150; flex-direction:column; align-items:center; justify-content:center; gap:28px;
  opacity:0; transition:opacity .25s;
}
.mobile-menu.open { display:flex; opacity:1; }
.mobile-menu a { font-size:20px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--text); text-decoration:none; }
.mobile-menu .mcta {
  padding:13px 36px; background:var(--blue); color:#fff !important;
  border-radius:10px; font-size:13px !important; margin-top:8px;
  box-shadow:0 4px 16px rgba(27,79,196,.3);
}

/* ─── HERO ──────────────────────────────────────── */
.hero { padding:64px 0 0; background:var(--white); }
.hero-inner {
  display:grid; grid-template-columns:0.9fr 1.1fr;
  border:1px solid var(--border); border-radius:var(--radius-lg);
  overflow:hidden; box-shadow:var(--shadow);
}
.hero-left {
  padding:56px 52px 52px;
  display:flex; flex-direction:column; justify-content:space-between; gap:36px;
}
.hero-eyebrow {
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--blue); display:flex; align-items:center; gap:8px; margin-bottom:16px;
}
.hero-eyebrow::before { content:''; width:20px; height:2px; background:var(--blue); border-radius:2px; }
.hero-h1 {
  font-family:'Barlow Condensed', sans-serif;
  font-size:clamp(52px, 5.5vw, 78px);
  font-weight:900; line-height:.92; text-transform:uppercase;
  color:var(--text); letter-spacing:-.01em; margin-bottom:18px;
}
.hero-h1 .accent { color:var(--blue); display:block; }
.hero-h1 .light { font-weight:300; color:var(--muted); }
.hero-desc { font-size:15px; font-weight:400; color:var(--muted); line-height:1.75; max-width:380px; text-align:justify; }
.hero-btns { display:flex; gap:10px; flex-wrap:wrap; margin-top:28px; }
.btn-p {
  padding:12px 26px; background:var(--blue); color:#fff;
  font-family:'Barlow Condensed', sans-serif;
  font-size:14px; letter-spacing:.08em; text-transform:uppercase; font-weight:700;
  text-decoration:none; border-radius:8px;
  transition:background .2s, transform .15s;
  box-shadow:0 4px 16px rgba(27,79,196,.28);
}
.btn-p:hover { background:var(--blue-soft); transform:translateY(-2px); }
.btn-s {
  padding:12px 26px; border:1.5px solid var(--border); color:var(--text);
  font-family:'Barlow Condensed', sans-serif;
  font-size:14px; letter-spacing:.08em; text-transform:uppercase; font-weight:700;
  text-decoration:none; border-radius:8px; transition:border-color .2s, color .2s;
}
.btn-s:hover { border-color:var(--blue); color:var(--blue); }

.hero-stats { display:flex; gap:32px; padding-top:24px; border-top:1px solid var(--border); }
.stat-n { font-family:'Barlow Condensed', sans-serif; font-size:32px; font-weight:900; color:var(--blue); line-height:1; }
.stat-n em { font-style:normal; color:var(--sky); font-size:18px; }
.stat-l { font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); font-weight:500; margin-top:3px; }

/* panel derecho hero */
.hero-right {
  background:var(--blue);
  padding:56px 52px 52px;
  display:flex; flex-direction:column; justify-content:space-between; gap:28px;
  position:relative; overflow:hidden;
}
.hero-right::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 140% 80% at 50% 110%, rgba(56,170,220,.45) 0%, transparent 55%),
    radial-gradient(ellipse 60% 40% at 20% 20%, rgba(255,255,255,.07) 0%, transparent 50%);
  pointer-events:none;
}
.hero-right::after {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:36px 36px; pointer-events:none;
}
.hr-label { font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.45); position:relative; z-index:2; }
.hr-big {
  font-family:'Barlow Condensed', sans-serif;
  font-size:clamp(40px, 4.4vw, 62px); font-weight:900; text-transform:uppercase;
  color:#fff; line-height:.92; position:relative; z-index:1;
}
.hr-big span { color:var(--sky); }
.hr-chips { display:flex; flex-wrap:wrap; gap:8px; position:relative; z-index:1; }
.chip { font-size:10px; letter-spacing:.1em; text-transform:uppercase; padding:6px 14px; border-radius:6px; }
.chip-w { color:#fff; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.35); }
.chip-s { color:var(--sky); border:1px solid rgba(56,170,220,.4); background:rgba(56,170,220,.1); }
.hr-contact { position:relative; z-index:1; }
.hr-contact p { font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.45); margin-bottom:6px; }
.hr-link { font-size:14px; color:rgba(255,255,255,.9); text-decoration:none; border-bottom:1px solid rgba(255,255,255,.3); padding-bottom:2px; transition:color .2s; }
.hr-link:hover { color:#fff; }
/* Portada estilo editorial: foto que se funde hacia el texto + entrada lateral */
.hero-photo{ position:relative; overflow:hidden; background:var(--white); min-height:430px; }
.hero-photo img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:60% center;
  -webkit-mask-image:linear-gradient(to right, transparent 0%, transparent 2%, #000 24%);
  mask-image:linear-gradient(to right, transparent 0%, transparent 2%, #000 24%); }
.anim .hero-left, .anim .hero-photo{ opacity:0; }
.site-ready .hero-left{ animation:heroInLeft 1s cubic-bezier(.22,.8,.36,1) both; }
.site-ready .hero-photo{ animation:heroInRight 1s cubic-bezier(.22,.8,.36,1) .08s both; }
@keyframes heroInLeft{ from{ opacity:0; transform:translateX(-40px); } to{ opacity:1; transform:translateX(0); } }
@keyframes heroInRight{ from{ opacity:0; transform:translateX(40px); } to{ opacity:1; transform:translateX(0); } }

/* ─── MARQUEE ───────────────────────────────────── */
.marquee { background:var(--offwhite); border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:12px 0; overflow:hidden; white-space:nowrap; margin-top:40px; position:relative; width:100%; }
.marquee-track { display:inline-flex; gap:28px; animation:mq 22s linear infinite; will-change:transform; width:max-content; }
.marquee-item { font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); display:inline-flex; align-items:center; gap:12px; }
.marquee-item::after { content:''; width:4px; height:4px; border-radius:50%; background:var(--sky); }
.marquee-item.mq-free{ color:var(--blue); font-weight:700; }
/* Promo destacada: primera clase gratis */
.ft-strip{ padding:42px 0 2px; }
.free-trial{ display:flex; align-items:center; gap:18px; justify-content:center; margin:0;
  background:linear-gradient(100deg, var(--sky) 0%, var(--blue) 76%); color:#fff;
  border-radius:14px; padding:18px 26px; position:relative; overflow:hidden;
  box-shadow:0 12px 30px rgba(27,79,196,.30); }
.free-trial .ft-badge{ flex-shrink:0; background:#fff; color:var(--blue);
  font-family:'Barlow Condensed',sans-serif; font-weight:900; text-transform:uppercase;
  letter-spacing:.05em; font-size:16px; line-height:1; padding:9px 17px; border-radius:50px; }
.free-trial p{ font-size:15px; font-weight:300; line-height:1.45; }
.free-trial strong{ font-weight:700; }
.ft-cta{ flex-shrink:0; background:#fff; color:var(--blue); padding:11px 24px; border-radius:50px;
  font-family:'Barlow Condensed',sans-serif; font-weight:700; font-size:13px; letter-spacing:.08em;
  text-transform:uppercase; text-decoration:none; transition:transform .15s, box-shadow .2s; white-space:nowrap; }
.ft-cta:hover{ transform:translateY(-2px); box-shadow:0 8px 20px rgba(0,0,0,.2); }
.free-trial::after{ content:''; position:absolute; top:0; left:-60%; width:38%; height:100%;
  background:linear-gradient(100deg, transparent, rgba(255,255,255,.30), transparent);
  transform:skewX(-18deg); animation:ftShine 5s ease-in-out infinite; pointer-events:none; }
@keyframes ftShine{ 0%,55%{ left:-60%; } 100%{ left:135%; } }
@media(max-width:560px){ .free-trial{ flex-direction:column; gap:12px; text-align:center; padding:20px 22px; } .ft-strip{ padding:34px 0 2px; } }
@keyframes mq { from { transform:translateX(0); } to { transform:translateX(-50%); } }

/* ─── NOSOTROS ──────────────────────────────────── */
.sobre-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; align-items:stretch; }
.sobre-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:40px;
  box-shadow:var(--shadow-sm);
}
.sobre-card-blue {
  background:var(--blue);
  border-color:transparent;
}
.sobre-big-text {
  font-family:'Barlow Condensed', sans-serif;
  font-size:clamp(48px,5vw,68px); font-weight:900;
  text-transform:uppercase; color:#fff; line-height:.92;
  margin-bottom:20px;
}
.sobre-big-text span { color:var(--sky); }
.sobre-tagline { font-size:13px; font-weight:400; color:rgba(255,255,255,.6); line-height:1.7; text-align:justify; }
.sobre-p { font-size:15px; font-weight:400; color:var(--text); line-height:1.8; margin-bottom:16px; text-align:justify; }
.sobre-p:last-child { margin-bottom:0; }
.sobre-p strong { font-weight:600; color:var(--blue); }

/* valores */
.valores-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:40px; }
.valor-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:28px 24px;
  box-shadow:var(--shadow-sm); text-align:center;
  transition:box-shadow .2s, transform .15s;
}
.valor-card:hover { box-shadow:var(--shadow); transform:translateY(-3px); }
.valor-icon { font-size:28px; margin-bottom:12px; display:block; }
.valor-title { font-family:'Barlow Condensed', sans-serif; font-size:17px; font-weight:800; text-transform:uppercase; color:var(--text); margin-bottom:8px; letter-spacing:.04em; }
.valor-desc { font-size:13px; font-weight:300; color:var(--muted); line-height:1.65; text-align:justify; }
.valor-card .valor-ic{ margin:0 auto 14px; }

/* ─── BENEFICIOS ────────────────────────────────── */
.beneficios-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.ben-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:28px 28px 24px;
  box-shadow:var(--shadow-sm); display:flex; gap:20px; align-items:flex-start;
  transition:box-shadow .2s;
}
.ben-card:hover { box-shadow:var(--shadow); }
.ben-icon {
  width:48px; height:48px; border-radius:12px;
  background:var(--sky-light); display:flex; align-items:center; justify-content:center;
  font-size:22px; flex-shrink:0;
}
.ben-icon img{ width:32px; height:32px; object-fit:contain; display:block; }
.ben-title { font-family:'Barlow Condensed', sans-serif; font-size:16px; font-weight:800; text-transform:uppercase; color:var(--text); margin-bottom:6px; letter-spacing:.04em; }
.ben-desc { font-size:13px; font-weight:300; color:var(--muted); line-height:1.7; text-align:justify; }

/* ─── NIVELES ───────────────────────────────────── */
.niveles-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.nivel-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:28px 24px;
  box-shadow:var(--shadow-sm); position:relative; overflow:hidden;
  transition:box-shadow .2s, transform .15s;
}
.nivel-card:hover { box-shadow:var(--shadow); transform:translateY(-3px); }
.nivel-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--blue); transform:scaleX(0); transform-origin:left; transition:transform .4s cubic-bezier(.22,.8,.36,1); }
.nivel-card:hover::before, .nivel-card.featured::before { transform:scaleX(1); }
.nivel-card.featured::before { background:linear-gradient(90deg, var(--blue), var(--sky)); }
.nivel-card.featured { border-color:var(--blue); }
.nivel-num { font-size:10px; letter-spacing:.2em; color:var(--blue); font-weight:600; text-transform:uppercase; margin-bottom:10px; display:block; }
.nivel-name { font-family:'Barlow Condensed', sans-serif; font-size:20px; font-weight:900; text-transform:uppercase; color:var(--text); margin-bottom:4px; }
.nivel-pub { font-size:11px; font-weight:600; color:var(--sky); letter-spacing:.08em; text-transform:uppercase; margin-bottom:12px; }
.nivel-time { font-size:13px; font-weight:500; color:var(--muted); margin-bottom:12px; display:flex; align-items:center; gap:6px; }
.nivel-desc { font-size:13px; font-weight:300; color:var(--muted); line-height:1.65; text-align:justify; }

/* ─── HORARIOS ──────────────────────────────────── */
.horario-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm);
  max-width:700px; margin:0 auto;
}
.horario-head{ background:linear-gradient(100deg,var(--blue-dark) 0%,var(--blue) 30%,#2f78c8 56%,var(--sky) 100%); color:#fff; padding:30px 28px; display:flex; align-items:center; justify-content:center; gap:18px; text-align:center; }
.hh-dash{ width:42px; height:1.5px; background:rgba(255,255,255,.55); flex-shrink:0; }
.hh-title{ font-family:'Barlow Condensed',sans-serif; font-size:26px; font-weight:900; text-transform:uppercase; letter-spacing:.2em; line-height:1; }
.valor-ic{ width:46px; height:46px; border-radius:12px; background:var(--sky-light); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.valor-ic img{ width:31px; height:31px; object-fit:contain; display:block; }
@media(max-width:560px){ .horario-head{ gap:12px; padding:26px 22px; } .hh-dash{ width:24px; } .hh-title{ font-size:21px; letter-spacing:.14em; } }
table { width:100%; border-collapse:collapse; }
thead tr { background:var(--offwhite); }
th { font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); padding:14px 20px; text-align:left; border-bottom:1px solid var(--border); }
td { font-size:14px; font-weight:400; color:var(--text); padding:14px 20px; border-bottom:1px solid var(--border); }
tr:last-child td { border-bottom:none; }
tr:hover td { background:var(--offwhite); }
td:last-child { font-weight:600; color:var(--blue); }

/* ─── TARIFAS ───────────────────────────────────── */
.tarifas-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; max-width:720px; margin:0 auto; }
.tarifa-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:36px 28px 28px;
  box-shadow:var(--shadow-sm); text-align:center;
  transition:box-shadow .2s, transform .15s;
}
.tarifa-card:hover { box-shadow:var(--shadow); transform:translateY(-3px); }
.tarifa-card.featured { background:var(--blue); border-color:transparent; }
.tarifa-label { font-size:11px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:12px; }
.tarifa-card.featured .tarifa-label { color:rgba(255,255,255,.6); }
.tarifa-price { font-family:'Barlow Condensed', sans-serif; font-size:44px; font-weight:900; color:var(--blue); line-height:1; margin-bottom:4px; }
.tarifa-card.featured .tarifa-price { color:#fff; }
.tarifa-per { font-size:11px; font-weight:500; color:var(--muted); letter-spacing:.08em; text-transform:uppercase; margin-bottom:16px; }
.tarifa-card.featured .tarifa-per { color:rgba(255,255,255,.5); }
.tarifa-divider { height:1px; background:var(--border); margin:16px 0; }
.tarifa-card.featured .tarifa-divider { background:rgba(255,255,255,.15); }
.tarifa-desc { font-size:13px; font-weight:300; color:var(--muted); line-height:1.7; text-align:justify; }
.tarifa-card.featured .tarifa-desc { color:rgba(255,255,255,.7); }
.tarifa-note {
  text-align:center; margin-top:28px;
  font-size:14px; font-weight:400; color:var(--muted); line-height:1.6;
  padding:16px 20px; background:var(--sky-light); border-radius:var(--radius);
  border:1px solid rgba(56,170,220,.2);
}
.tarifa-note strong { color:var(--blue); }

/* ─── GALERÍA ───────────────────────────────────── */
.galeria-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.gal-video{ grid-column:1 / -1; }
.galeria-item {
  border-radius:var(--radius-lg); overflow:hidden;
  aspect-ratio:4/3; position:relative;
  background:var(--blue); box-shadow:var(--shadow-sm);
  cursor:pointer; transition:transform .2s, box-shadow .2s;
}
.galeria-item:hover { transform:translateY(-4px); box-shadow:var(--shadow); }
.galeria-item::after{ content:''; position:absolute; inset:0; background:linear-gradient(180deg, transparent 55%, rgba(12,28,60,.45) 100%); pointer-events:none; opacity:.7; transition:opacity .3s; }
.galeria-item:hover::after{ opacity:1; }
/* .tall retirado: todas las celdas comparten proporción uniforme */
/* placeholders visuales mientras no hay fotos reales */
.galeria-placeholder {
  width:100%; height:100%; min-height:200px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:10px; padding:24px;
}
.gal-bg-1 { background:linear-gradient(135deg, #1b4fc4 0%, #38aadc 100%); }
.gal-bg-2 { background:linear-gradient(135deg, #0f3a9b 0%, #1b4fc4 100%); }
.gal-bg-3 { background:linear-gradient(135deg, #38aadc 0%, #2563eb 100%); }
.gal-bg-4 { background:linear-gradient(135deg, #153ea0 0%, #38aadc 100%); }
.gal-bg-6 { background:linear-gradient(135deg, #38aadc 0%, #153ea0 100%); }
.gal-icon { font-size:36px; opacity:.6; }
.gal-caption { font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.6); text-align:center; }
.galeria-note {
  text-align:center; margin-top:28px;
  font-size:13px; font-weight:300; color:var(--muted);
  padding:12px; border:1px dashed var(--border); border-radius:var(--radius);
}
.galeria-note a { color:var(--blue); text-decoration:none; font-weight:500; }
/* ═══ NOTICIAS: carrusel de flyers ═══ */
.noticias-wrap{ position:relative; }
.noticias-track{ display:flex; gap:18px; overflow-x:auto; scroll-snap-type:x mandatory; scroll-behavior:smooth; padding:6px 2px 22px; -webkit-overflow-scrolling:touch; scrollbar-width:thin; }
.noticias-track::-webkit-scrollbar{ height:7px; }
.noticias-track::-webkit-scrollbar-track{ background:transparent; }
.noticias-track::-webkit-scrollbar-thumb{ background:var(--border); border-radius:4px; }
.noticia-card{ flex:0 0 290px; scroll-snap-align:center; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); background:#fff; transition:transform .25s, box-shadow .25s; }
.noticia-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.noticia-card img{ width:100%; height:auto; display:block; }
.not-arrow{ position:absolute; top:46%; transform:translateY(-50%); z-index:3; width:44px; height:44px; border-radius:50%; border:1px solid var(--border); background:rgba(255,255,255,.96); color:var(--blue); font-size:26px; line-height:1; cursor:pointer; box-shadow:var(--shadow-sm); display:flex; align-items:center; justify-content:center; transition:background .2s,color .2s; }
.not-arrow:hover{ background:var(--blue); color:#fff; }
.not-prev{ left:-12px; } .not-next{ right:-12px; }
@media(max-width:640px){ .noticia-card{ flex-basis:80%; } .not-arrow{ display:none; } }

/* ─── TESTIMONIOS ───────────────────────────────── */
.test-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:28px;
  box-shadow:var(--shadow-sm); display:flex; flex-direction:column;
  transition:box-shadow .2s;
}
.test-card:hover { box-shadow:var(--shadow); }
.test-stars { display:flex; gap:3px; margin-bottom:14px; }
.star { width:13px; height:13px; background:var(--sky); clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%); }
.test-q { font-size:14px; font-weight:400; color:var(--text); line-height:1.8; font-style:italic; flex:1; text-align:justify; }
.test-q::before { content:'\201C'; font-family:'Barlow Condensed', sans-serif; font-size:44px; font-weight:900; color:var(--blue); line-height:.7; display:block; margin-bottom:8px; opacity:.25; }
.test-author { display:flex; align-items:center; gap:10px; margin-top:20px; padding-top:16px; border-top:1px solid var(--border); }
.test-av { width:36px; height:36px; border-radius:50%; background:linear-gradient(135deg, var(--blue), var(--sky)); display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:800; color:#fff; font-family:'Barlow Condensed', sans-serif; flex-shrink:0; }
.test-name { font-size:13px; font-weight:700; color:var(--text); }
.test-role { font-size:11px; font-weight:300; color:var(--muted); }
.test-empty {
  border:1px dashed var(--border); border-radius:var(--radius-lg);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:8px; padding:32px 24px; min-height:200px;
}
.test-empty p { font-size:13px; font-weight:300; color:var(--muted); text-align:center; line-height:1.6; }
.test-empty .test-cta{ display:inline-flex; align-items:center; gap:8px; margin-top:4px; padding:10px 20px; border:1.5px solid var(--blue); border-radius:50px; font-family:'Barlow Condensed',sans-serif; font-size:13px; letter-spacing:.08em; text-transform:uppercase; font-weight:700; color:var(--blue); text-decoration:none; transition:background .18s, color .18s, transform .15s; }
.test-empty .test-cta:hover{ background:var(--blue); color:#fff; transform:translateY(-2px); }
.test-empty .test-cta .wa-glyph{ width:1.1em; height:1.1em; }

/* ─── UBICACIÓN ─────────────────────────────────── */
.ubicacion-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; align-items:stretch; }
.ubic-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:36px;
  box-shadow:var(--shadow-sm);
}
.ubic-items { display:flex; flex-direction:column; gap:0; margin-top:28px; }
.ubic-item { display:flex; align-items:flex-start; gap:14px; padding:16px 0; border-bottom:1px solid var(--border); }
.ubic-item:first-child { border-top:1px solid var(--border); }
.ubic-icon { width:38px; height:38px; border-radius:10px; background:var(--sky-light); display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
.ubic-icon img{ width:24px; height:24px; object-fit:contain; display:block; }
.ubic-lbl { font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--blue); margin-bottom:3px; }
.ubic-val { font-size:14px; font-weight:400; color:var(--text); line-height:1.5; }
.ubic-val a { color:var(--blue); text-decoration:none; }

.map-card {
  background:var(--blue); border:1px solid transparent;
  border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:var(--shadow); display:flex; flex-direction:column;
  min-height:280px;
}
.map-embed { flex:1; background:var(--sky-light); min-height:220px; position:relative; }
.map-embed iframe { width:100%; height:100%; border:none; display:block; }
.map-footer { padding:18px 24px; display:flex; align-items:center; justify-content:space-between; }
.map-footer p { font-size:13px; font-weight:600; color:#fff; }
.map-footer span { font-size:11px; color:rgba(255,255,255,.6); }
.map-btn {
  padding:9px 18px; background:rgba(255,255,255,.15); color:#fff;
  font-size:11px; letter-spacing:.1em; text-transform:uppercase; font-weight:600;
  text-decoration:none; border-radius:6px; border:1px solid rgba(255,255,255,.3);
  transition:background .2s;
}
.map-btn:hover { background:rgba(255,255,255,.25); }

/* ─── CONTACTO ──────────────────────────────────── */
.cto-grid { display:grid; grid-template-columns:1fr; max-width:680px; margin:0 auto; gap:24px; align-items:start; }
.cto-info-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:36px;
  box-shadow:var(--shadow-sm);
}
.cto-intro { font-size:15px; font-weight:400; color:var(--muted); line-height:1.75; margin-bottom:24px; text-align:justify; }
.cto-row { display:flex; align-items:flex-start; gap:14px; padding:14px 0; border-bottom:1px solid var(--border); }
.cto-row:first-of-type { border-top:1px solid var(--border); }
.cto-lbl { font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); font-weight:600; min-width:64px; margin-top:2px; flex-shrink:0; }
.cto-val { font-size:14px; font-weight:400; color:var(--text); line-height:1.5; }
.cto-val a { color:var(--blue); text-decoration:none; }
.cto-pills { display:flex; flex-direction:column; gap:10px; margin-top:24px; }
.cpill {
  display:flex; align-items:center; gap:10px;
  padding:12px 16px; border-radius:8px; text-decoration:none;
  font-size:13px; font-weight:500; color:var(--text);
  background:var(--offwhite); border:1px solid var(--border);
  transition:background .2s, border-color .2s;
}
.cpill:hover { background:var(--sky-light); border-color:rgba(56,170,220,.3); }

.cto-form-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius-lg); box-shadow:var(--shadow-sm); overflow:hidden;
}
.cto-form-head {
  padding:14px 20px; border-bottom:1px solid var(--border);
  font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--blue); font-weight:600;
  background:var(--offwhite);
}
.cto-form-body { padding:26px 26px 30px; }

/* ─── FORMULARIO DE INSCRIPCIÓN ─── */
.insc-form { display:flex; flex-direction:column; gap:16px; }
.insc-field { display:flex; flex-direction:column; gap:7px; }
.insc-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.insc-field label { font-family:'Barlow Condensed',sans-serif; font-size:13px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--text); }
.insc-field input, .insc-field select, .insc-field textarea {
  font-family:'Barlow',sans-serif; font-size:14px; color:var(--text);
  padding:11px 14px; border:1.5px solid var(--border); border-radius:9px;
  background:var(--white); transition:border-color .2s, box-shadow .2s; width:100%;
}
.insc-field input:focus, .insc-field select:focus, .insc-field textarea:focus {
  outline:none; border-color:var(--blue); box-shadow:0 0 0 3px var(--sky-light);
}
.insc-field input[aria-invalid="true"], .insc-field select[aria-invalid="true"] { border-color:#c0392b; }
.insc-field textarea { resize:vertical; min-height:64px; }
.insc-hint { font-size:11.5px; font-weight:300; color:var(--muted); line-height:1.5; }

.insc-toggle { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.insc-tg {
  font-family:'Barlow',sans-serif; font-size:13px; font-weight:500; color:var(--text);
  padding:11px 10px; border:1.5px solid var(--border); border-radius:9px; background:var(--white);
  cursor:pointer; transition:all .2s; text-align:center;
}
.insc-tg:hover { border-color:var(--sky); }
.insc-tg.active { background:var(--blue); border-color:var(--blue); color:#fff; }

.insc-solo-menor { overflow:hidden; }
.insc-form.es-adulto .insc-solo-menor { display:none; }

.insc-btn {
  margin-top:4px; padding:14px; background:var(--blue); color:#fff; border:none; border-radius:9px;
  font-family:'Barlow Condensed',sans-serif; font-size:15px; letter-spacing:.08em; text-transform:uppercase;
  font-weight:700; cursor:pointer; transition:background .2s, transform .15s;
}
.insc-btn:hover { background:var(--blue-soft); transform:translateY(-1px); }
.insc-btn:disabled { background:var(--muted); cursor:not-allowed; transform:none; }

.insc-msg { font-size:13.5px; line-height:1.6; padding:13px 16px; border-radius:9px; }
.insc-ok { background:#e7f6ec; color:#1d6b38; border:1px solid #b7e0c4; }
.insc-err { background:#fdecea; color:#b0352a; border:1px solid #f4c4be; }

/* ─── FOOTER ────────────────────────────────────── */
footer { background:var(--blue); border-top:1px solid rgba(255,255,255,.06); }
@media (max-width:920px){
  .footer-inner{ flex-direction:column; text-align:center; gap:18px; padding:32px 0; }
  .footer-brand{ align-items:center; }
  .footer-nav{ justify-content:center; }
  .footer-copy{ max-width:520px; }
}
.footer-inner { padding:36px 0; display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.footer-brand { display:flex; flex-direction:column; gap:4px; }
.footer-name { font-family:'Barlow Condensed', sans-serif; font-size:20px; font-weight:900; text-transform:uppercase; color:#fff; letter-spacing:.06em; }
.footer-tagline { font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.45); }
.footer-nav { display:flex; gap:22px; flex-wrap:wrap; }
.footer-nav a { font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.4); text-decoration:none; transition:color .2s; }
.footer-nav a:hover { color:rgba(255,255,255,.9); }
.footer-copy { font-size:10px; color:rgba(255,255,255,.25); }

/* ─── FAB ───────────────────────────────────────── */
/* FAB azul "Inscríbete" retirado: se deja solo el flotante de WhatsApp */

/* ─── RESPONSIVE ────────────────────────────────── */

/* ─── PRELOADER ─────────────────────────────────── */
#preloader{position:fixed;inset:0;background:var(--blue-dark);z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;transition:opacity .7s ease,visibility .7s ease;}
#preloader.done{opacity:0;visibility:hidden;}
.pl-logo{width:172px;height:172px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;animation:plpulse 1.7s ease-in-out infinite;box-shadow:0 14px 40px rgba(0,0,0,.22);}
.pl-logo img{width:152px;max-width:72%;height:auto;display:block;object-fit:contain;}
.pl-text{font-family:'Barlow Condensed',sans-serif;font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:rgba(255,255,255,.6);font-weight:600;}
@keyframes plpulse{0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(56,170,220,.45);}50%{transform:scale(1.06);box-shadow:0 0 0 16px rgba(56,170,220,0);}}

/* ─── BARRA DE PROGRESO + VOLVER ARRIBA ─────────── */
.progress-bar{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--blue),var(--sky));z-index:400;transition:width .1s linear;}
.to-top{position:fixed;bottom:28px;left:28px;z-index:300;width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:#fff;color:var(--blue);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .3s,visibility .3s,transform .3s,background .2s;box-shadow:var(--shadow-sm);}
.to-top.show{opacity:1;visibility:visible;transform:translateY(0);}
.to-top:hover{background:var(--offwhite);}
.to-top svg{width:20px;height:20px;}

/* ─── REVEAL: variantes direccionales + escalonado ── */
.reveal.from-left{transform:translateX(-42px);}
.reveal.from-right{transform:translateX(42px);}
.reveal.from-scale{transform:scale(.95) translateY(14px);}
.reveal.from-left.in,.reveal.from-right.in,.reveal.from-scale.in{transform:none;}
.reveal.d1{transition-delay:.07s;}.reveal.d2{transition-delay:.14s;}.reveal.d3{transition-delay:.21s;}
.reveal.d4{transition-delay:.28s;}.reveal.d5{transition-delay:.35s;}.reveal.d6{transition-delay:.42s;}

/* ─── CONTADOR ──────────────────────────────────── */
.stat-n .count{font-variant-numeric:tabular-nums;}

/* ─── PARALLAX ──────────────────────────────────── */
.hero-right{will-change:background-position;}

@media (prefers-reduced-motion: reduce){
  .reveal,.a1,.a2,.a3,.a4,.a5,.aR,.hero-left,.hero-photo{transition:none!important;animation:none!important;transform:none!important;opacity:1!important;}
  html{scroll-behavior:auto;}
  .pl-logo{animation:none!important;}
  .free-trial::after{animation:none!important;display:none;}
}





/* ═══ FRANJA ADULTOS ═══ */
.adultos-band{ background:linear-gradient(100deg,var(--blue-dark) 0%,var(--blue) 28%,#2f78c8 42%,var(--sky) 60%,var(--sky) 100%); border-radius:var(--radius-lg); padding:58px 52px; position:relative; overflow:hidden; box-shadow:var(--shadow); min-height:380px; display:flex; align-items:center; }
.adultos-band::after{ content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px); background-size:36px 36px; z-index:1; pointer-events:none; }
.adultos-content{ position:relative; z-index:3; max-width:400px; }
.adultos-tag{ font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--sky-light); font-weight:700; margin-bottom:14px; }
.adultos-title{ font-family:'Barlow Condensed',sans-serif; font-size:clamp(30px,4.4vw,46px); font-weight:900; text-transform:uppercase; color:#fff; line-height:1.04; }
.adultos-title em{ font-style:normal; color:var(--sky-light); }
.adultos-desc{ font-size:15px; font-weight:300; color:rgba(255,255,255,.85); line-height:1.75; margin-top:18px; }
.adultos-points{ display:flex; flex-wrap:wrap; gap:12px; margin-top:22px; }
.adultos-points span{ font-size:12px; font-weight:500; color:#fff; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.25); border-radius:50px; padding:9px 16px; }
.adultos-cta{ display:inline-block; margin-top:26px; padding:14px 30px; background:#fff; color:var(--blue); border-radius:8px; font-family:'Barlow Condensed',sans-serif; font-size:14px; letter-spacing:.08em; text-transform:uppercase; font-weight:700; text-decoration:none; transition:transform .15s, box-shadow .2s; }
.adultos-cta:hover{ transform:translateY(-2px); box-shadow:0 8px 22px rgba(0,0,0,.18); }
@media (max-width:520px){ .adultos-photo{ height:180px; } }
.adultos-photo{ position:absolute; top:0; right:0; bottom:0; width:60%; z-index:2; }
.adultos-photo img{ width:100%; height:100%; object-fit:cover; object-position:50% center; display:block;
  -webkit-mask-image:linear-gradient(to right, transparent 0%, transparent 13%, #000 40%);
  mask-image:linear-gradient(to right, transparent 0%, transparent 13%, #000 40%); }
@media (max-width:760px){
  .adultos-band{ padding:0; display:block; min-height:0; }
  .adultos-photo{ position:relative; width:100%; height:210px; z-index:1; }
  .adultos-photo img{ object-position:center 32%;
    -webkit-mask-image:linear-gradient(to bottom, #000 52%, transparent 100%);
    mask-image:linear-gradient(to bottom, #000 52%, transparent 100%); }
  .adultos-content{ max-width:none; padding:6px 28px 38px; margin-top:-26px; }
}
/* Franja Inclusión TEA (foto izquierda) */
.tea-band{ background:linear-gradient(100deg, var(--sky) 0%, var(--sky) 30%, #2f78c8 48%, var(--blue) 66%, var(--blue-dark) 100%); border-radius:var(--radius-lg); padding:58px 52px; position:relative; overflow:hidden; box-shadow:var(--shadow); min-height:380px; display:flex; align-items:center; justify-content:flex-end; }
.tea-band::after{ content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px); background-size:36px 36px; z-index:1; pointer-events:none; }
.tea-content{ position:relative; z-index:3; max-width:420px; }
.tea-tag{ font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--sky-light); font-weight:700; margin-bottom:14px; }
.tea-title{ font-family:'Barlow Condensed',sans-serif; font-size:clamp(28px,4vw,42px); font-weight:900; text-transform:uppercase; color:#fff; line-height:1.05; }
.tea-title em{ font-style:normal; color:var(--sky-light); }
.tea-desc{ font-size:15px; font-weight:300; color:rgba(255,255,255,.88); line-height:1.75; margin-top:18px; }
.tea-team{ display:inline-flex; align-items:center; gap:10px; margin-top:24px; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.28); border-radius:50px; padding:10px 18px; font-size:13px; color:#fff; }
.tea-team span{ font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--sky-light); font-weight:700; }
.tea-photo{ position:absolute; top:0; left:0; bottom:0; width:60%; z-index:2; }
.tea-photo img{ width:100%; height:100%; object-fit:cover; object-position:50% 50%; display:block;
  -webkit-mask-image:linear-gradient(to right, #000 0%, #000 62%, transparent 93%);
  mask-image:linear-gradient(to right, #000 0%, #000 62%, transparent 93%); }
@media (max-width:760px){
  .tea-band{ padding:0; display:block; min-height:0; }
  .tea-photo{ position:relative; width:100%; height:240px; z-index:1; }
  .tea-photo img{ object-position:center 58%;
    -webkit-mask-image:linear-gradient(to bottom, #000 55%, transparent 100%);
    mask-image:linear-gradient(to bottom, #000 55%, transparent 100%); }
  .tea-content{ max-width:none; padding:6px 28px 38px; margin-top:-24px; }
}
/* Cómo empezar: pasos + qué llevar */
.pasos-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.paso-card{ position:relative; background:var(--white); border:1px solid var(--border); border-radius:var(--radius-lg); padding:32px 28px; box-shadow:var(--shadow-sm); transition:box-shadow .2s, transform .15s; }
.paso-card:hover{ box-shadow:var(--shadow); transform:translateY(-3px); }
.paso-num{ font-family:'Barlow Condensed',sans-serif; font-size:42px; font-weight:900; color:var(--sky); line-height:1; margin-bottom:14px; }
.paso-title{ font-family:'Barlow Condensed',sans-serif; font-size:19px; font-weight:800; text-transform:uppercase; letter-spacing:.04em; color:var(--blue); margin-bottom:8px; }
.paso-desc{ font-size:14px; font-weight:300; color:var(--muted); line-height:1.7; }
.paso-desc a{ color:var(--blue); font-weight:600; text-decoration:underline; text-underline-offset:2px; }
.llevar-card{ margin-top:24px; background:var(--blue); color:#fff; border-radius:var(--radius-lg); padding:30px 34px; display:flex; flex-wrap:wrap; align-items:center; gap:18px 40px; box-shadow:var(--shadow); }
.llevar-head{ flex:1 1 240px; }
.llevar-title{ font-family:'Barlow Condensed',sans-serif; font-size:22px; font-weight:900; text-transform:uppercase; letter-spacing:.03em; }
.llevar-sub{ font-size:13px; font-weight:300; color:rgba(255,255,255,.82); margin-top:6px; }
.llevar-list{ flex:1 1 320px; list-style:none; display:grid; grid-template-columns:1fr 1fr; gap:11px 22px; }
.llevar-list li{ position:relative; padding-left:28px; font-size:14px; font-weight:400; }
.llevar-list li::before{ content:''; position:absolute; left:0; top:1px; width:18px; height:18px; border-radius:50%; background:var(--sky); }
.llevar-list li::after{ content:''; position:absolute; left:6px; top:6px; width:6px; height:3px; border-left:2px solid #fff; border-bottom:2px solid #fff; transform:rotate(-45deg); }
@media (max-width:760px){ .pasos-grid{ grid-template-columns:1fr; } .llevar-card{ padding:26px 26px; } .llevar-list{ gap:10px 16px; } }
/* Glifo de Instagram (proporcional, hereda el color del texto) */
.ig-glyph, .wa-glyph, .pin-glyph, .cal-glyph{ width:1em; height:1em; vertical-align:-.14em; flex-shrink:0; }

/* ═══ EQUIPO ═══ */
.team-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:40px; }
.team-card{ background:var(--white); border:1px solid var(--border); border-radius:var(--radius-lg); padding:32px 24px; box-shadow:var(--shadow-sm); text-align:center; transition:box-shadow .2s, transform .15s; }
.team-card:hover{ box-shadow:var(--shadow); transform:translateY(-3px); }
.team-avatar{ width:108px; height:108px; border-radius:50%; margin:0 auto 18px; background:linear-gradient(135deg,var(--blue),var(--sky)); display:flex; align-items:center; justify-content:center; overflow:hidden; border:3px solid var(--white); box-shadow:0 0 0 1px var(--border); }
.team-avatar img{ width:100%; height:100%; object-fit:cover; }
.team-avatar svg{ width:48px; height:48px; }
.team-badge{ display:inline-block; background:var(--sky-light); color:var(--blue); font-size:10px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; padding:5px 12px; border-radius:50px; margin-bottom:10px; }
.team-name{ font-family:'Barlow Condensed',sans-serif; font-size:19px; font-weight:900; text-transform:uppercase; color:var(--text); letter-spacing:.02em; }
.team-role{ font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--blue); font-weight:700; margin-top:4px; }
.team-desc{ font-size:13px; font-weight:300; color:var(--muted); line-height:1.65; margin-top:14px; }

/* ═══ FAQ (acordeón) ═══ */
.faq-list{ max-width:760px; margin:0 auto; display:flex; flex-direction:column; gap:12px; }
.faq-item{ border:1px solid var(--border); border-radius:var(--radius); background:var(--white); overflow:hidden; transition:border-color .2s; }
.faq-item.open{ border-color:var(--blue); }
.faq-q{ width:100%; text-align:left; background:none; border:none; cursor:pointer; padding:20px 24px; font-family:'Barlow Condensed',sans-serif; font-size:16px; font-weight:700; color:var(--text); text-transform:uppercase; letter-spacing:.02em; display:flex; align-items:center; justify-content:space-between; gap:16px; }
.faq-q:hover{ color:var(--blue); }
.faq-icon{ flex-shrink:0; width:20px; height:20px; position:relative; }
.faq-icon::before, .faq-icon::after{ content:''; position:absolute; background:var(--blue); border-radius:2px; transition:transform .3s; }
.faq-icon::before{ top:9px; left:0; width:20px; height:2px; }
.faq-icon::after{ top:0; left:9px; width:2px; height:20px; }
.faq-item.open .faq-icon::after{ transform:rotate(90deg); opacity:0; }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .35s ease; }
.faq-a-inner{ padding:0 24px 20px; font-size:14px; font-weight:300; color:var(--muted); line-height:1.7; }
.faq-a-inner strong{ color:var(--text); font-weight:600; }

/* ═══ CALCULADORA: modo paso a paso ═══ */
.calc-progress{ display:flex; align-items:center; justify-content:center; gap:8px; margin-bottom:24px; }
.calc-dot{ width:9px; height:9px; border-radius:50%; background:var(--border); transition:background .3s, transform .3s; }
.calc-dot.active{ background:var(--blue); transform:scale(1.25); }
.calc-dot.done{ background:var(--sky); }
.calc-step-num{ font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); font-weight:600; text-align:center; margin-bottom:8px; }
.calc-q{ display:none; animation:fadeUp .4s cubic-bezier(.22,.8,.36,1) both; }
.calc-q.active{ display:block; }
.calc-q .calc-q-title{ justify-content:center; text-align:center; font-size:19px; margin-bottom:20px; }
.calc-q .calc-opts{ flex-direction:column; align-items:stretch; max-width:420px; margin:0 auto; }
.calc-q .calc-opt{ text-align:center; padding:14px 18px; }
.calc-back{ display:block; margin:18px auto 0; background:none; border:none; color:var(--muted); font-size:12px; letter-spacing:.06em; text-transform:uppercase; cursor:pointer; font-family:'Barlow',sans-serif; }
.calc-back:hover{ color:var(--blue); }
.calc-restart{ display:inline-block; margin-top:8px; background:none; border:none; color:var(--muted); font-size:12px; letter-spacing:.06em; text-transform:uppercase; cursor:pointer; font-family:'Barlow',sans-serif; text-decoration:underline; }
.calc-restart:hover{ color:var(--blue); }

/* ═══ TESTIMONIOS: carrusel con puntos ═══ */
/* ═══ CARRUSEL DE NIVELES ═══ */
.niv-carousel{ overflow:hidden; }
.niv-track{ display:flex; gap:20px; transition:transform .5s cubic-bezier(.22,.8,.36,1); }
.niv-track .nivel-card{ flex:0 0 calc((100% - 40px) / 3); box-sizing:border-box; }
.niv-controls{ display:flex; flex-direction:column; align-items:center; gap:14px; margin-top:28px; }
.niv-dots{ display:flex; align-items:center; justify-content:center; gap:10px; }
.niv-dot{ width:10px; height:10px; border-radius:50%; background:var(--border); border:none; cursor:pointer; padding:0; transition:background .3s, transform .3s; }
.niv-dot.active{ background:var(--blue); transform:scale(1.25); }
.niv-arrows{ display:flex; gap:12px; }
@media (max-width:860px){ .niv-track .nivel-card{ flex:0 0 calc((100% - 20px) / 2); } }
@media (max-width:680px){ .niv-track .nivel-card{ flex:0 0 100%; } }

.test-carousel{ position:relative; max-width:560px; margin:0 auto; overflow:hidden; }
.test-track{ display:flex; transition:transform .5s cubic-bezier(.22,.8,.36,1); }
.test-track > *{ flex:0 0 100%; box-sizing:border-box; }
.test-dots{ display:flex; align-items:center; justify-content:center; gap:10px; margin-top:24px; }
.test-dot{ width:10px; height:10px; border-radius:50%; background:var(--border); border:none; cursor:pointer; padding:0; transition:background .3s, transform .3s; }
.test-dot.active{ background:var(--blue); transform:scale(1.25); }
.test-arrows{ display:flex; justify-content:center; gap:12px; margin-top:14px; }
.test-arrow{ width:38px; height:38px; border-radius:50%; border:1px solid var(--border); background:var(--white); color:var(--blue); cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background .2s, border-color .2s; }
.test-arrow:hover{ background:var(--offwhite); border-color:var(--blue); }
.test-arrow svg{ width:18px; height:18px; }

/* ═══ INSTAGRAM MÉTRICAS ═══ */
.ig-band{ background:var(--blue); border-radius:var(--radius-lg); padding:44px 40px; box-shadow:var(--shadow); position:relative; overflow:hidden; }
.ig-band::after{ content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px); background-size:36px 36px; pointer-events:none; }
.ig-head{ display:flex; align-items:center; gap:12px; justify-content:center; margin-bottom:30px; position:relative; z-index:1; }
.ig-head svg{ width:26px; height:26px; }
.ig-handle{ font-family:'Barlow Condensed',sans-serif; font-weight:800; font-size:20px; letter-spacing:.04em; color:#fff; text-decoration:none; }
.ig-handle:hover{ color:var(--sky-light); }
.ig-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; position:relative; z-index:1; }
.ig-stat{ text-align:center; }
.ig-num{ font-family:'Barlow Condensed',sans-serif; font-size:clamp(38px,5vw,56px); font-weight:900; color:#fff; line-height:1; font-variant-numeric:tabular-nums; }
.ig-lbl{ font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.6); font-weight:600; margin-top:8px; }
.ig-divider{ display:none; }
.ig-cta{ display:block; text-align:center; margin-top:30px; position:relative; z-index:1; }
.ig-btn{ display:inline-flex; align-items:center; gap:8px; padding:11px 24px; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.35); border-radius:50px; color:#fff; font-size:12px; letter-spacing:.1em; text-transform:uppercase; font-weight:700; text-decoration:none; font-family:'Barlow Condensed',sans-serif; transition:background .2s; }
.ig-btn:hover{ background:rgba(255,255,255,.25); }
@media (max-width:520px){ .ig-band{ padding:34px 22px; } .ig-stats{ gap:10px; } .ig-lbl{ font-size:9px; letter-spacing:.08em; } }

/* ═══ TESTIMONIOS: scroll horizontal ═══ */

/* ═══ CALCULADORA DE NIVEL ═══ */
.calc-card{ background:linear-gradient(160deg, var(--offwhite) 0%, #eaf2fb 100%); border:1px solid var(--border); border-radius:var(--radius-lg); padding:40px; box-shadow:var(--shadow-sm); max-width:720px; margin:0 auto; }
.calc-q{ margin-bottom:24px; }
.calc-q:last-of-type{ margin-bottom:28px; }
.calc-q-title{ font-family:'Barlow Condensed',sans-serif; font-size:17px; font-weight:800; color:var(--text); margin-bottom:12px; display:flex; gap:10px; align-items:baseline; }
.calc-q-num{ font-size:12px; color:var(--blue); font-weight:700; flex-shrink:0; }
.calc-opts{ display:flex; flex-wrap:wrap; gap:10px; }
.calc-opt{ font-size:13px; font-weight:500; color:var(--text); padding:10px 18px; border:1.5px solid var(--border); border-radius:50px; background:var(--white); cursor:pointer; transition:all .2s; font-family:'Barlow',sans-serif; }
.calc-opt:hover{ border-color:var(--sky); }
.calc-opt.sel{ background:var(--blue); border-color:var(--blue); color:#fff; }
.calc-btn{ width:100%; padding:14px; background:var(--blue); color:#fff; border:none; border-radius:8px; font-family:'Barlow Condensed',sans-serif; font-size:15px; letter-spacing:.08em; text-transform:uppercase; font-weight:700; cursor:pointer; transition:background .2s,transform .15s; }
.calc-btn:hover{ background:var(--blue-soft); transform:translateY(-1px); }
.calc-btn:disabled{ background:var(--border); color:var(--muted); cursor:not-allowed; transform:none; }
.calc-result{ margin-top:24px; border:1px solid var(--blue); border-radius:var(--radius); padding:28px; background:var(--offwhite); text-align:center; display:none; }
.calc-result.show{ display:block; animation:fadeUp .5s cubic-bezier(.22,.8,.36,1) both; }
.calc-result-lbl{ font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--blue); font-weight:700; margin-bottom:8px; }
.calc-result-name{ font-family:'Barlow Condensed',sans-serif; font-size:34px; font-weight:900; text-transform:uppercase; color:var(--blue); line-height:1; margin-bottom:10px; }
.calc-result-desc{ font-size:14px; color:var(--muted); line-height:1.7; max-width:440px; margin:0 auto 8px; }
.calc-result-note{ font-size:13px; color:var(--text); background:var(--sky-light); border-radius:8px; padding:10px 16px; margin:14px auto 0; max-width:460px; display:none; }
.calc-result-cta{ display:inline-block; margin-top:18px; padding:12px 28px; background:var(--blue); color:#fff; border-radius:8px; font-family:'Barlow Condensed',sans-serif; font-size:14px; letter-spacing:.08em; text-transform:uppercase; font-weight:700; text-decoration:none; transition:background .2s; }
.calc-result-cta:hover{ background:var(--blue-soft); }
@media (max-width:520px){ .calc-card{ padding:28px 22px; } }

/* ═══ FAB WHATSAPP ═══ */
.fab-wa{ position:fixed; bottom:28px; right:28px; z-index:301; width:56px; height:56px; border-radius:50%; background:#25D366; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 20px rgba(37,211,102,.45); transition:transform .2s, box-shadow .2s; }
.fab-wa:hover{ transform:translateY(-3px) scale(1.04); box-shadow:0 8px 26px rgba(37,211,102,.55); }
.fab-wa svg{ width:30px; height:30px; }
.fab-wa::before{ content:''; position:absolute; inset:0; border-radius:50%; box-shadow:0 0 0 0 rgba(37,211,102,.5); animation:waPulse 2.4s ease-out infinite; }
@keyframes waPulse{ 0%{ box-shadow:0 0 0 0 rgba(37,211,102,.45); } 70%,100%{ box-shadow:0 0 0 16px rgba(37,211,102,0); } }

/* ═══ ANIMACIONES 3D (CSS puro, sin librerías) ═══ */

/* Agua animada con profundidad en el hero (3 capas de onda) */
.hero-right{ perspective:900px; }
.hero-waves{ position:absolute; left:0; right:0; bottom:0; height:46%; z-index:0; pointer-events:none; overflow:hidden; }
.hero-waves .wave{ position:absolute; left:-50%; width:200%; height:100%;
  background-repeat:repeat-x; background-position:0 bottom; background-size:50% 100%; opacity:.5; }
.hero-waves .w1{ background-image:radial-gradient(ellipse 50% 100% at 50% 130%, rgba(255,255,255,.20), transparent 70%); animation:waveMove 9s linear infinite; transform:translateZ(0); opacity:.55; }
.hero-waves .w2{ background-image:radial-gradient(ellipse 50% 100% at 50% 135%, rgba(56,170,220,.55), transparent 72%); animation:waveMove 13s linear infinite reverse; height:80%; opacity:.5; }
.hero-waves .w3{ background-image:radial-gradient(ellipse 50% 100% at 50% 140%, rgba(208,234,248,.30), transparent 75%); animation:waveMove 19s linear infinite; height:62%; opacity:.4; }
@keyframes waveMove{ from{ background-position:0 bottom; } to{ background-position:50% bottom; } }

/* Partículas/burbujas que suben (muy sutiles) */
.hero-bubbles{ position:absolute; inset:0; z-index:0; pointer-events:none; overflow:hidden; }
.bubble{ position:absolute; bottom:-12px; border-radius:50%; background:rgba(255,255,255,.18);
  animation:bubbleUp linear infinite; }
@keyframes bubbleUp{ 0%{ transform:translateY(0) scale(1); opacity:0; } 15%{ opacity:.8; } 100%{ transform:translateY(-340px) scale(.4); opacity:0; } }

/* Tilt 3D en tarjetas de nivel (perfil siguiendo el cursor) */
/* Tilt 3D de niveles retirado: ahora es carrusel */

/* Flotación 3D leve de los chips del hero */
.hr-chips .chip{ animation:floatChip 5s ease-in-out infinite; }
.hr-chips .chip:nth-child(2){ animation-delay:.6s; }
.hr-chips .chip:nth-child(3){ animation-delay:1.2s; }
.hr-chips .chip:nth-child(4){ animation-delay:1.8s; }
.hr-chips .chip:nth-child(5){ animation-delay:2.4s; }
@keyframes floatChip{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-4px); } }

@media (prefers-reduced-motion: reduce){
  .hero-waves .wave, .bubble, .hr-chips .chip, .fab-wa::before{ animation:none !important; }
  .nivel-card{ transform:none !important; }
}

/* ═══ RESPONSIVE (escalonado: 1024 / 860 / 680 / 480) ═══ */

/* Desktop chico / tablet horizontal */
/* Desktop chico / tablet horizontal */
@media (max-width:1024px){
  .wrap{ padding:0 32px; }
  .hero-inner{ grid-template-columns:1fr; }
  .hero-photo{ min-height:300px; }
  .hero-photo img{ object-position:center; -webkit-mask-image:linear-gradient(to bottom, transparent 0%, #000 24%); mask-image:linear-gradient(to bottom, transparent 0%, #000 24%); }
  .hero-left{ padding:48px 44px 28px; border-right:none; }
  .sobre-grid{ grid-template-columns:1fr; }
  .valores-grid{ grid-template-columns:repeat(3,1fr); }
  .beneficios-grid{ grid-template-columns:repeat(2,1fr); }
  .niveles-grid{ grid-template-columns:repeat(3,1fr); }
  .tarifas-grid{ grid-template-columns:repeat(2,1fr); }
  .team-grid{ grid-template-columns:repeat(3,1fr); gap:18px; }
  .galeria-grid{ grid-template-columns:repeat(2,1fr); }
  .ubicacion-grid{ grid-template-columns:1fr; }
  .cto-grid{ grid-template-columns:1fr; }
  .insc-row{ grid-template-columns:1fr; }
  .insc-toggle{ grid-template-columns:1fr; }
}

/* Nav: pasar a hamburguesa antes de que se apriete */
@media (max-width:920px){
  .nav-links, .btn-nav{ display:none; }
  .burger{ display:flex; }
  .nav-sub{ display:none; }
}

/* Tablet vertical / "media pantalla": todo a 2 columnas (nunca salta a 1 de golpe) */
@media (max-width:860px){
  .valores-grid{ grid-template-columns:repeat(3,1fr); gap:14px; }
  .beneficios-grid{ grid-template-columns:repeat(2,1fr); }
  .niveles-grid{ grid-template-columns:repeat(2,1fr); }
  .tarifas-grid{ grid-template-columns:repeat(2,1fr); }
  .team-grid{ grid-template-columns:repeat(2,1fr); max-width:620px; margin-left:auto; margin-right:auto; }
  .galeria-grid{ grid-template-columns:repeat(2,1fr); }
}

@media (max-width:680px){
  .wrap{ padding:0 22px; }
  .section{ padding:44px 0; }
  nav{ height:58px; }
  .mobile-menu{ top:58px; inset:58px 0 0 0; }
  .nav-links, .btn-nav{ display:none; }
  .burger{ display:flex; }
  .hero{ padding:28px 0 0; }
  .hero-left{ padding:34px 24px 30px; }
  .hero-photo{ min-height:230px; }
  .valores-grid{ grid-template-columns:1fr; max-width:420px; margin-left:auto; margin-right:auto; }
  .beneficios-grid{ grid-template-columns:1fr; }
  .niveles-grid{ grid-template-columns:1fr; }
  .tarifas-grid{ grid-template-columns:1fr; max-width:420px; margin:0 auto; }
  .galeria-grid{ grid-template-columns:1fr; gap:14px; }
  footer{ padding:0; }
  .footer-inner{ flex-direction:column; gap:16px; text-align:center; padding:28px 0; }
  .footer-nav{ flex-wrap:wrap; justify-content:center; }

  /* TABLA -> TARJETAS apiladas (arregla el bloque en blanco) */
  .horario-card table, .horario-card thead, .horario-card tbody, .horario-card tr, .horario-card td{ display:block; width:100%; }
  .horario-card thead{ display:none; }
  .horario-card tr{ border-bottom:1px solid var(--border); padding:14px 20px; }
  .horario-card tr:last-child{ border-bottom:none; }
  .horario-card td{ padding:4px 0; border:none; font-size:14px; display:flex; justify-content:space-between; gap:16px; }
  .horario-card td::before{ content:attr(data-lbl); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); font-weight:700; flex-shrink:0; }
  .horario-card td:first-child{ font-family:'Barlow Condensed',sans-serif; font-weight:900; font-size:17px; text-transform:uppercase; color:var(--blue); margin-bottom:4px; }
  .horario-card td:first-child::before{ align-self:center; }
  .horario-card td:last-child{ color:var(--blue); font-weight:600; }
}

@media (max-width:480px){
  .wrap{ padding:0 18px; }
  .hero-btns{ flex-direction:column; }
  .hero-stats{ gap:18px; flex-wrap:wrap; }
  .valores-grid{ grid-template-columns:1fr; }
  .galeria-grid{ grid-template-columns:1fr; }
  .team-grid{ grid-template-columns:1fr; max-width:360px; }
  .hero-desc, .sobre-p, .sobre-tagline, .valor-desc, .ben-desc, .nivel-desc, .tarifa-desc, .test-q, .cto-intro{ text-align:left; }
  .map-footer{ flex-direction:column; align-items:flex-start; gap:12px; }
  .fab-wa{ bottom:20px; right:16px; }
  .to-top{ bottom:20px; left:20px; }
}

/* Fixes transversales de overflow */
img, iframe{ max-width:100%; }
.ubic-val, .cto-val, .hr-link, .map-footer, .footer-tagline{ overflow-wrap:anywhere; }
.horario-card{ max-width:100%; }

/* === Casilla de consentimiento === */
.insc-consent{margin-top:4px;}
.insc-check{display:flex;gap:10px;align-items:flex-start;font-family:'Barlow',sans-serif;font-size:13px;line-height:1.5;color:#4a5160;cursor:pointer;}
.insc-check input{margin-top:2px;width:17px;height:17px;flex:0 0 auto;accent-color:var(--blue);cursor:pointer;}
.insc-check a{color:var(--blue);text-decoration:underline;}
/* === Prosa legal === */
.legal{max-width:760px;margin:0 auto;font-family:'Barlow',sans-serif;color:#2f3540;line-height:1.7;font-size:16px;}
.legal h3{font-family:'Barlow Condensed',sans-serif;font-size:24px;font-weight:700;color:var(--blue-dark,#16367f);margin:30px 0 8px;}
.legal p{margin:0 0 14px;}
.legal a{color:var(--blue);text-decoration:underline;}
.legal-updated{font-size:13px;color:#7a8190;text-transform:uppercase;letter-spacing:.04em;}
.legal-note{margin-top:26px;padding:16px 18px;background:#eef3ff;border-left:3px solid var(--blue);border-radius:8px;font-size:14px;color:#3a4252;}
