/* ============================================================
   Academia de Ballet Clásico Connie — base system
   ============================================================ */
:root{
  --crema:#F7F1E8;
  --crema-2:#EFE6D7;        /* warmer card / inset */
  --tinta:#1C1813;          /* ink */
  --tinta-2:#13100C;        /* deeper ink for B&W bands */
  --rosa:#A8786E;           /* dusty rose */
  --rosa-soft:#C19A92;
  --oro:#B79A66;            /* champagne gold */
  --texto:#2A241D;          /* body on cream */
  --texto-mute:#6B6055;     /* muted body */
  --linea:rgba(28,24,19,.14);
  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Jost", system-ui, sans-serif;
  --maxw:1240px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  background:var(--crema);
  color:var(--texto);
  font-family:var(--sans);
  font-weight:300;
  font-size:17px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;margin:0;line-height:1.04;letter-spacing:-.01em}
p{margin:0 0 1em;text-wrap:pretty}

/* ---------- layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:clamp(72px,11vw,150px) 0;position:relative}
.eyebrow{
  font-family:var(--sans);font-weight:400;font-size:12.5px;
  letter-spacing:.32em;text-transform:uppercase;color:var(--rosa);
  display:flex;align-items:center;gap:14px;margin:0 0 22px;
}
.eyebrow::before{content:"";width:34px;height:1px;background:currentColor;opacity:.7;flex:none}
.eyebrow.center{justify-content:center}
.eyebrow.light{color:var(--oro)}
.kicker-serif{font-family:var(--serif);font-style:italic;font-weight:400}

.display{font-size:clamp(40px,6vw,76px);line-height:1.0}
.lead{font-family:var(--serif);font-size:clamp(21px,2.6vw,28px);line-height:1.4;color:var(--texto);font-weight:400}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--tinta);--fg:var(--crema);
  display:inline-flex;align-items:center;gap:11px;
  font-family:var(--sans);font-weight:400;font-size:14px;letter-spacing:.06em;
  padding:16px 30px;border-radius:999px;border:1px solid var(--bg);
  background:var(--bg);color:var(--fg);cursor:pointer;
  transition:transform .4s var(--ease), background .4s var(--ease), color .4s var(--ease), box-shadow .4s var(--ease);
  text-transform:uppercase;min-height:48px;
}
.btn svg{width:17px;height:17px}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 30px -16px rgba(28,24,19,.5)}
.btn--ghost{--bg:transparent;--fg:var(--tinta);border-color:var(--linea)}
.btn--ghost:hover{--bg:var(--tinta);--fg:var(--crema)}
.btn--wa{--bg:#1FA855;--fg:#fff;border-color:#1FA855}
.btn--gold{--bg:var(--oro);--fg:#211c12;border-color:var(--oro)}
.btn--on-dark{--bg:transparent;--fg:var(--crema);border-color:rgba(247,241,232,.4)}
.btn--on-dark:hover{--bg:var(--crema);--fg:var(--tinta);border-color:var(--crema)}
.btn--lg{padding:19px 38px;font-size:15px}

/* ---------- reveal animation ---------- */
.rv{opacity:0;transform:translateY(26px);transition:opacity 1s var(--ease), transform 1s var(--ease)}
.rv.in{opacity:1;transform:none}
.rv-2{transition-delay:.12s}
.rv-3{transition-delay:.24s}
.rv-4{transition-delay:.36s}
@media (prefers-reduced-motion:reduce){.rv{opacity:1!important;transform:none!important;transition:none}}
/* Títulos de sección: revelado con máscara, línea por línea (se dispara con .rv.in) */
.section h2 .ml{display:block;overflow:hidden;padding:.05em .14em;margin:0 -.14em}
.section h2 .ml-i{display:block;transform:translateY(118%);transition:transform 1.05s var(--ease)}
.rv.in .ml-i{transform:none}
.rv.in .ml:nth-child(2) .ml-i{transition-delay:.1s}
.rv.in .ml:nth-child(3) .ml-i{transition-delay:.2s}
/* Eyebrows de sección: la línea se dibuja y el espaciado asienta */
.section .eyebrow{letter-spacing:.46em;transition:letter-spacing 1s var(--ease)}
.section .eyebrow:not(.center)::before{width:0;transition:width .9s var(--ease)}
.section .rv.in .eyebrow,.section .eyebrow.rv.in{letter-spacing:.32em}
.section .rv.in .eyebrow:not(.center)::before,.section .eyebrow.rv.in:not(.center)::before{width:34px}
@media (prefers-reduced-motion:reduce){
  .section h2 .ml-i{transform:none!important}
  .section .eyebrow{letter-spacing:.32em!important}
  .section .eyebrow::before{width:34px!important}
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(20px,4vw,46px);
  transition:background .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease);
}
.nav__logo{height:46px;width:auto;transition:height .5s var(--ease),filter .4s}
.nav__logo--dark{display:none}
.nav__links{display:flex;align-items:center;gap:30px;list-style:none;margin:0;padding:0}
.nav__links a{
  font-size:13.5px;letter-spacing:.04em;color:var(--crema);font-weight:300;
  position:relative;padding:4px 0;transition:color .35s;
}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;background:var(--oro);transition:width .4s var(--ease)}
.nav__links a:hover::after{width:100%}
.nav__cta{display:flex;align-items:center;gap:16px}
.nav.scrolled{background:rgba(247,241,232,.92);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--linea);padding-top:12px;padding-bottom:12px}
.nav.scrolled .nav__logo--white{display:none}
.nav.scrolled .nav__logo--dark{display:block}
.nav.scrolled .nav__logo{height:40px}
.nav.scrolled .nav__links a{color:var(--tinta)}
.nav.scrolled .nav__burger span{background:var(--tinta)}
.nav__burger{display:none;width:46px;height:46px;border:none;background:none;cursor:pointer;flex-direction:column;justify-content:center;align-items:flex-end;gap:5.5px;padding:11px;filter:drop-shadow(0 1px 2px rgba(10,8,6,.55))}
.nav__burger span{display:block;width:24px;height:2px;border-radius:2px;background:var(--crema);transition:.4s var(--ease)}
.nav__burger span:nth-child(2){width:18px}
.nav.scrolled .nav__burger{filter:none}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:70;background:var(--tinta);display:flex;flex-direction:column;
  padding:30px clamp(24px,7vw,40px);transform:translateX(100%);transition:transform .6s var(--ease);visibility:hidden;
  overflow-y:auto;-webkit-overflow-scrolling:touch}
