.container{max-width:var(--container-max);margin-inline:auto;padding-inline:var(--container-pad)}
.navbar{position:fixed;top:0;left:0;right:0;z-index:100;border-bottom:1px solid transparent;background:transparent;transition:background var(--transition-slow),border-color var(--transition-slow)}
.navbar.navbar--solid{background:rgba(247,246,248,.97);border-color:rgba(0,0,0,.10);backdrop-filter:blur(12px)}
.dark .navbar.navbar--solid{background:rgba(247,246,248,.97);border-color:rgba(0,0,0,.10)}
.navbar__inner{display:flex;align-items:center;justify-content:space-between;height:var(--navbar-height)}
.navbar__logo{height:44px;width:auto}
.navbar__links{display:none;align-items:center;gap:var(--space-5)}
@media(min-width:900px){.navbar__links{display:flex}}
.navbar__link{font-size:var(--font-size-sm);font-weight:600;color:rgba(255,255,255,.90);letter-spacing:.02em;transition:color var(--transition-fast);padding-block:var(--space-1);position:relative;text-shadow:0 1px 4px rgba(0,0,0,.4)}
.navbar__link::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--color-accent);transition:width var(--transition-base);border-radius:var(--radius-full)}
.navbar__link:hover{color:var(--color-accent)}.navbar__link:hover::after{width:100%}
.navbar--solid .navbar__link{color:#1a1a2e;text-shadow:none}
.navbar--solid .navbar__link:hover{color:var(--color-primary)}
.navbar--solid .navbar__link::after{background:var(--color-primary)}
.dark .navbar--solid .navbar__link{color:#1a1a2e;text-shadow:none}
.dark .navbar--solid .navbar__link:hover{color:var(--color-primary)}
.navbar__actions{display:flex;align-items:center;gap:var(--space-3)}
.hamburger{display:flex}
@media(min-width:900px){.hamburger{display:none}}
.mobile-menu{border-top:1px solid var(--color-border);background:var(--color-bg-alt);padding:var(--space-4) var(--container-pad) var(--space-6)}
.mobile-menu[hidden]{display:none}
.mobile-menu ul{display:flex;flex-direction:column;gap:var(--space-1)}
.mobile-menu__link{display:block;padding:var(--space-3) var(--space-2);font-weight:600;color:var(--color-text);border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast)}
.mobile-menu__link:hover{color:var(--color-primary);background:var(--color-primary-10)}

/* HERO */
.hero{position:relative;width:100%;height:100vh;min-height:600px;overflow:hidden;display:flex;align-items:center;justify-content:center;will-change:opacity}
.hero__video-wrap{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:#0f0a1a}
.hero__overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(to bottom,rgba(0,0,0,.75) 0%,rgba(0,0,0,.55) 50%,rgba(15,10,26,.85) 100%)}
.hero__content{position:relative;z-index:2;text-align:center;padding-block:var(--space-24);padding-top:calc(var(--navbar-height) + var(--space-6))}
.hero__logo-big{display:block;margin:0 auto var(--space-6);width:clamp(200px,38vw,400px);height:auto;filter:drop-shadow(0 4px 24px rgba(0,0,0,.40))}
.hero__badge{display:inline-flex;align-items:center;gap:var(--space-2);background:rgba(255,255,255,.12);backdrop-filter:blur(8px);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);border:1px solid rgba(255,255,255,.20);margin-bottom:var(--space-8);color:#fff;font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.12em}
.hero__badge .material-symbols-outlined{font-size:1rem;color:var(--color-accent)}
.hero__title{font-size:var(--font-size-hero);font-weight:900;color:#fff;line-height:1.1;letter-spacing:-.02em;margin-bottom:var(--space-10);text-shadow:0 2px 20px rgba(0,0,0,.5)}
.hero__title--accent{color:var(--color-accent);font-style:italic}
.hero__actions{display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}
@media(min-width:480px){.hero__actions{flex-direction:row;justify-content:center}}
.hero__scroll-hint{position:absolute;bottom:var(--space-8);left:50%;animation:bounce-y 1.8s ease-in-out infinite;z-index:2;color:rgba(255,255,255,.80)}
.hero__scroll-hint .material-symbols-outlined{font-size:2.5rem}

/* SECCIONES */
.section{padding-block:clamp(var(--space-16),8vw,var(--space-32))}
.section--primary{background:var(--color-primary);color:#fff}
.section--dark{background:#0f0a1a;color:#fff}
.section--muted{background:var(--color-bg-muted);position:relative;overflow:hidden}
.section--alt{background:var(--color-bg-alt)}
.section__header{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-12)}
.section__header--centered{align-items:center;text-align:center}
.section__label{display:block;font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--color-primary);margin-bottom:var(--space-2)}
.section__label--accent{color:var(--color-accent)}
.section__label--white{color:rgba(255,255,255,.70)}
.dark .section__label{color:#c084fc}

/* Jerarquía tipográfica de secciones */
.section__title{font-size:clamp(var(--font-size-3xl),4.5vw,3rem);font-weight:900;line-height:1.05;letter-spacing:-.03em}
.section__title--light{color:#fff}
.section__title--centered{text-align:center}
.subsection__title{font-size:clamp(var(--font-size-2xl),3vw,var(--font-size-3xl));font-weight:800;line-height:1.1;letter-spacing:-.02em}
.section__subtitle{font-size:var(--font-size-lg);color:var(--color-text-muted);margin-top:var(--space-4);line-height:1.7;max-width:65ch}
.section__subtitle--light{color:rgba(255,255,255,.80)}
.section__subtitle--centered{text-align:center;margin-inline:auto}

/* INSTRUMENTOS GRID */
.instruments-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}
@media(min-width:480px){.instruments-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:768px){.instruments-grid{grid-template-columns:repeat(4,1fr)}}

/* CANTO */
.canto-layout{display:grid;grid-template-columns:1fr;gap:var(--space-12);align-items:center}
@media(min-width:1024px){.canto-layout{grid-template-columns:1fr 1fr}}
.canto-layout__image{position:relative;width:100%}
.canto-layout__frame{position:absolute;inset:-1rem;border:2px solid var(--color-accent);border-radius:var(--radius-2xl);translate:1rem 1rem;pointer-events:none}
.canto-layout__photo{border-radius:var(--radius-2xl);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow-xl)}
.canto-layout__photo img{width:100%;height:100%;object-fit:cover;filter:grayscale(1);transition:filter var(--transition-slow)}
.canto-layout__photo:hover img{filter:grayscale(0)}
.canto-layout__content{display:flex;flex-direction:column;gap:var(--space-6);width:100%}

/* DANCE GRID */
.dance-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}
@media(min-width:640px){.dance-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.dance-grid{grid-template-columns:repeat(4,1fr)}}
.dance-card{position:relative;aspect-ratio:4/3;border-radius:var(--radius-2xl);overflow:hidden;cursor:pointer}
.dance-card__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow);z-index:0}
.dance-card:hover .dance-card__img{transform:scale(1.06)}
.dance-card__bg{position:absolute;inset:0;z-index:0;background:var(--color-primary-20)}
.dance-card__overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(60,0,120,.85) 0%,rgba(0,0,0,.05) 60%,transparent 100%)}
.dance-card__label{position:absolute;bottom:var(--space-5);left:var(--space-5);z-index:2;color:#fff;font-size:var(--font-size-base);font-weight:800;text-shadow:0 2px 8px rgba(0,0,0,.5)}

/* TEATRO */
.teatro-layout{display:grid;grid-template-columns:1fr;gap:var(--space-12);align-items:center}
@media(min-width:1024px){.teatro-layout{grid-template-columns:1fr 1fr}}
.teatro-layout__content{display:flex;flex-direction:column;gap:var(--space-6)}
.teatro-layout__photos{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}
.photo-col{display:flex;flex-direction:column;gap:var(--space-3)}
.photo-col--offset{padding-top:var(--space-8)}
.photo-frame{border-radius:var(--radius-xl);overflow:hidden;background:var(--color-bg-muted)}
.photo-frame img{width:100%;height:100%;object-fit:cover}
.photo-frame--short{height:10rem}.photo-frame--med{height:13rem}.photo-frame--tall{height:17rem}

/* QUÉ ES */
.que-es-layout{display:grid;grid-template-columns:1fr;gap:var(--space-12);align-items:center}
@media(min-width:1024px){.que-es-layout{grid-template-columns:3fr 2fr}}
.que-es__text{display:flex;flex-direction:column;gap:var(--space-5)}
.que-es__text p{font-size:var(--font-size-lg);line-height:1.8;color:var(--color-text-muted)}
.que-es__image{border-radius:var(--radius-2xl);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow-xl)}
.que-es__image img{width:100%;height:100%;object-fit:cover}

