/* ============================================================
   SONRISA PARA TODOS · V2 — ¡Alegre, colorido y con mucho movimiento!
   Paleta festiva · tipografía redonda · animaciones por todas partes.
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* Paleta vibrante */
  --sol:     #FFC23C;   /* amarillo sol */
  --sol-deep:#F2A413;
  --coral:   #FF5D5D;   /* coral/rojo feliz */
  --coral-deep:#E8413F;
  --turq:    #18BFB0;   /* turquesa */
  --turq-deep:#0E9C90;
  --cielo:   #2E9BEC;   /* azul cielo */
  --cielo-deep:#1B7FD0;
  --uva:     #8B5CF6;   /* violeta */
  --uva-deep:#7242E0;
  --rosa:    #FF7BB0;   /* rosa */

  --cream:   #FFF7E9;   /* fondo crema cálido */
  --cream-2: #FFEFD6;
  --ink:     #232036;   /* tinta violácea oscura */
  --ink-2:   #4A4666;
  --ink-soft:#7B7595;
  --white:   #FFFFFF;

  /* Tipografía */
  --font-display: "Fredoka", "Hanken Grotesque", system-ui, sans-serif;
  --font-sans: "Hanken Grotesque", system-ui, -apple-system, sans-serif;

  /* Escala fluida */
  --fs-eyebrow: 0.82rem;
  --fs-body: 1.075rem;
  --fs-lead: clamp(1.15rem, 0.9rem + 1vw, 1.5rem);
  --fs-h3: clamp(1.3rem, 1.05rem + 0.8vw, 1.7rem);
  --fs-h2: clamp(2.1rem, 1.4rem + 2.8vw, 3.6rem);
  --fs-h1: clamp(2.7rem, 1.5rem + 5.2vw, 5.8rem);

  --pad-x: clamp(20px, 5vw, 80px);
  --maxw: 1280px;
  --gap: clamp(28px, 4vw, 56px);
  --sec-y: clamp(56px, 6vw, 110px);

  --radius: 28px;
  --radius-sm: 18px;
  --radius-pill: 999px;
  --shadow: 0 30px 60px -30px rgba(35,32,54,.4);
  --shadow-pop: 0 18px 0 -2px rgba(35,32,54,.10);
  --ease: cubic-bezier(.34,1.56,.64,1);     /* bounce */
  --ease-soft: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  font-family:var(--font-sans); color:var(--ink); background:var(--cream);
  font-size:var(--fs-body); line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden; position:relative;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
strong{ font-weight:700; color:var(--coral-deep); }
::selection{ background:var(--sol); color:var(--ink); }

h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; line-height:1.02; letter-spacing:-.01em; color:var(--ink); text-wrap:balance; }
h1{ font-size:var(--fs-h1); font-weight:700; }
h2{ font-size:var(--fs-h2); }
h3{ font-size:var(--fs-h3); line-height:1.12; }
p{ text-wrap:pretty; }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 var(--pad-x); position:relative; z-index:2; }
.section{ padding:var(--sec-y) 0; position:relative; }