.drawer.open{transform:none;visibility:visible}
/* con el menú abierto, ocultar el botón flotante para que no choque con el del menú */
.drawer.open ~ .wa-float{opacity:0;visibility:hidden;pointer-events:none}
.drawer__top,.drawer__foot{flex:none}
.drawer__top{display:flex;justify-content:space-between;align-items:center}
.drawer__close{background:none;border:none;color:var(--crema);font-size:40px;cursor:pointer;line-height:1;padding:6px;
  opacity:0;transform:rotate(-90deg) scale(.5);
  transition:transform .6s var(--ease),opacity .45s var(--ease),color .3s var(--ease)}
.drawer.open .drawer__close{opacity:1;transform:rotate(0) scale(1);transition-delay:.32s}
.drawer.open .drawer__close:hover{transform:rotate(90deg) scale(1.1);color:var(--oro);transition-delay:0s}
.drawer.open .drawer__close:active{transform:rotate(90deg) scale(.9);color:var(--oro);transition-delay:0s}
@media (prefers-reduced-motion:reduce){.drawer__close{opacity:1;transform:none;transition:color .3s}}
.drawer__links{list-style:none;margin:auto 0;padding:0;display:flex;flex-direction:column;gap:6px}
.drawer__links a{font-family:var(--serif);font-size:34px;color:var(--crema);padding:8px 0;display:block;font-weight:400}
.drawer__links a:active{color:var(--oro)}
.drawer__foot{display:flex;flex-direction:column;gap:14px}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;background:var(--tinta-2)}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media video,.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 28%}
.hero__media .v-desktop{display:block}
.hero__media .v-mobile{display:none}
.hero__scrim{position:absolute;inset:0;z-index:1;
  background:
   linear-gradient(180deg, rgba(19,16,12,.5) 0%, rgba(19,16,12,.06) 28%, rgba(19,16,12,.34) 58%, rgba(19,16,12,.9) 100%),
   linear-gradient(75deg, rgba(19,16,12,.72) 0%, rgba(19,16,12,.18) 50%, rgba(19,16,12,0) 78%);
}
.hero__inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;
  padding:0 28px clamp(54px,9vh,104px);color:var(--crema)}
