/* =========================================================
   ARA · La Princesa de los Niños
   Sistema de diseño — tema claro candy, mundo de corazones
   ========================================================= */

/* ---------- Fuentes auto-alojadas ---------- */
@font-face{font-family:"Fredoka";src:url("../assets/fonts/fredoka-400.woff2") format("woff2");font-weight:400;font-display:swap;}
@font-face{font-family:"Fredoka";src:url("../assets/fonts/fredoka-500.woff2") format("woff2");font-weight:500;font-display:swap;}
@font-face{font-family:"Fredoka";src:url("../assets/fonts/fredoka-600.woff2") format("woff2");font-weight:600;font-display:swap;}
@font-face{font-family:"Fredoka";src:url("../assets/fonts/fredoka-700.woff2") format("woff2");font-weight:700;font-display:swap;}
@font-face{font-family:"Nunito";src:url("../assets/fonts/nunito-400.woff2") format("woff2");font-weight:400;font-display:swap;}
@font-face{font-family:"Nunito";src:url("../assets/fonts/nunito-600.woff2") format("woff2");font-weight:600;font-display:swap;}
@font-face{font-family:"Nunito";src:url("../assets/fonts/nunito-700.woff2") format("woff2");font-weight:700;font-display:swap;}
@font-face{font-family:"Nunito";src:url("../assets/fonts/nunito-800.woff2") format("woff2");font-weight:800;font-display:swap;}

/* ---------- Tokens ---------- */
:root{
  /* paleta (del vestuario de Ara) */
  --red:#ff335a;        --red-deep:#c8143b;   --red-soft:#ffd9e1;
  --turq:#15c2c9;       --turq-deep:#0f9aa0;  --turq-soft:#c6f3f4;
  --sun:#ffc83d;        --sun-soft:#ffeec2;
  --pink:#ff8fbe;       --pink-soft:#ffe1ee;
  --sky:#6cc9ff;        --sky-soft:#dcf1ff;
  --cream:#fff8f1;      --cream-2:#fff1f5;     --sky-bg:#eef9ff;
  --ink:#2c2150;        --ink-soft:#6a6190;
  --white:#ffffff;

  /* tipografía */
  --font-display:"Fredoka",system-ui,sans-serif;
  --font-body:"Nunito",system-ui,sans-serif;

  /* radios (sistema suave, botones pill) */
  --r-sm:16px; --r-md:24px; --r-lg:36px; --r-xl:48px; --r-pill:999px;

  /* sombras tintadas (tono uva/rosa, nunca negro puro) */
  --sh-sm:0 4px 14px -6px rgba(44,33,80,.20);
  --sh-md:0 14px 34px -12px rgba(44,33,80,.24);
  --sh-lg:0 30px 70px -22px rgba(44,33,80,.30);
  --sh-red:0 18px 40px -14px rgba(232,30,72,.45);
  --sh-turq:0 18px 40px -14px rgba(15,154,160,.42);

  /* easing */
  --ease:cubic-bezier(.16,1,.3,1);
  --bounce:cubic-bezier(.34,1.56,.64,1);

  /* layout */
  --maxw:1240px;
  --pad:clamp(1.2rem,5vw,4rem);

  /* z-index */
  --z-ambient:1; --z-base:2; --z-nav:50; --z-burst:60; --z-pre:100;
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
html.lenis{height:auto;}
.lenis.lenis-smooth{scroll-behavior:auto !important;}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain;}
.lenis.lenis-stopped{overflow:clip;}

body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  overflow-x:clip;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}
ul,ol{list-style:none;}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none;}
:focus-visible{outline:3px solid var(--turq);outline-offset:3px;border-radius:6px;}

.ic{width:1em;height:1em;display:inline-block;fill:currentColor;vertical-align:middle;}
.ic--inline{width:.95em;height:.95em;fill:var(--red);}

/* ---------- Tipografía utilitaria ---------- */
.h-section{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(2rem,5.2vw,3.6rem);
  line-height:1.04;
  letter-spacing:-.01em;
  color:var(--ink);
}
.eyebrow{
  display:inline-flex;align-items:center;gap:.45em;
  font-family:var(--font-display);font-weight:600;
  font-size:.95rem;
  color:var(--red-deep);
  background:var(--red-soft);
  padding:.4em .9em;border-radius:var(--r-pill);
  width:fit-content;
}
.eyebrow .ic{font-size:1.05em;}
.eyebrow--hero{color:var(--red-deep);background:rgba(255,255,255,.78);backdrop-filter:blur(6px);box-shadow:var(--sh-sm);}