/* ---------- Eyebrow tipo sticker ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-display); font-weight:600; font-size:var(--fs-eyebrow);
  letter-spacing:.04em; text-transform:uppercase;
  background:var(--white); color:var(--ink);
  padding:8px 16px 8px 12px; border-radius:var(--radius-pill);
  box-shadow:var(--shadow-pop); transform:rotate(-2deg);
}
.eyebrow .dot{ width:12px; height:12px; border-radius:50%; background:var(--coral); box-shadow:0 0 0 4px color-mix(in srgb, var(--coral) 25%, transparent); }
.eyebrow.e-turq .dot{ background:var(--turq); box-shadow:0 0 0 4px color-mix(in srgb, var(--turq) 25%, transparent); }
.eyebrow.e-cielo .dot{ background:var(--cielo); box-shadow:0 0 0 4px color-mix(in srgb, var(--cielo) 25%, transparent); }
.eyebrow.e-sol .dot{ background:var(--sol); box-shadow:0 0 0 4px color-mix(in srgb, var(--sol) 30%, transparent); }
.eyebrow.e-uva .dot{ background:var(--uva); box-shadow:0 0 0 4px color-mix(in srgb, var(--uva) 25%, transparent); }

.section-head{ margin-bottom:clamp(28px,4vw,52px); }
.section-head .eyebrow{ margin-bottom:18px; }
.section-head h2 .squiggle{ display:inline-block; }
.section-head p{ color:var(--ink-2); font-size:var(--fs-lead); margin-top:14px; max-width:46ch; }
@media (min-width:880px){
  .section-head--split{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(32px,5vw,72px); align-items:end; }
  .section-head--split h2{ max-width:16ch; }
  .section-head--split .head-aside{ color:var(--ink-2); font-size:1.08rem; line-height:1.55; padding-bottom:8px; max-width:34ch; }
}
.head-aside{ color:var(--ink-2); }
@media (max-width:879px){ .section-head--split .head-aside{ margin-top:14px; font-size:1.05rem; } }

.lead{ font-size:var(--fs-lead); color:var(--ink-2); line-height:1.5; }

/* texto resaltado con marcador */
.hl{ position:relative; white-space:nowrap; }
.hl::after{
  content:""; position:absolute; left:-4px; right:-4px; bottom:.06em; height:.42em; z-index:-1;
  background:var(--sol); border-radius:6px; transform:rotate(-1.5deg);
}
.hl.hl-turq::after{ background:color-mix(in srgb, var(--turq) 60%, transparent); }
.hl.hl-rosa::after{ background:var(--rosa); }
.hl.hl-cielo::after{ background:color-mix(in srgb, var(--cielo) 55%, transparent); }
h1 .hl, h2 .hl{ z-index:0; }
h1 .hl::after, h2 .hl::after{ z-index:-1; }