.hero__content{max-width:660px}
.hero .eyebrow{color:rgba(247,241,232,.82)}
.hero h1{font-size:clamp(48px,8.4vw,108px);font-weight:400;color:var(--crema);letter-spacing:-.015em;margin-bottom:22px}
.hero h1 em{font-style:italic;color:#EAD9B6}
.hero__sub{font-family:var(--serif);font-size:clamp(19px,2.3vw,25px);font-weight:300;line-height:1.45;color:rgba(247,241,232,.9);max-width:540px;margin-bottom:34px}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px}
.hero__scroll{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:9px;color:rgba(247,241,232,.7);
  font-size:10.5px;letter-spacing:.3em;text-transform:uppercase}
.hero__scroll i{width:1px;height:42px;background:linear-gradient(var(--oro),transparent);position:relative;overflow:hidden}
.hero__scroll i::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--crema);animation:scrolldrop 2.4s var(--ease) infinite}
@keyframes scrolldrop{0%{top:-50%}60%,100%{top:100%}}
/* Hero: sombra para legibilidad + entrada escalonada del texto */
.hero .eyebrow,.hero__sub{text-shadow:0 1px 2px rgba(10,8,6,.5),0 2px 18px rgba(10,8,6,.45)}
.hero h1{text-shadow:0 1px 3px rgba(10,8,6,.6)}
/* el contenedor es solo el disparador */
.hero__content.rv{opacity:1;transform:none;transition:none}
/* eyebrow: fade + apertura de espaciado que asienta en .32em */
.hero .eyebrow{opacity:0;transform:translateY(12px);letter-spacing:.52em;
  transition:opacity .9s var(--ease),transform .9s var(--ease),letter-spacing 1.2s var(--ease)}
.hero__content.in .eyebrow{opacity:1;transform:none;letter-spacing:.32em;transition-delay:.05s}
/* título: revelado con máscara, línea por línea */
.hero h1 .h1-line{display:block;overflow:hidden;padding:.02em .14em;margin:0 -.14em}
.hero h1 .h1-line>span{display:block;transform:translateY(118%);transition:transform 1.15s var(--ease)}
.hero__content.in h1 .h1-line>span{transform:none}
.hero__content.in h1 .h1-line:nth-child(1)>span{transition-delay:.22s}
.hero__content.in h1 .h1-line:nth-child(2)>span{transition-delay:.38s}
/* subtítulo: blur-in */
.hero__sub{opacity:0;filter:blur(12px);transform:translateY(8px);
  transition:opacity 1s var(--ease),filter 1.1s var(--ease),transform 1s var(--ease)}