/* ---------- Botones ---------- */
.btn{
  --bg:var(--ink);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--font-display);font-weight:600;font-size:1.05rem;
  line-height:1;white-space:nowrap;
  padding:.95em 1.6em;border-radius:var(--r-pill);
  background:var(--bg);color:var(--fg);
  box-shadow:var(--sh-md);
  transition:transform .28s var(--bounce),box-shadow .35s var(--ease),background .25s;
  will-change:transform;
}
.btn .ic{font-size:1.15em;}
@media (hover:hover){.btn:hover{transform:translateY(-3px) scale(1.03);}}
.btn:active{transform:translateY(0) scale(.96);transition-duration:.11s;}
.btn--primary{--bg:linear-gradient(135deg,#dd1646 0%,#b00f35 100%);--fg:#fff;box-shadow:var(--sh-red);}
.btn--ghost{--bg:rgba(255,255,255,.82);--fg:var(--ink);box-shadow:var(--sh-sm);border:2px solid var(--turq);backdrop-filter:blur(6px);}
.btn--ghost:hover{--bg:#fff;}
.btn--mini{padding:.6em 1.1em;font-size:.98rem;--bg:linear-gradient(135deg,#dd1646,#b00f35);--fg:#fff;box-shadow:var(--sh-red);}
.btn--light{--bg:#fff;--fg:var(--red-deep);box-shadow:0 18px 40px -14px rgba(0,0,0,.35);}
.btn--spotify{--bg:#1db954;--fg:#08331c;box-shadow:0 16px 36px -14px rgba(29,185,84,.6);}

/* =========================================================
   PRELOADER
   ========================================================= */
.preloader{
  position:fixed;inset:0;z-index:var(--z-pre);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.1rem;
  background:radial-gradient(120% 120% at 50% 30%,var(--sky-bg),var(--cream));
  transition:opacity .6s var(--ease),visibility .6s;
}
.preloader.is-done{opacity:0;visibility:hidden;pointer-events:none;}
.preloader__heart{font-size:clamp(3.4rem,9vw,5rem);color:var(--red);animation:beat 1s var(--ease) infinite;filter:drop-shadow(var(--sh-red));}
.preloader__txt{font-family:var(--font-display);font-weight:600;color:var(--ink-soft);letter-spacing:.02em;}
@keyframes beat{0%,100%{transform:scale(1)}25%{transform:scale(1.18)}40%{transform:scale(.98)}60%{transform:scale(1.1)}}

/* =========================================================
   CAMPO DE CORAZONES AMBIENTE
   ========================================================= */
.ambient{position:fixed;inset:0;z-index:var(--z-ambient);pointer-events:none;overflow:hidden;}
.ambient .float{position:absolute;top:100%;color:var(--red);fill:currentColor;opacity:0;will-change:transform,opacity;}

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:var(--z-nav);
  height:72px;display:flex;align-items:center;gap:1.5rem;
  padding:0 var(--pad);
  transition:background .35s var(--ease),box-shadow .35s var(--ease),height .35s var(--ease);
}
.nav.is-scrolled{height:64px;background:rgba(255,248,241,.82);backdrop-filter:blur(14px) saturate(1.3);box-shadow:var(--sh-sm);}
.nav__brand{display:flex;align-items:center;gap:.5rem;margin-right:auto;}
.nav__mark{display:grid;place-items:center;width:40px;height:40px;border-radius:var(--r-pill);background:linear-gradient(135deg,var(--red),var(--red-deep));color:#fff;font-size:1.2rem;box-shadow:var(--sh-red);}
.nav__name{font-family:var(--font-display);font-weight:700;font-size:1.5rem;letter-spacing:.02em;color:var(--ink);}
.nav__links{display:flex;gap:1.6rem;}
.nav__links a{font-family:var(--font-display);font-weight:500;font-size:1.02rem;color:var(--ink);position:relative;padding:.2em 0;transition:color .25s;}
.nav__links a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:3px;border-radius:3px;background:var(--turq);transition:right .3s var(--ease);}
.nav__links a:hover{color:var(--turq-deep);}
.nav__links a:hover::after{right:0;}
.nav__burger{display:none;flex-direction:column;gap:5px;width:44px;height:44px;align-items:center;justify-content:center;border-radius:var(--r-sm);}
.nav__burger span{width:24px;height:3px;border-radius:3px;background:var(--ink);transition:transform .3s var(--ease),opacity .3s;}
.nav__burger[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg);}
.nav__burger[aria-expanded="true"] span:nth-child(2){opacity:0;}
.nav__burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg);}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;z-index:var(--z-base);
  min-height:100svh;min-height:100dvh;
  display:flex;align-items:center;
  padding:6rem var(--pad) 2rem;
  overflow:hidden;
}
.hero__bg{position:absolute;inset:0;z-index:0;}
.hero__world{width:100%;height:100%;object-fit:cover;object-position:center 35%;}
.hero__sky{position:absolute;inset:0;background:linear-gradient(180deg,rgba(238,249,255,.1) 0%,rgba(255,248,241,.0) 40%,rgba(255,248,241,.55) 100%);}
.hero__clouds{position:absolute;inset:0;z-index:1;pointer-events:none;color:#fff;}
.cloud{position:absolute;fill:currentColor;filter:drop-shadow(0 8px 16px rgba(108,201,255,.25));opacity:.92;}
.cloud--1{width:160px;height:100px;top:16%;left:6%;}
.cloud--2{width:230px;height:140px;top:24%;right:8%;}
.cloud--3{width:120px;height:75px;top:60%;left:14%;opacity:.8;}

.hero__inner{
  position:relative;z-index:2;
  width:100%;max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:2rem;
}
.hero__copy{max-width:36rem;}
.hero__title{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(2.6rem,7vw,5.2rem);line-height:.98;letter-spacing:-.02em;
  color:var(--ink);margin:.5rem 0 .9rem;
}
.hero__title .line{display:block;}
.hero__title em{font-style:normal;color:var(--red);position:relative;white-space:nowrap;}
.hero__title em::after{content:"";position:absolute;left:-2%;right:-2%;bottom:.06em;height:.18em;border-radius:var(--r-pill);background:var(--sun);z-index:-1;}
.hero__sub{font-size:clamp(1.05rem,1.6vw,1.28rem);color:var(--ink-soft);font-weight:600;max-width:30rem;}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1.7rem;}

.hero__art{position:relative;display:grid;place-items:center;min-height:60vh;}
.hero__glow{position:absolute;width:78%;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,rgba(255,143,190,.55),rgba(108,201,255,.25) 55%,transparent 72%);
  filter:blur(8px);animation:glowPulse 5s ease-in-out infinite;}
.hero__ara{position:relative;z-index:2;width:min(100%,460px);filter:drop-shadow(0 30px 50px rgba(44,33,80,.28));}
@keyframes glowPulse{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.08);opacity:1}}