/* ---------- Botones ---------- */
.btn{
  font-family:var(--font-display); font-weight:600; font-size:1.05rem;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:15px 28px; border-radius:var(--radius-pill); border:none; cursor:pointer;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease-soft), filter .2s;
  line-height:1; position:relative;
}
.btn:hover{ transform:translateY(-3px) scale(1.03); }
.btn:active{ transform:translateY(0) scale(.98); }
.btn--coral{ background:var(--coral); color:#fff; box-shadow:0 10px 0 -1px var(--coral-deep); }
.btn--coral:hover{ box-shadow:0 14px 0 -1px var(--coral-deep); }
.btn--sol{ background:var(--sol); color:var(--ink); box-shadow:0 10px 0 -1px var(--sol-deep); }
.btn--sol:hover{ box-shadow:0 14px 0 -1px var(--sol-deep); }
.btn--turq{ background:var(--turq); color:#fff; box-shadow:0 10px 0 -1px var(--turq-deep); }
.btn--turq:hover{ box-shadow:0 14px 0 -1px var(--turq-deep); }
.btn--white{ background:#fff; color:var(--ink); box-shadow:0 10px 0 -1px rgba(35,32,54,.14); }
.btn--wa{ background:#1FB955; color:#fff; box-shadow:0 10px 0 -1px #14803d; }
.btn--wa:hover{ box-shadow:0 14px 0 -1px #14803d; }
.btn--ghost{ background:transparent; color:var(--ink); box-shadow:inset 0 0 0 2.5px currentColor; }
.btn--ghost:hover{ background:var(--ink); color:#fff; }
.btn--block{ width:100%; }
.btn--lg{ padding:18px 34px; font-size:1.15rem; }

.arrow-link{ display:inline-flex; align-items:center; gap:8px; font-family:var(--font-display); font-weight:600; color:var(--cielo-deep); }
.arrow-link svg{ width:18px; height:18px; transition:transform .25s var(--ease); }
.arrow-link:hover svg{ transform:translateX(5px); }

/* ============================================================
   FONDO ANIMADO — blobs de colores flotando
   ============================================================ */
.bg-decor{ position:fixed; inset:0; z-index:0; overflow:hidden; pointer-events:none; }
.blob{ position:absolute; border-radius:50%; filter:blur(60px); opacity:.5; mix-blend-mode:multiply; animation:float-blob 18s ease-in-out infinite; }
.blob.b1{ width:46vw; height:46vw; background:var(--sol); top:-12vw; left:-10vw; animation-delay:0s; }
.blob.b2{ width:40vw; height:40vw; background:var(--turq); bottom:-12vw; right:-8vw; animation-delay:-6s; }
.blob.b3{ width:34vw; height:34vw; background:var(--rosa); top:38%; left:46%; animation-delay:-11s; opacity:.4; }
@keyframes float-blob{
  0%,100%{ transform:translate(0,0) scale(1); }
  33%{ transform:translate(4vw,-3vw) scale(1.08); }
  66%{ transform:translate(-3vw,3vw) scale(.95); }
}

/* formas decorativas flotantes (estrellas, círculos, smiles) */
.floaty{ position:absolute; z-index:1; pointer-events:none; animation:bob 6s ease-in-out infinite; }
.floaty svg{ display:block; }
@keyframes bob{ 0%,100%{ transform:translateY(0) rotate(var(--r,0deg)); } 50%{ transform:translateY(-16px) rotate(var(--r2,8deg)); } }
@keyframes spin-slow{ to{ transform:rotate(360deg); } }

/* scroll progress */
.scroll-progress{ position:fixed; top:0; left:0; width:100%; height:5px; z-index:60; pointer-events:none; }
.scroll-progress i{ display:block; height:100%; width:0%; background:linear-gradient(90deg,var(--coral),var(--sol),var(--turq),var(--cielo)); }

/* ============================================================
   HEADER
   ============================================================ */
.topbar{ position:sticky; top:0; z-index:50; background:color-mix(in srgb,var(--cream) 82%, transparent); backdrop-filter:blur(14px); border-bottom:3px solid var(--ink); }
.topbar .wrap{ display:flex; align-items:center; justify-content:space-between; padding:12px var(--pad-x); gap:18px; }
.brand{ display:flex; align-items:center; gap:12px; min-width:0; }
.brand img{ width:46px; height:46px; border-radius:50%; flex:none; border:3px solid var(--ink); background:#fff; transition:transform .4s var(--ease); }
.brand:hover img{ transform:rotate(-12deg) scale(1.08); }
.brand .bt{ display:flex; flex-direction:column; line-height:1.05; min-width:0; }
.brand b{ font-family:var(--font-display); font-weight:700; font-size:1.18rem; letter-spacing:-.01em; }
.brand small{ font-size:.68rem; color:var(--ink-soft); font-weight:600; letter-spacing:.06em; text-transform:uppercase; }
.nav-links{ display:none; }
.nav-actions{ display:flex; align-items:center; gap:12px; }
.hamb{ display:inline-flex; flex-direction:column; gap:5px; padding:10px; background:none; border:none; cursor:pointer; }
.hamb span{ width:24px; height:3px; background:var(--ink); border-radius:3px; transition:transform .3s var(--ease), opacity .2s; }
.hamb.open span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.hamb.open span:nth-child(2){ opacity:0; }
.hamb.open span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }
.mobile-menu{ display:none; flex-direction:column; background:var(--cream); border-bottom:3px solid var(--ink); }
.mobile-menu.open{ display:flex; }
.mobile-menu a{ padding:16px var(--pad-x); font-family:var(--font-display); font-weight:600; font-size:1.1rem; border-top:1.5px dashed var(--cream-2); }
.mobile-menu a:first-child{ border-top:none; }
.mobile-menu a.cta{ color:var(--turq-deep); }

/* ============================================================
   HERO
   ============================================================ */
.hero{ padding-top:clamp(28px,4vw,56px); padding-bottom:0; }
.hero-inner{ display:grid; gap:clamp(28px,4vw,48px); align-items:center; }
.hero .eyebrow{ margin-bottom:22px; }
.hero h1{ margin-bottom:24px; }
.hero h1 .pop{ color:var(--coral); display:inline-block; }
.hero .lead{ max-width:42ch; margin-bottom:32px; color:var(--ink-2); }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; }

.hero-figure{ position:relative; padding:14px; }
.hero-figure .frame{ position:relative; border-radius:var(--radius); overflow:hidden; border:4px solid var(--ink); box-shadow:14px 14px 0 0 var(--turq); transform:rotate(-1.5deg); }
.hero-figure img{ width:100%; aspect-ratio:4/3; height:auto; object-fit:cover; }
.hero-figure .frame::after{ content:""; position:absolute; inset:0; box-shadow:inset 0 -60px 60px -30px rgba(35,32,54,.35); }
.hero-badge{
  position:absolute; z-index:3; background:var(--sol); color:var(--ink);
  font-family:var(--font-display); font-weight:600; font-size:.92rem;
  padding:14px 18px; border-radius:50%; width:104px; height:104px;
  display:grid; place-items:center; text-align:center; line-height:1.1;
  border:3px solid var(--ink); box-shadow:var(--shadow-pop);
  top:-6px; right:6px; animation:spin-slow 22s linear infinite;
}
.hero-badge span{ animation:spin-slow 22s linear infinite reverse; }
.hero-tag{
  position:absolute; left:24px; bottom:24px; z-index:3;
  background:#fff; color:var(--ink); padding:10px 16px; border-radius:var(--radius-pill);
  font-family:var(--font-display); font-weight:600; font-size:.85rem;
  display:flex; align-items:center; gap:8px; border:2.5px solid var(--ink); transform:rotate(1.5deg);
}
.hero-tag svg{ width:18px; height:18px; color:var(--coral); }

/* franja stats */
.hero-stats{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin-top:clamp(36px,5vw,56px); }
.hstat{ background:#fff; border:3px solid var(--ink); border-radius:var(--radius-sm); padding:18px 20px; box-shadow:var(--shadow-pop); transition:transform .3s var(--ease); }
.hstat:hover{ transform:translateY(-4px) rotate(-1.5deg); }
.hstat:nth-child(2){ background:var(--turq); color:#fff; }
.hstat:nth-child(3){ background:var(--cielo); color:#fff; }
.hstat:nth-child(4){ background:var(--coral); color:#fff; }
.hstat b{ font-family:var(--font-display); font-weight:700; font-size:clamp(1.9rem,1.2rem+2vw,2.8rem); line-height:1; display:block; font-variant-numeric:tabular-nums; }
.hstat span{ font-size:.86rem; font-weight:600; margin-top:6px; display:block; opacity:.9; }

/* ============================================================
   ONDA divisora
   ============================================================ */
.wave{ display:block; width:100%; height:auto; position:relative; z-index:2; margin-bottom:-1px; }
.wave.flip{ transform:rotate(180deg); }

/* ============================================================
   PROYECTO
   ============================================================ */
.band-turq{ background:var(--turq); color:#fff; }
.band-turq .eyebrow{ color:var(--ink); }
.band-turq h2{ color:#fff; }
.band-turq .lead, .band-turq p{ color:rgba(255,255,255,.92); }
.band-turq strong{ color:var(--sol); }

.about{ display:grid; gap:var(--gap); align-items:center; }
.about-figure{ position:relative; padding:12px; }
.about-figure img{ width:100%; aspect-ratio:5/4; height:auto; object-fit:cover; object-position:50% 40%; border-radius:var(--radius); border:4px solid var(--ink); box-shadow:-12px 12px 0 0 var(--sol); }
.about-text h2{ margin-bottom:20px; }
.about-text p+p{ margin-top:16px; }
.pullquote{ font-family:var(--font-display); font-weight:500; font-size:clamp(1.35rem,1.05rem+1.3vw,1.9rem); line-height:1.28; margin-top:26px; padding:22px 24px; background:rgba(255,255,255,.14); border-radius:var(--radius-sm); border:2px dashed rgba(255,255,255,.5); }
.pullquote span{ color:var(--sol); }

/* ============================================================
   SERVICIOS  (tarjetas pop)
   ============================================================ */
.svc-grid{ display:grid; gap:clamp(18px,2.4vw,26px); }
.svc{ background:#fff; border:3px solid var(--ink); border-radius:var(--radius); padding:clamp(24px,2.6vw,32px); display:flex; flex-direction:column; gap:14px; box-shadow:var(--shadow-pop); transition:transform .3s var(--ease), box-shadow .3s var(--ease-soft); }
.svc:hover{ transform:translateY(-8px) rotate(-1deg); box-shadow:0 26px 0 -4px rgba(35,32,54,.12); }
.svc-ico{ width:62px; height:62px; border-radius:18px; display:grid; place-items:center; color:#fff; }
.svc-ico svg{ width:34px; height:34px; }
.svc:nth-child(1) .svc-ico{ background:var(--coral); }
.svc:nth-child(2) .svc-ico{ background:var(--cielo); }
.svc:nth-child(3) .svc-ico{ background:var(--turq); }
.svc:nth-child(4) .svc-ico{ background:var(--uva); }
.svc .idx{ font-family:var(--font-display); font-weight:700; font-size:.85rem; color:var(--ink-soft); }
.svc h3{ font-size:1.32rem; }
.svc p{ font-size:.98rem; color:var(--ink-2); line-height:1.5; }

/* ============================================================
   IMPACTO (banda violeta festiva)
   ============================================================ */
.impact{ background:var(--uva); color:#fff; position:relative; overflow:hidden; }
.impact .eyebrow{ color:var(--ink); }
.impact h2{ color:#fff; margin-bottom:clamp(34px,4vw,52px); }
.stat-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(16px,2vw,24px); }
.stat{ background:rgba(255,255,255,.12); border:2.5px solid rgba(255,255,255,.4); border-radius:var(--radius-sm); padding:24px 20px; text-align:center; transition:transform .3s var(--ease); }
.stat:hover{ transform:translateY(-6px) scale(1.03); background:rgba(255,255,255,.2); }
.stat b{ font-family:var(--font-display); font-weight:700; font-size:clamp(2.4rem,1.5rem+3.2vw,4rem); line-height:1; display:block; color:#fff; font-variant-numeric:tabular-nums; }
.stat span{ font-size:.92rem; color:rgba(255,255,255,.85); font-weight:600; margin-top:8px; display:block; }
.impact .note{ font-size:.8rem; color:rgba(255,255,255,.6); margin-top:clamp(28px,3vw,40px); text-align:center; }

/* ============================================================
   EVENTOS
   ============================================================ */
.events-grid{ display:grid; gap:var(--gap); align-items:start; }
.event-feature{ background:var(--coral); color:#fff; border:4px solid var(--ink); border-radius:var(--radius); padding:clamp(26px,3vw,40px); box-shadow:10px 10px 0 0 var(--ink); }
.event-feature .tag{ display:inline-flex; align-items:center; gap:7px; background:var(--sol); color:var(--ink); padding:8px 16px; border-radius:var(--radius-pill); font-family:var(--font-display); font-weight:600; font-size:.82rem; border:2px solid var(--ink); }
.event-feature h3{ color:#fff; font-size:clamp(1.5rem,1.1rem+1.6vw,2.2rem); margin:18px 0 8px; }
.event-feature>p{ color:rgba(255,255,255,.92); font-size:1.02rem; }
.countdown{ display:flex; gap:10px; margin:24px 0; }
.cd{ flex:1; background:#fff; color:var(--ink); border:2.5px solid var(--ink); border-radius:14px; padding:14px 6px; text-align:center; }
.cd b{ font-family:var(--font-display); font-weight:700; font-size:clamp(1.6rem,1.2rem+1vw,2.2rem); line-height:1; display:block; font-variant-numeric:tabular-nums; }
.cd span{ font-size:.64rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft); margin-top:6px; display:block; }
.countdown.done-msg{ display:block; text-align:center; font-family:var(--font-display); font-weight:600; font-size:1.4rem; background:#fff; color:var(--coral-deep); border:2.5px solid var(--ink); border-radius:14px; padding:18px; }
.event-meta{ display:flex; flex-wrap:wrap; gap:12px 20px; margin-bottom:22px; }
.event-meta div{ display:flex; align-items:center; gap:9px; font-family:var(--font-display); font-weight:600; font-size:.95rem; }
.event-meta svg{ width:18px; height:18px; }

.tl-head{ margin-bottom:22px; }
.tl-head h3{ font-size:1.6rem; }
.tl-head small{ color:var(--ink-soft); font-weight:600; font-size:.88rem; }
.sem-label{ display:inline-block; font-family:var(--font-display); font-size:.74rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--turq-deep); background:color-mix(in srgb,var(--turq) 18%, #fff); padding:5px 12px; border-radius:var(--radius-pill); margin:26px 0 10px; }
.sem-label:first-of-type{ margin-top:0; }
.tl-item{ display:flex; gap:18px; padding:16px; border-radius:var(--radius-sm); transition:background .25s, transform .25s var(--ease); }
.tl-item:hover{ background:#fff; transform:translateX(6px); box-shadow:var(--shadow-pop); }
.tl-month{ flex:none; width:54px; }
.tl-month b{ font-family:var(--font-display); font-weight:700; font-size:1.05rem; color:var(--coral-deep); text-transform:uppercase; display:block; }
.tl-month i{ font-style:normal; font-size:.76rem; color:var(--ink-soft); }
.tl-body h4{ font-family:var(--font-display); font-size:1.06rem; font-weight:600; margin-bottom:3px; }
.tl-body p{ font-size:.92rem; color:var(--ink-2); line-height:1.45; }

/* ============================================================
   AYUDAR
   ============================================================ */
.help-grid{ display:grid; gap:clamp(20px,2.5vw,30px); margin-bottom:clamp(32px,4vw,48px); }
.help{ padding:32px 28px; border-radius:var(--radius); border:3px solid var(--ink); box-shadow:var(--shadow-pop); transition:transform .3s var(--ease); }
.help:hover{ transform:translateY(-6px) rotate(1deg); }
.help:nth-child(1){ background:var(--sol); }
.help:nth-child(2){ background:var(--turq); color:#fff; }
.help:nth-child(3){ background:var(--cielo); color:#fff; }
.help .num{ font-family:var(--font-display); font-weight:700; font-size:1.5rem; width:54px; height:54px; border-radius:50%; display:grid; place-items:center; background:#fff; color:var(--ink); border:3px solid var(--ink); margin-bottom:18px; }
.help h3{ font-size:1.3rem; margin-bottom:8px; }
.help:nth-child(2) h3, .help:nth-child(3) h3{ color:#fff; }
.help p{ font-size:1rem; line-height:1.5; }
.help:nth-child(1) p{ color:var(--ink-2); }
.help:nth-child(1) strong{ color:var(--coral-deep); }
.help:nth-child(2) p, .help:nth-child(3) p{ color:rgba(255,255,255,.92); }
.help:nth-child(2) strong, .help:nth-child(3) strong{ color:var(--sol); }
.help-cta{ display:flex; justify-content:center; }

/* ============================================================
   GALERÍA
   ============================================================ */
.gallery{ display:grid; grid-template-columns:repeat(2,1fr); grid-auto-rows:clamp(150px,30vw,210px); gap:clamp(12px,1.6vw,18px); }
.gphoto{ position:relative; margin:0; border-radius:var(--radius-sm); overflow:hidden; border:3px solid var(--ink); transition:transform .3s var(--ease); }
.gphoto:nth-child(odd){ transform:rotate(-1deg); }
.gphoto:nth-child(even){ transform:rotate(1deg); }
.gphoto:hover{ transform:rotate(0) scale(1.02); z-index:2; }
.gphoto img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease-soft); }
.gphoto:hover img{ transform:scale(1.08); }
.gphoto figcaption{ position:absolute; inset:auto 0 0 0; padding:26px 14px 12px; color:#fff; font-family:var(--font-display); font-weight:600; font-size:1rem; background:linear-gradient(to top, rgba(35,32,54,.82), transparent); }
.gallery .tall{ grid-row:span 2; }

/* ============================================================
   ALIADOS — marquee
   ============================================================ */
.marquee{ overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.marquee-track{ display:flex; gap:18px; width:max-content; animation:scroll-x 26s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
@keyframes scroll-x{ to{ transform:translateX(-50%); } }
.ally{ flex:none; display:flex; align-items:center; gap:12px; background:#fff; border:3px solid var(--ink); border-radius:var(--radius-pill); padding:14px 22px 14px 14px; box-shadow:var(--shadow-pop); }
.ally .logo{ width:46px; height:46px; border-radius:50%; display:grid; place-items:center; font-family:var(--font-display); font-weight:700; font-size:1rem; color:#fff; flex:none; }
.ally:nth-child(5n+1) .logo{ background:var(--coral); }
.ally:nth-child(5n+2) .logo{ background:var(--cielo); }
.ally:nth-child(5n+3) .logo{ background:var(--turq); }
.ally:nth-child(5n+4) .logo{ background:var(--uva); }
.ally:nth-child(5n+5) .logo{ background:var(--sol); color:var(--ink); }
.ally span{ font-family:var(--font-display); font-weight:600; font-size:.95rem; white-space:nowrap; }

/* ============================================================
   CONTACTO
   ============================================================ */
.contact{ background:var(--cielo); color:#fff; }
.contact .eyebrow{ color:var(--ink); }
.contact h2{ color:#fff; }
.contact .head-aside{ color:rgba(255,255,255,.9); }
.contact-list{ display:grid; gap:16px; }
.contact-row{ display:flex; align-items:center; gap:16px; background:#fff; color:var(--ink); border:3px solid var(--ink); border-radius:var(--radius); padding:20px 22px; box-shadow:var(--shadow-pop); transition:transform .3s var(--ease); }
.contact-row:hover{ transform:translateY(-5px) rotate(-1deg); }
.contact-row .ci{ flex:none; width:50px; height:50px; border-radius:14px; display:grid; place-items:center; color:#fff; border:2.5px solid var(--ink); }
.contact-row .ci svg{ width:24px; height:24px; }
.contact-row .ct b{ display:block; font-family:var(--font-display); font-size:1.06rem; font-weight:600; }
.contact-row .ct span{ font-size:.9rem; color:var(--ink-soft); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--ink); color:#fff; text-align:center; padding:clamp(48px,6vw,80px) 0 calc(clamp(48px,6vw,80px) + env(safe-area-inset-bottom)); position:relative; overflow:hidden; }
.footer img{ width:72px; height:72px; margin:0 auto 18px; border-radius:50%; border:3px solid #fff; position:relative; z-index:2; }
.footer .tag2{ font-family:var(--font-display); font-weight:600; font-size:1.6rem; color:#fff; position:relative; z-index:2; }
.footer small{ display:block; color:rgba(255,255,255,.5); font-size:.85rem; margin-top:14px; line-height:1.6; position:relative; z-index:2; }
.footer .social{ display:flex; gap:12px; justify-content:center; margin-top:24px; position:relative; z-index:2; }
.footer .social a{ width:50px; height:50px; border-radius:50%; border:2.5px solid rgba(255,255,255,.3); display:grid; place-items:center; color:#fff; transition:transform .3s var(--ease), background .2s; }
.footer .social a:hover{ transform:translateY(-4px) scale(1.1); }
.footer .social a:nth-child(1):hover{ background:#DD2A7B; }
.footer .social a:nth-child(2):hover{ background:#1FB955; }
.footer .social a:nth-child(3):hover{ background:var(--coral); }
.footer .social svg{ width:22px; height:22px; }

/* ============================================================
   STICKY CTA mobile
   ============================================================ */
.sticky-cta{ position:fixed; bottom:0; left:0; right:0; z-index:45; display:flex; gap:10px; padding:12px var(--pad-x) calc(12px + env(safe-area-inset-bottom)); background:color-mix(in srgb,var(--cream) 92%, transparent); backdrop-filter:blur(14px); border-top:3px solid var(--ink); }
.sticky-cta .btn{ flex:1; padding:14px; font-size:1rem; box-shadow:0 6px 0 -1px rgba(35,32,54,.2); }

/* confetti */
.confetti-piece{ position:fixed; top:-20px; z-index:70; pointer-events:none; border-radius:2px; }

/* ============================================================
   REVEAL bounce
   ============================================================ */
.reveal{ opacity:0; transform:translateY(36px) scale(.96); transition:opacity .7s var(--ease-soft), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; } .reveal.d3{ transition-delay:.24s; }

/* ============================================================
   TABLET ≥680
   ============================================================ */
@media (min-width:680px){
  .hero-stats{ grid-template-columns:repeat(4,1fr); }
  .svc-grid{ grid-template-columns:repeat(2,1fr); }
  .help-grid{ grid-template-columns:repeat(3,1fr); }
  .gallery{ grid-template-columns:repeat(3,1fr); }
  .gallery .tall{ grid-column:span 2; }
  .stat-grid{ grid-template-columns:repeat(4,1fr); }
  .contact-list{ grid-template-columns:repeat(3,1fr); }
}

/* ============================================================
   DESKTOP ≥960
   ============================================================ */
@media (min-width:960px){
  .nav-links{ display:flex; align-items:center; gap:30px; margin-left:auto; margin-right:6px; }
  .nav-links a{ font-family:var(--font-display); font-weight:600; font-size:1rem; color:var(--ink-2); position:relative; padding:4px 0; transition:color .2s; }
  .nav-links a::after{ content:""; position:absolute; left:0; bottom:-2px; height:3px; width:0; background:var(--coral); border-radius:3px; transition:width .25s var(--ease); }
  .nav-links a:hover{ color:var(--ink); }
  .nav-links a:hover::after{ width:100%; }
  .hamb{ display:none; }
  .mobile-menu{ display:none !important; }
  .sticky-cta{ display:none; }

  .hero-inner{ grid-template-columns:1.05fr .95fr; }
  .hero-figure img{ aspect-ratio:4/3.4; }
  .about{ grid-template-columns:1fr 1.08fr; }
  .about--reverse .about-figure{ order:2; }
  .svc-grid{ grid-template-columns:repeat(4,1fr); }
  .events-grid{ grid-template-columns:.92fr 1.08fr; }
  .event-feature{ position:sticky; top:96px; }
  .gallery{ grid-template-columns:repeat(4,1fr); grid-auto-rows:clamp(180px,16vw,230px); }
  .gallery .tall{ grid-row:span 2; grid-column:span 2; }
}

@media (max-width:959px){
  body{ padding-bottom:calc(76px + env(safe-area-inset-bottom)); }
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; }
  .reveal{ opacity:1 !important; transform:none !important; transition:none !important; }
  .marquee-track{ animation:none !important; }
  .blob{ animation:none !important; }
}