.hero__content.in .hero__sub{opacity:1;filter:blur(0);transform:none;transition-delay:.62s}
/* botones: fade + rise */
.hero__cta{opacity:0;transform:translateY(18px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.hero__content.in .hero__cta{opacity:1;transform:none;transition-delay:.92s}
@media (prefers-reduced-motion:reduce){
  .hero .eyebrow,.hero__sub,.hero__cta,.hero h1 .h1-line>span{opacity:1!important;transform:none!important;filter:none!important;letter-spacing:.32em;transition:none}
}

/* ============================================================
   INTRO + DATOS
   ============================================================ */
.intro{text-align:center;padding-bottom:clamp(72px,11vw,150px)}
.niveles{padding-top:0}
.intro__brand{font-size:clamp(30px,4.6vw,56px);font-weight:400;max-width:16ch;margin:0 auto;color:var(--tinta)}
.intro__brand em{font-style:italic;color:var(--rosa)}
.intro__note{max-width:52ch;margin:26px auto 0;color:var(--texto-mute)}
.datos{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:clamp(48px,7vw,80px);
  border-top:1px solid var(--linea);border-bottom:1px solid var(--linea)}
.dato{padding:34px 26px;text-align:center;position:relative}
.dato+.dato::before{content:"";position:absolute;left:0;top:22%;height:56%;width:1px;background:var(--linea)}
.dato__ic{color:var(--oro);margin:0 auto 12px;width:26px;height:26px}
.dato__k{font-family:var(--sans);font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--texto-mute);margin-bottom:7px}
.dato__v{font-family:var(--serif);font-size:clamp(20px,2.4vw,27px);color:var(--tinta);line-height:1.2}
.dato__v small{display:block;font-family:var(--sans);font-size:13px;color:var(--texto-mute);letter-spacing:.01em;margin-top:4px;font-weight:300}

/* ============================================================
   NIVELES
   ============================================================ */
.niveles__head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:clamp(40px,5vw,64px)}
.niveles__head h2{font-size:clamp(34px,5vw,60px);max-width:14ch}
.niveles__head .eyebrow{margin-bottom:30px}
.niveles__head p{max-width:38ch;color:var(--texto-mute);margin:0}
.niveles__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,30px)}
.nivel{background:var(--crema-2);overflow:hidden;display:flex;flex-direction:column;
  border:1px solid rgba(28,24,19,.06);transition:transform .6s var(--ease),box-shadow .6s var(--ease)}
.nivel:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(28,24,19,.5)}
.nivel__img{position:relative;aspect-ratio:4/5;overflow:hidden}
.nivel__img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.nivel:hover .nivel__img img{transform:scale(1.05)}
.nivel__age{position:absolute;top:16px;left:16px;background:rgba(247,241,232,.93);color:var(--tinta);
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;padding:8px 14px;border-radius:999px}
.nivel__body{padding:26px 26px 30px;display:flex;flex-direction:column;flex:1}
.nivel__body h3{font-size:27px;margin-bottom:6px;color:var(--tinta)}
.nivel__edad{font-family:var(--sans);font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--rosa);margin-bottom:14px}
.nivel__body p{font-size:15px;line-height:1.6;color:var(--texto-mute);margin-bottom:20px}
.nivel__link{margin-top:auto;display:inline-flex;align-items:center;gap:9px;font-size:13px;letter-spacing:.04em;color:var(--tinta);
  text-transform:uppercase}
.nivel__link svg{width:15px;transition:transform .4s var(--ease)}
.nivel:hover .nivel__link svg{transform:translateX(5px)}

/* ============================================================
   QUIZ
   ============================================================ */
.quiz{background:var(--crema-2);position:relative;overflow:hidden}
.quiz::before,.quiz::after{content:"";position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;pointer-events:none}
.quiz::before{width:380px;height:380px;background:rgba(168,120,110,.22);top:-120px;right:-90px}
.quiz::after{width:340px;height:340px;background:rgba(183,154,102,.2);bottom:-140px;left:-110px}
.quiz__card{max-width:760px;margin:0 auto;background:var(--crema);border:1px solid var(--linea);
  border-radius:6px;box-shadow:0 50px 90px -60px rgba(28,24,19,.55);position:relative;z-index:1;
  padding:clamp(30px,5vw,58px);min-height:440px;display:flex;flex-direction:column}
.quiz__progress{display:flex;gap:8px;margin-bottom:28px;justify-content:center}
.quiz__progress span{width:34px;height:3px;border-radius:2px;background:var(--linea);transition:background .5s}
.quiz__progress span.on{background:var(--rosa)}
.quiz__step{display:none;flex-direction:column;flex:1;animation:qfade .55s var(--ease)}
.quiz__step.active{display:flex}
@keyframes qfade{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.quiz__count{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--rosa);text-align:center;margin-bottom:14px}
.quiz__q{font-family:var(--serif);font-size:clamp(26px,3.6vw,40px);text-align:center;color:var(--tinta);margin-bottom:30px;line-height:1.1}
.quiz__opts{display:flex;flex-direction:column;gap:13px;max-width:460px;margin:0 auto;width:100%}
.quiz__opt{display:flex;align-items:center;gap:16px;width:100%;text-align:left;cursor:pointer;
  background:var(--crema);border:1px solid var(--linea);border-radius:999px;padding:17px 24px;
  font-family:var(--sans);font-size:16px;color:var(--texto);transition:all .35s var(--ease);min-height:60px}