/* =========================================================
   MANIFIESTO
   ========================================================= */
.manifesto{
  position:relative;z-index:var(--z-base);
  background:var(--ink);color:#fff;
  padding:clamp(3.5rem,8vw,6rem) var(--pad);
  text-align:center;overflow:hidden;
}
.manifesto__line{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.8rem,5.5vw,4rem);line-height:1.1;letter-spacing:-.01em;
  max-width:18ch;margin:0 auto;
}
.hl{position:relative;white-space:nowrap;}
.hl--red{color:var(--red);}
.hl--turq{color:var(--turq);}
.hl--pink{color:var(--pink);}

/* =========================================================
   QUIÉN ES ARA
   ========================================================= */
.about{
  position:relative;z-index:var(--z-base);
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(4rem,9vw,7.5rem) var(--pad);
  display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;
}
.about__media{position:relative;}
.about__frame{
  border-radius:var(--r-xl);overflow:hidden;
  border:8px solid #fff;box-shadow:var(--sh-lg);
  transform:rotate(-2.5deg);aspect-ratio:4/5;background:var(--turq-soft);
}
.about__frame img{width:100%;height:100%;object-fit:cover;object-position:top center;}
.sticker{position:absolute;display:grid;place-items:center;width:74px;height:74px;border-radius:var(--r-pill);font-size:2rem;box-shadow:var(--sh-md);z-index:3;}
.sticker--tl{top:-26px;left:-22px;background:var(--sun);color:#fff;transform:rotate(-12deg);}
.sticker--br{bottom:-22px;right:-18px;background:var(--turq);color:#fff;transform:rotate(10deg);}
.about__text{display:flex;flex-direction:column;gap:1.1rem;align-items:flex-start;}
.about__text p{font-size:1.15rem;color:var(--ink-soft);font-weight:600;max-width:42ch;}
.stats{display:flex;flex-wrap:wrap;gap:1.4rem 2rem;margin-top:.6rem;}
.stats li{display:flex;flex-direction:column;}
.stats strong{font-family:var(--font-display);font-weight:700;font-size:1.9rem;color:var(--red);line-height:1;}
.stats span{font-weight:700;color:var(--ink-soft);font-size:.95rem;}

/* =========================================================
   TRAYECTORIA (scroll-telling)
   ========================================================= */
.journey{
  position:relative;z-index:var(--z-base);
  background:linear-gradient(180deg,var(--cream) 0%,var(--sky-bg) 50%,var(--cream) 100%);
  padding:clamp(4rem,9vw,7rem) var(--pad) clamp(5rem,10vw,8rem);
}
.journey__head{max-width:var(--maxw);margin:0 auto 3.5rem;display:flex;flex-direction:column;gap:1rem;align-items:center;text-align:center;}
.journey__track{position:relative;max-width:880px;margin:0 auto;}
.journey__spine{position:absolute;left:50%;top:0;bottom:0;width:6px;transform:translateX(-50%);
  background:rgba(44,33,80,.10);border-radius:var(--r-pill);overflow:hidden;}
.journey__progress{position:absolute;left:0;top:0;width:100%;height:100%;transform:scaleY(0);transform-origin:top center;border-radius:var(--r-pill);
  background:linear-gradient(180deg,var(--red),var(--turq) 55%,var(--pink));will-change:transform;}
.milestones{display:flex;flex-direction:column;gap:clamp(2.5rem,5vw,4.5rem);}
.ms{position:relative;width:calc(50% - 2.4rem);}
.ms:nth-child(odd){align-self:flex-start;text-align:right;}
.ms:nth-child(even){align-self:flex-end;text-align:left;}
.ms__year{
  display:inline-block;font-family:var(--font-display);font-weight:700;font-size:1.05rem;
  color:var(--ink);background:var(--turq);padding:.25em .9em;border-radius:var(--r-pill);margin-bottom:.7rem;box-shadow:var(--sh-turq);
}
.ms--gold .ms__year{background:linear-gradient(135deg,var(--sun),#f5a623);}
.ms__card{
  position:relative;background:#fff;border-radius:var(--r-lg);padding:1.6rem 1.7rem;
  box-shadow:var(--sh-md);border:2px solid rgba(255,255,255,.9);
}
.ms:nth-child(odd) .ms__card::after,
.ms:nth-child(even) .ms__card::after{
  content:"";position:absolute;top:30px;width:18px;height:18px;background:#fff;transform:rotate(45deg);
}
.ms:nth-child(odd) .ms__card::after{right:-9px;box-shadow:3px -3px 6px -3px rgba(44,33,80,.12);}
.ms:nth-child(even) .ms__card::after{left:-9px;box-shadow:-3px 3px 6px -3px rgba(44,33,80,.12);}
.ms__card h3{font-family:var(--font-display);font-weight:700;font-size:1.35rem;color:var(--ink);margin-bottom:.35rem;}
.ms__card p{color:var(--ink-soft);font-weight:600;font-size:1.02rem;}
.ms__card em{font-style:normal;color:var(--red-deep);font-weight:700;}
.ms__icon{
  position:absolute;top:-26px;display:grid;place-items:center;width:56px;height:56px;border-radius:var(--r-pill);
  color:#fff;font-size:1.5rem;box-shadow:var(--sh-md);z-index:2;
}
.ms:nth-child(odd) .ms__icon{right:1.5rem;}
.ms:nth-child(even) .ms__icon{left:1.5rem;}
.ms__icon--radio{background:var(--pink);}
.ms__icon--tv{background:var(--turq);}
.ms__icon--star{background:var(--sky);}
.ms__icon--crown{background:linear-gradient(135deg,var(--sun),#f5a623);}
.ms__icon--heart{background:linear-gradient(135deg,var(--red),var(--red-deep));}
/* nodo en la columna */
.ms::before{
  content:"";position:absolute;top:14px;width:20px;height:20px;border-radius:var(--r-pill);
  background:#fff;border:5px solid var(--turq);z-index:4;box-shadow:var(--sh-sm);
}
.ms:nth-child(odd)::before{right:-3.4rem;}
.ms:nth-child(even)::before{left:-3.4rem;}
.ms--gold::before{border-color:var(--sun);}

/* =========================================================
   MOMENTO SOBERANO
   ========================================================= */
.soberano{
  position:relative;z-index:var(--z-base);overflow:hidden;
  background:linear-gradient(135deg,var(--red) 0%,#c8143b 55%,#8e0e2c 100%);
  color:#fff;padding:clamp(4.5rem,10vw,8rem) var(--pad);text-align:center;
}
.soberano__inner{position:relative;z-index:2;max-width:46rem;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1.2rem;}
.soberano__badge{display:inline-flex;align-items:center;gap:.55em;font-family:var(--font-display);font-weight:600;
  background:rgba(255,255,255,.16);border:1.5px solid rgba(255,255,255,.45);backdrop-filter:blur(6px);
  padding:.5em 1.1em;border-radius:var(--r-pill);font-size:1rem;}
.soberano__badge .ic{color:var(--sun);font-size:1.2em;}
.soberano__title{font-family:var(--font-display);font-weight:700;font-size:clamp(2.2rem,6vw,4.2rem);line-height:1.02;letter-spacing:-.01em;}
.soberano__desc{font-size:clamp(1.05rem,1.8vw,1.3rem);font-weight:600;color:rgba(255,255,255,.92);max-width:38rem;}
.soberano__desc strong{color:var(--sun);}

/* =========================================================
   EL MAGIC SHOW
   ========================================================= */
.show{
  position:relative;z-index:var(--z-base);
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(4rem,9vw,7.5rem) var(--pad);
}
.show__head{max-width:46rem;margin:0 auto 3rem;text-align:center;display:flex;flex-direction:column;gap:1rem;align-items:center;}
.show__lead{font-size:1.18rem;color:var(--ink-soft);font-weight:600;}
.segments{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;}
.seg{
  background:#fff;border-radius:var(--r-md);padding:1.5rem 1rem;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:.7rem;
  box-shadow:var(--sh-sm);border:2px solid rgba(44,33,80,.04);
  transition:transform .35s var(--bounce),box-shadow .35s var(--ease);
}
@media (hover:hover){.seg:hover{transform:translateY(-8px) rotate(-2deg);box-shadow:var(--sh-md);}}
.seg__emoji{display:grid;place-items:center;width:58px;height:58px;border-radius:var(--r-pill);font-size:1.6rem;color:#fff;}
.seg:nth-child(6n+1) .seg__emoji{background:var(--red);}
.seg:nth-child(6n+2) .seg__emoji{background:var(--turq);}
.seg:nth-child(6n+3) .seg__emoji{background:var(--pink);}
.seg:nth-child(6n+4) .seg__emoji{background:var(--sun);}
.seg:nth-child(6n+5) .seg__emoji{background:var(--sky);}
.seg:nth-child(6n+6) .seg__emoji{background:var(--turq-deep);}
.seg h3{font-family:var(--font-display);font-weight:600;font-size:1.1rem;color:var(--ink);}

.airtime{
  margin-top:2.4rem;display:flex;align-items:center;justify-content:center;gap:clamp(1.2rem,4vw,3rem);
  background:linear-gradient(135deg,#096b70 0%,#05484c 100%);color:#fff;
  border-radius:var(--r-xl);padding:1.8rem clamp(1.5rem,5vw,3.5rem);box-shadow:var(--sh-turq);flex-wrap:wrap;text-align:center;
}
.airtime__when,.airtime__where{display:flex;flex-direction:column;}
.airtime__day,.airtime__channel{font-family:var(--font-display);font-weight:700;font-size:clamp(1.5rem,3vw,2.1rem);line-height:1.1;}
.airtime__time{font-family:var(--font-display);font-weight:600;font-size:1.2rem;color:var(--sun-soft);}
.airtime__label{font-weight:700;opacity:.85;font-size:.95rem;}
.airtime__sep{font-size:2.4rem;color:rgba(255,255,255,.9);animation:beat 1.4s var(--ease) infinite;}

/* =========================================================
   GALERÍA (scroll horizontal)
   ========================================================= */
.gallery{position:relative;z-index:var(--z-base);padding:clamp(4rem,9vw,7rem) 0;background:var(--cream-2);overflow:hidden;}
.gallery__head{max-width:var(--maxw);margin:0 auto 2.5rem;padding:0 var(--pad);text-align:center;display:flex;flex-direction:column;gap:1rem;align-items:center;}
.gallery__viewport{overflow:hidden;}
.gallery__track{display:flex;gap:1.5rem;padding:1rem var(--pad);width:max-content;will-change:transform;}
.shot{flex:0 0 auto;width:clamp(220px,30vw,340px);aspect-ratio:3/4;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--sh-md);border:6px solid #fff;background:var(--turq-soft);}
.shot:nth-child(even){transform:rotate(1.6deg);}
.shot:nth-child(odd){transform:rotate(-1.6deg);}
.shot img{width:100%;height:100%;object-fit:cover;object-position:top center;}
.gallery__hint{text-align:center;font-family:var(--font-display);font-weight:600;color:var(--ink-soft);margin-top:1rem;}

/* =========================================================
   MÚSICA & PRODUCCIONES
   ========================================================= */
.music{
  position:relative;z-index:var(--z-base);max-width:var(--maxw);margin:0 auto;
  padding:clamp(4rem,9vw,7.5rem) var(--pad);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center;
}
.music__text{display:flex;flex-direction:column;gap:1.1rem;align-items:flex-start;}
.music__text p{font-size:1.15rem;color:var(--ink-soft);font-weight:600;max-width:40ch;}
.music__cards{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;}
.disc{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.8rem;
  aspect-ratio:1;border-radius:var(--r-lg);color:#fff;font-family:var(--font-display);font-weight:600;text-align:center;padding:1rem;
  box-shadow:var(--sh-md);font-size:1.05rem;
}
.disc .ic{font-size:2.6rem;}
.disc--1{background:linear-gradient(135deg,var(--red),var(--pink));}
.disc--2{background:linear-gradient(135deg,var(--turq),var(--sky));}
.disc--3{background:linear-gradient(135deg,var(--sun),#f5a623);grid-column:span 2;aspect-ratio:auto;padding:1.6rem;flex-direction:row;justify-content:center;gap:1rem;}
.disc--3 .ic{font-size:2rem;}

/* =========================================================
   EVENTOS / CONTRATA
   ========================================================= */
.events{position:relative;z-index:var(--z-base);padding:clamp(3rem,7vw,5rem) var(--pad);}
.events__inner{
  position:relative;overflow:hidden;
  max-width:var(--maxw);margin:0 auto;text-align:center;
  background:
    radial-gradient(80% 120% at 15% 10%,rgba(255,200,61,.35),transparent 50%),
    radial-gradient(80% 120% at 90% 90%,rgba(108,201,255,.35),transparent 50%),
    #fff;
  border-radius:var(--r-xl);padding:clamp(3rem,7vw,5.5rem) var(--pad);box-shadow:var(--sh-lg);
  display:flex;flex-direction:column;align-items:center;gap:1.2rem;
}
.events__title{font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,5vw,3.4rem);line-height:1.05;color:var(--ink);}
.events__desc{font-size:1.18rem;color:var(--ink-soft);font-weight:600;max-width:42rem;}
.events__cta{margin-top:.6rem;}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{position:relative;z-index:var(--z-base);background:var(--ink);color:#fff;padding:clamp(3rem,6vw,4.5rem) var(--pad) 2rem;}
.footer__top{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;}
.footer__brand p{color:rgba(255,255,255,.7);font-weight:600;margin-top:1rem;max-width:32ch;}
.footer__logo{width:140px;}
.footer__nav{display:flex;flex-direction:column;gap:.7rem;}
.footer__nav a{color:rgba(255,255,255,.82);font-family:var(--font-display);font-weight:500;width:fit-content;transition:color .2s,transform .2s;}
.footer__nav a:hover{color:var(--turq);transform:translateX(4px);}
.footer__social{display:flex;flex-direction:column;gap:.9rem;}
.footer__label{font-family:var(--font-display);font-weight:700;font-size:1.1rem;}
.footer__icons{display:flex;gap:.8rem;}
.footer__icons a{display:grid;place-items:center;width:46px;height:46px;border-radius:var(--r-pill);background:rgba(255,255,255,.1);font-size:1.3rem;transition:transform .3s var(--bounce),background .3s;}
.footer__icons a:hover{transform:translateY(-4px) scale(1.08);background:var(--red);}
.footer__air{color:rgba(255,255,255,.7);font-weight:700;font-size:.95rem;}
.footer__bottom{max-width:var(--maxw);margin:2.5rem auto 0;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.14);
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;color:rgba(255,255,255,.6);font-weight:600;font-size:.92rem;}
.footer__made{display:inline-flex;align-items:center;gap:.4em;}

/* =========================================================
   REVEAL (estado inicial; activado por JS)
   ========================================================= */
.js [data-reveal]{opacity:0;transform:translateY(34px);}
.js [data-ms]{opacity:0;transform:translateY(40px) scale(.96);}

/* =========================================================
   PARTÍCULAS DE ESTALLIDO
   ========================================================= */
.burst{position:fixed;z-index:var(--z-burst);pointer-events:none;fill:currentColor;will-change:transform,opacity;}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  .segments{grid-template-columns:repeat(3,1fr);}
}
@media (max-width:880px){
  .nav__links{display:none;}
  .nav__burger{display:flex;}
  .nav.menu-open{height:auto;flex-wrap:wrap;background:rgba(255,248,241,.97);backdrop-filter:blur(14px);padding-bottom:1rem;}
  .nav.menu-open .nav__links{display:flex;flex-direction:column;gap:.4rem;width:100%;order:3;}
  .nav.menu-open .nav__links a{padding:.85rem .2rem;font-size:1.2rem;}

  .hero__inner{grid-template-columns:1fr;text-align:center;gap:1rem;}
  .hero__copy{max-width:none;margin:0 auto;display:flex;flex-direction:column;align-items:center;}
  .hero__sub{margin:0 auto;}
  .hero__cta{justify-content:center;}
  .hero__art{order:-1;min-height:auto;}
  .hero__ara{width:min(72%,320px);}
  .eyebrow--hero{align-self:center;}

  .about{grid-template-columns:1fr;}
  .about__media{max-width:380px;margin:0 auto;}
  .about__text{align-items:center;text-align:center;}
  .about__text p{margin:0 auto;}
  .stats{justify-content:center;}

  .music{grid-template-columns:1fr;}
  .music__text{align-items:center;text-align:center;}
  .music__text p{margin:0 auto;}

  .footer__top{grid-template-columns:1fr 1fr;}
  .footer__brand{grid-column:1/-1;}
}
@media (max-width:760px){
  /* timeline a una columna */
  .journey__spine{left:22px;transform:none;}
  .journey__progress{}
  .ms{width:100%;align-self:stretch !important;text-align:left !important;padding-left:3.4rem;}
  .ms:nth-child(odd),.ms:nth-child(even){text-align:left;}
  .ms__card::after{display:none;}
  .ms::before{left:13px !important;right:auto !important;}
  .ms__icon{left:3.4rem !important;right:auto !important;}
}
@media (max-width:560px){
  .segments{grid-template-columns:repeat(2,1fr);}
  .airtime{flex-direction:column;gap:.6rem;}
  .airtime__sep{transform:rotate(90deg);}
  .footer__top{grid-template-columns:1fr;}
  .disc--3{flex-direction:column;}
  .btn{font-size:1rem;padding:.9em 1.4em;}
}

/* =========================================================
   TAG (etiqueta destacada)
   ========================================================= */
.tag{display:inline-flex;align-items:center;gap:.45em;font-family:var(--font-display);font-weight:600;font-size:.95rem;padding:.4em .9em;border-radius:var(--r-pill);width:fit-content;}
.tag--gold{background:var(--sun);color:#5a3d00;}
.tag--gold .ic{color:#5a3d00;}

/* =========================================================
   OBRA TEATRAL
   ========================================================= */
.theater{position:relative;z-index:var(--z-base);min-height:clamp(420px,66vh,600px);display:grid;place-items:center;overflow:hidden;padding:clamp(3rem,8vw,6rem) var(--pad);}
.theater__bg{position:absolute;inset:0;z-index:0;}
.theater__img{width:100%;height:120%;object-fit:cover;object-position:center;will-change:transform;}
.theater__scrim{position:absolute;inset:0;background:radial-gradient(120% 110% at 50% 38%,rgba(28,12,40,.32),rgba(28,12,40,.74));}
.theater__inner{position:relative;z-index:2;max-width:46rem;text-align:center;color:#fff;display:flex;flex-direction:column;align-items:center;gap:1.1rem;}
.theater__title{font-family:var(--font-display);font-weight:700;font-size:clamp(2.1rem,5.5vw,3.8rem);line-height:1.04;text-wrap:balance;text-shadow:0 4px 24px rgba(0,0,0,.4);}
.theater__desc{font-size:clamp(1.05rem,1.8vw,1.26rem);font-weight:600;color:rgba(255,255,255,.94);max-width:40rem;text-shadow:0 2px 12px rgba(0,0,0,.35);}
.theater__desc strong{color:var(--sun);}

/* =========================================================
   FAMILIA MÁGICA (colaboradores)
   ========================================================= */
.friends{position:relative;z-index:var(--z-base);max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,9vw,7rem) var(--pad);}
.friends__head{max-width:46rem;margin:0 auto 3rem;text-align:center;display:flex;flex-direction:column;gap:1rem;align-items:center;}
.friends__lead{font-size:1.15rem;color:var(--ink-soft);font-weight:600;}
.friends__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.5rem;}
.friend{background:#fff;border-radius:var(--r-lg);padding:2rem 1.5rem;text-align:center;box-shadow:var(--sh-md);display:flex;flex-direction:column;align-items:center;gap:.4rem;transition:transform .35s var(--bounce),box-shadow .35s var(--ease);}
@media (hover:hover){.friend:hover{transform:translateY(-8px);box-shadow:var(--sh-lg);}}
.friend__avatar{display:grid;place-items:center;width:88px;height:88px;border-radius:var(--r-pill);overflow:hidden;background:color-mix(in srgb,var(--c) 20%,#fff);border:3px solid var(--c);margin-bottom:.5rem;}
.friend__avatar img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block;transition:transform .4s var(--ease);}
@media (hover:hover){.friend:hover .friend__avatar img{transform:scale(1.08);}}
.friend h3{font-family:var(--font-display);font-weight:700;font-size:1.4rem;color:var(--ink);}
.friend__role{font-weight:700;color:var(--ink-soft);}
.friend__from{font-size:.9rem;font-weight:700;color:var(--ink-soft);opacity:.85;}
.friends__team{text-align:center;margin-top:2.2rem;color:var(--ink-soft);font-weight:600;}
.friends__team strong{color:var(--ink);}

/* =========================================================
   CAUSAS SOCIALES
   ========================================================= */
.cause{position:relative;z-index:var(--z-base);padding:clamp(3rem,7vw,5rem) var(--pad);}
.cause__inner{position:relative;overflow:hidden;max-width:var(--maxw);margin:0 auto;text-align:center;border-radius:var(--r-xl);padding:clamp(3rem,7vw,5rem) var(--pad);
  background:radial-gradient(90% 120% at 50% 0%,var(--pink-soft),transparent 60%),linear-gradient(180deg,#fff,var(--cream-2));
  box-shadow:var(--sh-md);display:flex;flex-direction:column;align-items:center;gap:1.1rem;}
.cause__heart{font-size:clamp(3rem,7vw,4.4rem);color:var(--red);filter:drop-shadow(var(--sh-red));animation:beat 1.7s var(--ease) infinite;}
.cause__title{font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,5vw,3.4rem);color:var(--ink);}
.cause__desc{font-size:1.18rem;color:var(--ink-soft);font-weight:600;max-width:44rem;}
.cause__desc strong{color:var(--red-deep);}
.cause__pills{display:flex;flex-wrap:wrap;justify-content:center;gap:.7rem;margin-top:.6rem;}
.cause__pills li{background:#fff;color:var(--ink);font-family:var(--font-display);font-weight:600;padding:.5em 1.1em;border-radius:var(--r-pill);box-shadow:var(--sh-sm);}

/* =========================================================
   FAQ (acordeón nativo)
   ========================================================= */
.faq{position:relative;z-index:var(--z-base);max-width:48rem;margin:0 auto;padding:clamp(3.5rem,8vw,6rem) var(--pad);}
.faq__head{text-align:center;margin-bottom:2rem;}
.faq__list{display:flex;flex-direction:column;gap:1rem;}
.faq__item{background:#fff;border-radius:var(--r-md);box-shadow:var(--sh-sm);overflow:hidden;}
.faq__item summary{display:flex;align-items:center;justify-content:space-between;gap:1rem;cursor:pointer;list-style:none;padding:1.2rem 1.4rem;font-family:var(--font-display);font-weight:600;font-size:1.1rem;color:var(--ink);transition:background .2s;}
.faq__item summary::-webkit-details-marker{display:none;}
@media (hover:hover){.faq__item summary:hover{background:var(--cream-2);}}
.faq__chev{display:grid;place-items:center;width:34px;height:34px;flex:0 0 auto;border-radius:var(--r-pill);background:var(--turq-soft);color:var(--turq-deep);font-size:1rem;transition:transform .3s var(--ease);}
.faq__item[open] .faq__chev{transform:rotate(90deg);}
.faq__a{padding:0 1.4rem 1.3rem;color:var(--ink-soft);font-weight:600;overflow:hidden;}
.faq__a p{max-width:62ch;}

/* responsive secciones nuevas */
@media (max-width:560px){
  .cause__pills{gap:.5rem;}
}

/* =========================================================
   SERVICIOS / CONTRATACIONES
   ========================================================= */
.services{position:relative;z-index:var(--z-base);overflow:hidden;padding:clamp(4.5rem,9vw,7.5rem) var(--pad);
  background:linear-gradient(180deg,#fff3f8 0%,#eafaff 100%);}
.services__head{max-width:46rem;margin:0 auto 2.8rem;text-align:center;display:flex;flex-direction:column;gap:1rem;align-items:center;}
.services__lead{font-size:1.15rem;color:var(--ink-soft);font-weight:600;}
.services__body{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(2rem,4vw,3.5rem);align-items:center;}
.services__art{position:relative;display:grid;place-items:center;min-height:340px;}
.services__halo{position:absolute;width:92%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(255,143,190,.55),rgba(108,201,255,.3) 58%,transparent 72%);filter:blur(8px);animation:glowPulse 6s ease-in-out infinite;}
.services__photo{position:relative;z-index:2;width:min(100%,340px);aspect-ratio:4/5;object-fit:cover;object-position:top center;border-radius:var(--r-xl);border:8px solid #fff;box-shadow:var(--sh-lg);}
.services__bubble{position:absolute;z-index:3;display:grid;place-items:center;width:62px;height:62px;border-radius:var(--r-pill);color:#fff;font-size:1.65rem;box-shadow:var(--sh-md);}
.services__bubble--a{background:var(--turq);top:2%;right:4%;}
.services__bubble--b{background:var(--sun);bottom:16%;left:-2%;}
.services__bubble--c{background:var(--red);bottom:2%;right:16%;}
.services__grid{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;}
.svc{display:flex;align-items:center;gap:.9rem;background:#fff;border-radius:var(--r-md);padding:.9rem 1rem;box-shadow:var(--sh-sm);border:2px solid rgba(44,33,80,.04);transition:transform .3s var(--bounce),box-shadow .3s var(--ease);}
@media (hover:hover){.svc:hover{transform:translateY(-5px);box-shadow:var(--sh-md);}}
.svc__ic{flex:0 0 auto;display:grid;place-items:center;width:50px;height:50px;border-radius:var(--r-pill);color:#fff;font-size:1.35rem;background:var(--c);box-shadow:var(--sh-sm);}
.svc h3{font-family:var(--font-display);font-weight:600;font-size:1.02rem;color:var(--ink);line-height:1.18;}
.svc h3 span{display:block;font-family:var(--font-body);font-weight:700;font-size:.8rem;color:var(--ink-soft);margin-top:.1rem;}

.contrata{margin-top:2.4rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.4rem;
  background:linear-gradient(135deg,#0f7d38 0%,#0a5f2b 100%);color:#fff;border-radius:var(--r-xl);
  padding:clamp(1.6rem,4vw,2.4rem) clamp(1.6rem,5vw,3rem);box-shadow:0 18px 40px -14px rgba(15,125,56,.55);}
.contrata__label{font-family:var(--font-display);font-weight:700;font-size:clamp(1.4rem,3vw,2.1rem);line-height:1.1;display:block;}
.contrata__sub{color:rgba(255,255,255,.92);font-weight:600;margin-top:.25rem;}
.contrata__wa{display:inline-flex;align-items:center;gap:.55em;background:#fff;color:#0b6e34;font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.4rem,3.4vw,2.05rem);padding:.55em 1em;border-radius:var(--r-pill);box-shadow:0 12px 26px -8px rgba(0,0,0,.35);
  transition:transform .3s var(--bounce),box-shadow .3s var(--ease);white-space:nowrap;will-change:transform;}
@media (hover:hover){.contrata__wa:hover{transform:translateY(-3px) scale(1.03);}}
.contrata__wa:active{transform:translateY(0) scale(.97);transition-duration:.11s;}
.contrata__wa .ic{font-size:1.15em;color:#25d366;}

.footer__wa{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-display);font-weight:700;font-size:1.25rem;color:#fff;width:fit-content;transition:transform .2s;}
.footer__wa .ic{color:#25d366;font-size:1.2em;}
@media (hover:hover){.footer__wa:hover{transform:translateX(3px);}}

@media (max-width:880px){
  .services__body{grid-template-columns:1fr;gap:2rem;}
  .services__art{order:-1;min-height:0;max-width:360px;margin:0 auto;}
}
@media (max-width:560px){
  .services__grid{grid-template-columns:1fr;}
  .contrata{flex-direction:column;text-align:center;align-items:center;}
  .contrata__wa{width:100%;justify-content:center;}
}

/* =========================================================
   REDUCED MOTION
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important;}
  .js [data-reveal],.js [data-ms]{opacity:1 !important;transform:none !important;}
  .ambient,.hero__glow,.preloader__heart,.airtime__sep{animation:none !important;}
  .hero__ara{filter:drop-shadow(0 20px 30px rgba(44,33,80,.25));}
}