/* INFANCIAS */
.infancias-grid{display:grid;grid-template-columns:1fr;gap:var(--space-8)}
@media(min-width:640px){.infancias-grid{grid-template-columns:repeat(3,1fr)}}
.infancia-card{background:var(--color-surface);border-radius:var(--radius-2xl);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);overflow:hidden;transition:transform var(--transition-base),box-shadow var(--transition-base)}
.infancia-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.infancia-card__header{background:var(--color-primary);padding:var(--space-6);text-align:center}
.infancia-card__icon{font-size:2.5rem;color:rgba(255,255,255,.90);display:block;margin-bottom:var(--space-2)}
.infancia-card__title{font-size:var(--font-size-lg);font-weight:900;color:#fff}
.infancia-card__body{padding:var(--space-6)}
.infancia-card__ages{display:inline-flex;align-items:center;gap:var(--space-2);background:var(--color-primary-10);color:var(--color-primary);border-radius:var(--radius-full);padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:700;margin-bottom:var(--space-3)}
.infancia-card__desc{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.7}
.infancia-card__list{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-3)}
.infancia-card__item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-muted)}
.infancia-card__item::before{content:'';width:.4rem;height:.4rem;border-radius:var(--radius-full);background:var(--color-accent);flex-shrink:0}

/* GALERÍA */
.galeria-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}
@media(min-width:640px){.galeria-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.galeria-grid{grid-template-columns:repeat(4,1fr)}}
.galeria-item{border-radius:var(--radius-xl);overflow:hidden;aspect-ratio:4/3;background:var(--color-bg-muted)}
.galeria-item img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}
.galeria-item:hover img{transform:scale(1.05)}