.quiz__opt:hover{border-color:var(--rosa);background:#fff;transform:translateX(4px)}
.quiz__opt b{width:30px;height:30px;border-radius:50%;border:1px solid var(--rosa);color:var(--rosa);
  display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:16px;font-weight:500;flex:none;transition:all .35s}
.quiz__opt:hover b{background:var(--rosa);color:#fff}
.quiz__back{align-self:center;margin-top:22px;background:none;border:none;color:var(--texto-mute);cursor:pointer;
  font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;padding:8px}
.quiz__back:hover{color:var(--tinta)}

/* quiz result */
.quiz__result{display:none;flex-direction:column;align-items:center;text-align:center;flex:1;animation:qfade .6s var(--ease)}
.quiz__result.active{display:flex}
.quiz__rmark{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--rosa);margin-bottom:8px}
.quiz__rname{font-family:var(--serif);font-size:clamp(34px,5.4vw,56px);color:var(--tinta);margin-bottom:6px;line-height:1.04}
.quiz__redad{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--oro);margin-bottom:20px}
.quiz__rdesc{max-width:46ch;color:var(--texto-mute);margin-bottom:22px}
.quiz__rhoras{background:var(--crema-2);border:1px solid var(--linea);border-radius:4px;padding:16px 22px;margin-bottom:26px;
  font-size:14.5px;color:var(--texto)}
.quiz__rhoras strong{color:var(--tinta);font-weight:500}
.quiz__ractions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}

/* ============================================================
   DISCIPLINA — B&W wow
   ============================================================ */
.disciplina{position:relative;background:var(--tinta-2);color:var(--crema);overflow:hidden;
  min-height:96vh;display:flex;align-items:center}
.disciplina__bg{position:absolute;inset:0;z-index:0}
.disciplina__bg img{width:100%;height:118%;object-fit:cover;filter:grayscale(1) contrast(1.06) brightness(.62)}
.disciplina__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,8,6,.7),rgba(10,8,6,.25) 60%,rgba(10,8,6,.55))}
.disciplina__inner{position:relative;z-index:1;width:100%;max-width:var(--maxw);margin:0 auto;padding:90px 28px;text-align:center}
.disciplina__lines{font-family:var(--serif);font-weight:300;font-size:clamp(30px,5.2vw,66px);line-height:1.18;letter-spacing:.005em}
.disciplina__lines .ln{display:block;opacity:0;transform:translateY(30px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}
.disciplina__lines.in .ln{opacity:1;transform:none}
.disciplina__lines.in .ln:nth-child(2){transition-delay:.35s}
.disciplina__lines.in .ln:nth-child(3){transition-delay:.7s}
.disciplina__lines em{font-style:italic;color:#E6CF9F}
.disciplina__sig{margin-top:34px;font-family:var(--sans);font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:rgba(247,241,232,.55);opacity:0;transition:opacity 1s ease 1.1s}
.disciplina__lines.in + .disciplina__sig{opacity:1}

/* ============================================================
   ACERCA DE — Historia + Directora (B&W)
   ============================================================ */
.acerca{background:var(--tinta);color:var(--crema)}
.acerca .eyebrow{color:var(--oro)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,84px);align-items:center}
.split + .split{margin-top:clamp(70px,9vw,130px)}
.split__media{position:relative}
.split__media img{width:100%;filter:grayscale(1) contrast(1.04);border:1px solid rgba(247,241,232,.1)}
.split__media .tag{position:absolute;bottom:-1px;left:-1px;background:var(--tinta);color:var(--oro);
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;padding:11px 18px;border:1px solid rgba(247,241,232,.14)}
.split--rev .split__media{order:2}
.split h2{font-size:clamp(32px,4.4vw,54px);color:var(--crema);margin-bottom:20px}
.split h2 em{font-style:italic;color:#E6CF9F}
.split p{color:rgba(247,241,232,.74);font-size:16px;line-height:1.72;margin-bottom:1.1em}
.split .lead-q{font-family:var(--serif);font-size:22px;font-style:italic;color:rgba(247,241,232,.92);line-height:1.4;margin-bottom:22px}
.split .credentials{list-style:none;padding:0;margin:22px 0 0;display:flex;flex-direction:column;gap:11px}
.split .credentials li{display:flex;gap:13px;align-items:flex-start;font-size:14.5px;color:rgba(247,241,232,.8)}
.split .credentials svg{width:17px;color:var(--oro);flex:none;margin-top:3px}
.split .name{font-family:var(--serif);font-size:15px;letter-spacing:.04em;color:var(--oro);text-transform:uppercase;margin-bottom:10px;display:block}

/* ============================================================
   GALERÍA
   ============================================================ */
.galeria__head{text-align:center;margin-bottom:clamp(36px,5vw,56px)}
.galeria__head h2{font-size:clamp(34px,5vw,60px);color:var(--tinta)}
.galeria__grid{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:11vw;gap:14px}
.gitem{position:relative;overflow:hidden;cursor:pointer;background:var(--crema-2)}
.gitem img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.gitem::after{content:"";position:absolute;inset:0;background:rgba(28,24,19,0);transition:background .5s}
.gitem:hover img{transform:scale(1.06)}
.gitem:hover::after{background:rgba(28,24,19,.12)}
.gitem .plus{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.7);z-index:2;
  width:46px;height:46px;border:1px solid rgba(247,241,232,.85);border-radius:50%;color:#fff;
  display:flex;align-items:center;justify-content:center;opacity:0;transition:.5s var(--ease)}
.gitem:hover .plus{opacity:1;transform:translate(-50%,-50%) scale(1)}
.g-a{grid-column:span 5;grid-row:span 3}
.g-b{grid-column:span 4;grid-row:span 2}
.g-c{grid-column:span 3;grid-row:span 3}
.g-d{grid-column:span 4;grid-row:span 2}
.g-e{grid-column:span 4;grid-row:span 2}
.g-f{grid-column:span 4;grid-row:span 2}

/* lightbox */
.lb{position:fixed;inset:0;z-index:90;background:rgba(13,10,7,.94);display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .45s var(--ease);padding:24px}
.lb.open{opacity:1;visibility:visible}
.lb img{max-width:90vw;max-height:86vh;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,.6);
  transform:scale(.95);transition:transform .5s var(--ease)}
.lb.open img{transform:scale(1)}
.lb__close,.lb__nav{position:absolute;background:none;border:1px solid rgba(247,241,232,.3);color:var(--crema);
  cursor:pointer;border-radius:50%;width:50px;height:50px;display:flex;align-items:center;justify-content:center;transition:.35s}
.lb__close:hover,.lb__nav:hover{background:rgba(247,241,232,.14)}
.lb__close{top:24px;right:24px;font-size:24px}
.lb__nav{top:50%;transform:translateY(-50%)}
.lb__prev{left:24px}.lb__next{right:24px}

/* ============================================================
   INSTAGRAM
   ============================================================ */
.insta{text-align:center;background:var(--crema);padding-top:0}
.insta__handle{font-family:var(--serif);font-size:clamp(26px,3.4vw,38px);color:var(--tinta);margin:6px 0 28px}
.insta__handle a{color:var(--rosa)}
.insta__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:30px}
.insta__cell{aspect-ratio:1;overflow:hidden;position:relative;background:var(--crema-2)}
.insta__cell img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.insta__cell:hover img{transform:scale(1.07)}
.insta__cell::after{content:"";position:absolute;inset:0;background:rgba(28,24,19,0);transition:.4s}
.insta__cell:hover::after{background:rgba(28,24,19,.16)}

/* ============================================================
   BLOG teaser
   ============================================================ */
.blog{background:var(--crema-2)}
.blog__head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;margin-bottom:clamp(36px,5vw,54px)}
.blog__head h2{font-size:clamp(34px,5vw,58px);color:var(--tinta)}
.blog__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,34px)}
.post{display:flex;flex-direction:column;background:var(--crema);border:1px solid rgba(28,24,19,.07);overflow:hidden;
  transition:transform .55s var(--ease),box-shadow .55s var(--ease)}