/* CONTACTO */
.contacto-layout{display:grid;grid-template-columns:1fr;gap:var(--space-16);align-items:start}
@media(min-width:1024px){.contacto-layout{grid-template-columns:1fr 1fr}}
.contacto-layout__info{display:flex;flex-direction:column;gap:var(--space-6)}
.contacto-layout__map{height:500px;border-radius:var(--radius-2xl);overflow:hidden;box-shadow:var(--shadow-xl);border:6px solid var(--color-surface);outline:1px solid var(--color-border)}
.blob{position:absolute;right:-6rem;top:-6rem;width:24rem;height:24rem;background:var(--color-primary-10);border-radius:var(--radius-full);filter:blur(64px);pointer-events:none}

/* GRILLA INSTRUMENTOS (sprite) */
.instrumentos-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}
@media(min-width:640px){.instrumentos-grid{grid-template-columns:repeat(4,1fr)}}

/* DANCE GRID actualizada — 4 col en desktop */
.dance-grid-v2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}
@media(min-width:768px){.dance-grid-v2{grid-template-columns:repeat(3,1fr)}}

/* Card "Y muchas más" */
.dance-card--more{
  background:linear-gradient(135deg,var(--color-primary-10),var(--color-accent-10));
  border:2px dashed var(--color-primary);
  border-radius:var(--radius-2xl);
  aspect-ratio:4/3;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:var(--space-3);
  cursor:pointer;
  transition:background var(--transition-base),transform var(--transition-base);
}
.dance-card--more:hover{background:var(--color-primary-10);transform:translateY(-4px)}
.dance-card--more p{font-size:var(--font-size-xl);font-weight:900;color:var(--color-primary);text-align:center;padding:var(--space-4)}

/* Teatro show photos grid */
.teatro-show-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}
@media(min-width:768px){.teatro-show-grid{grid-template-columns:repeat(2,1fr)}}
.teatro-show-item{border-radius:var(--radius-2xl);overflow:hidden;aspect-ratio:16/10;background:var(--color-bg-muted)}
.teatro-show-item img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}
.teatro-show-item:hover img{transform:scale(1.04)}

/* LOGO HERO */
.hero__logo-big{display:block;margin:0 auto var(--space-6);width:clamp(220px,40vw,420px);height:auto;filter:drop-shadow(0 4px 24px rgba(0,0,0,.40))}