.post:hover{transform:translateY(-6px);box-shadow:0 30px 60px -36px rgba(28,24,19,.5)}
.post__img{aspect-ratio:16/10;overflow:hidden}
.post__img img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.post:hover .post__img img{transform:scale(1.05)}
.post__body{padding:24px 26px 28px;display:flex;flex-direction:column;flex:1}
.post__meta{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--rosa);margin-bottom:12px}
.post__body h3{font-size:23px;line-height:1.16;color:var(--tinta);margin-bottom:10px}
.post__body p{font-size:14.5px;color:var(--texto-mute);margin-bottom:18px}
.post__more{margin-top:auto;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--tinta);display:inline-flex;gap:8px;align-items:center}
.post__more svg{width:15px;transition:transform .4s var(--ease)}
.post:hover .post__more svg{transform:translateX(5px)}

/* ============================================================
   CONTACTO
   ============================================================ */
.contacto{background:var(--tinta);color:var(--crema)}
.contacto__grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(40px,6vw,90px)}
.contacto h2{font-size:clamp(34px,5vw,58px);color:var(--crema);margin-bottom:18px}
.contacto h2 em{font-style:italic;color:#E6CF9F}
.contacto__sub{color:rgba(247,241,232,.72);max-width:42ch;margin-bottom:34px}
.cinfo{display:flex;flex-direction:column;gap:22px;margin-bottom:34px}
.cinfo__row{display:flex;gap:16px;align-items:flex-start}
.cinfo__ic{width:40px;height:40px;border:1px solid rgba(247,241,232,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--oro);flex:none}
.cinfo__ic svg{width:18px}
.cinfo__k{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(247,241,232,.5);margin-bottom:3px}
.cinfo__v{font-size:16px;color:var(--crema);line-height:1.5}
.cinfo__v a:hover{color:var(--oro)}
.horarios{border:1px solid rgba(247,241,232,.16);border-radius:4px;padding:22px 24px}
.horarios h4{font-family:var(--sans);font-weight:400;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--oro);margin-bottom:14px}
.horarios dl{margin:0;display:flex;flex-direction:column;gap:10px}
.horarios .hrow{display:flex;justify-content:space-between;gap:16px;font-size:14.5px;border-bottom:1px dashed rgba(247,241,232,.12);padding-bottom:9px}
.horarios .hrow:last-child{border-bottom:none;padding-bottom:0}
.horarios dt{color:rgba(247,241,232,.72)}
.horarios dd{margin:0;color:var(--crema);font-weight:400}

.form{background:rgba(247,241,232,.04);border:1px solid rgba(247,241,232,.14);border-radius:6px;padding:clamp(26px,3.4vw,38px)}
.form h3{font-family:var(--serif);font-size:26px;color:var(--crema);margin-bottom:6px}
.form p.fhint{font-size:14px;color:rgba(247,241,232,.6);margin-bottom:24px}
.field{margin-bottom:18px}
.field label{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(247,241,232,.6);margin-bottom:8px}
.field input,.field textarea{width:100%;background:rgba(247,241,232,.06);border:1px solid rgba(247,241,232,.18);
  border-radius:4px;padding:14px 16px;color:var(--crema);font-family:var(--sans);font-size:15px;transition:border .3s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--oro)}
.field textarea{resize:vertical;min-height:110px}
.form .btn{width:100%;justify-content:center;margin-top:6px}
.contacto__map{margin-top:clamp(48px,6vw,72px);border:1px solid rgba(247,241,232,.16);border-radius:6px;overflow:hidden;height:340px}
.contacto__map iframe{width:100%;height:100%;border:0;filter:grayscale(.4) contrast(1.05)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--tinta-2);color:rgba(247,241,232,.7);padding:64px 0 30px}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:44px;border-bottom:1px solid rgba(247,241,232,.12)}
.footer__logo{height:54px;width:auto;margin-bottom:20px}
.footer__top p{font-size:14px;line-height:1.7;max-width:34ch;margin:0}
.footer__col h5{font-family:var(--sans);font-weight:400;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--oro);margin:0 0 16px}
.footer__col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.footer__col a{font-size:14.5px;color:rgba(247,241,232,.72);transition:color .3s}
.footer__col a:hover{color:var(--crema)}
.footer__social{display:flex;gap:12px;margin-top:6px}
.footer__social a{width:40px;height:40px;border:1px solid rgba(247,241,232,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--crema);transition:.35s}
.footer__social a:hover{background:var(--oro);color:var(--tinta);border-color:var(--oro)}
.footer__social svg{width:18px}
.footer__bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:24px;font-size:12.5px;color:rgba(247,241,232,.5)}

/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.wa-float{position:fixed;right:20px;bottom:20px;z-index:80;display:flex;align-items:center;gap:0;
  background:#1FA855;color:#fff;border-radius:999px;padding:0;height:60px;width:60px;overflow:hidden;
  box-shadow:0 14px 34px -8px rgba(31,168,85,.6);transition:width .5s var(--ease),box-shadow .4s,opacity .3s var(--ease),visibility .3s;white-space:nowrap}
.wa-float svg{width:30px;height:30px;flex:none;margin:0 15px}
.wa-float span{font-size:14.5px;font-weight:400;padding-right:24px;opacity:0;transition:opacity .4s}
.wa-float:hover{width:232px;box-shadow:0 18px 40px -8px rgba(31,168,85,.7)}
.wa-float:hover span{opacity:1}
.wa-float::after{content:"";position:absolute;inset:0;border-radius:999px;border:2px solid #1FA855;animation:wapulse 2.6s var(--ease) infinite;pointer-events:none}
@keyframes wapulse{0%{transform:scale(1);opacity:.7}70%,100%{transform:scale(1.5);opacity:0}}
@media (prefers-reduced-motion:reduce){.wa-float::after{display:none}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .galeria__grid{grid-auto-rows:15vw}
}
@media (max-width:900px){
  .nav__links,.nav__cta .btn{display:none}
  .nav__burger{display:flex}
  .niveles__grid,.blog__grid{grid-template-columns:1fr;max-width:460px;margin-left:auto;margin-right:auto}
  .split{grid-template-columns:1fr;gap:28px}
  .split--rev .split__media{order:0}
  .contacto__grid{grid-template-columns:1fr;gap:44px}
  .insta__grid{grid-template-columns:repeat(3,1fr)}
  .footer__top{grid-template-columns:1fr;gap:32px}
}
@media (max-width:680px){
  body{font-size:16px}
  .hero__media .v-desktop{display:none}
  .hero__media .v-mobile{display:block}
  .hero__media video,.hero__media img{object-position:center 22%}
  .hero__scroll{display:none}
  /* Hero móvil: compactar y bajar el texto para no tapar el rostro */
  .hero__inner{padding-bottom:34px}
  .hero .eyebrow{margin-bottom:12px}
  .hero h1{font-size:42px;line-height:1.06;margin-bottom:14px}
  .hero__sub{font-size:17px;line-height:1.4;margin-bottom:22px}
  /* Menú lateral: enlaces más compactos y con aire arriba/abajo para que quepan y hagan scroll */
  .drawer__links{margin:20px 0;gap:0}
  .drawer__links a{font-size:25px;padding:8px 0}
  .datos{grid-template-columns:1fr}
  .dato+.dato::before{display:none}
  .dato{border-top:1px solid var(--linea)}
  .dato:first-child{border-top:none}
  .galeria__grid{display:flex;flex-direction:column;gap:12px}
  .galeria__grid .gitem{aspect-ratio:4/3;grid-column:auto;grid-row:auto}
  .galeria__grid .g-c{aspect-ratio:3/4}
  .lb__nav{top:auto;bottom:24px;transform:none}
  .lb__prev{left:calc(50% - 60px)}.lb__next{right:calc(50% - 60px)}
  .wrap{padding:0 20px}
}

/* Disciplina: en desktop, subir el encuadre para no cortar el rostro (móvil queda igual) */
@media (min-width:901px){
  .disciplina__bg img{object-position:center 35%}
}
