/* ─────────────────────────────────────────────
   LA MEDITACIÓN MÁS GRANDE DEL MUNDO
   Sistema de diseño · monumentalidad serena
   Paleta alineada con el Look del evento + Yoga palette
   ───────────────────────────────────────────── */

:root{
  /* Paleta obligatoria (Look + Yoga) */
  --serenity: #A4BAB7;       /* azul-verde sereno */
  --sage:     #C6C4AC;       /* salvia / olivo claro */
  --sand:     #E3D9CA;       /* arena cálida */
  --linen:    #DED9D5;       /* lino suave */

  /* Fondos cálidos (como el Look) */
  --paper:     #F2EBE0;      /* crema base, papel cálido */
  --paper-2:   #ECE4D6;      /* crema más cálida */
  --serenity-soft: #C9D7D4;  /* serenity muy diluido para fondos */
  --sage-soft:     #D9D6BD;  /* sage suave para fondos */

  /* Tinta cálida (no negro frío) */
  --ink:       #3D3A30;      /* olivo profundo cálido */
  --ink-soft:  #5C5A4E;
  --ink-mute:  #8C8A7D;
  --accent:    #6E8A7E;      /* verde sage profundo para destacar */
  --line:      rgba(61,58,48,.14);

  /* Tipografía */
  --serif: "Bodoni Moda", "Cormorant Garamond", "Times New Roman", serif;
  --sans:  "Satoshi", "Inter", system-ui, -apple-system, sans-serif;
  --script:"Cormorant Garamond", "Bodoni Moda", serif; /* Amoresa fallback */

  /* Optical-size de Bodoni Moda: bajo = trazos más sólidos */
  --bodoni-display: 'opsz' 16, 'wght' 600;
  --bodoni-text:    'opsz' 11, 'wght' 600;

  /* Ritmo (reducido para mejor legibilidad) */
  --r1: clamp(.9rem, .85rem + .2vw, 1rem);
  --r2: clamp(1.02rem, .98rem + .35vw, 1.15rem);
  --r3: clamp(1.25rem, 1.1rem + .7vw, 1.55rem);
  --r4: clamp(1.7rem, 1.35rem + 1.4vw, 2.4rem);
  --r5: clamp(2.1rem, 1.6rem + 2.2vw, 3.4rem);
  --r6: clamp(2.6rem, 1.8rem + 4vw, 5rem);
  --r7: clamp(3.2rem, 2.1rem + 5.5vw, 6.4rem);

  --maxw: 1240px;
  --gutter: clamp(1.25rem, 3.5vw, 2.75rem);
  --section-y: clamp(3rem, 5vw, 5rem);

  --ease: cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  font-size:var(--r2);
  line-height:1.6;
  letter-spacing:.005em;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
section{padding:var(--section-y) 0;position:relative}

/* ───── Tipografía: Bodoni Moda controlada ───── */
h1,h2,h3{
  font-family:var(--serif);
  font-weight:600;
  font-variation-settings: var(--bodoni-text);
  letter-spacing:-.008em;
  line-height:1.08;
  color:var(--ink);
  margin:0;
}
h2{font-size:var(--r5)}
h3{font-size:var(--r3);font-weight:600}

/* Itálicas elegantes pero legibles */
em{font-style:italic;font-family:var(--serif);font-weight:500}

p{margin:0 0 1em 0;color:var(--ink-soft)}

/* Acento "Amoresa" — script ligero */
.accent{
  font-family:var(--script);
  font-style:italic;
  font-weight:500;
  letter-spacing:0;
  color:var(--accent);
}

/* Kicker (eyebrow) */
.kicker{
  font-family:var(--sans);
  font-size:.74rem;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--accent);
  margin:0 0 1.6em 0;
  font-weight:500;
}

/* ───── Botones ───── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  padding:.95em 1.6em;
  font-family:var(--sans);
  font-size:.92rem;
  letter-spacing:.06em;
  font-weight:500;
  border-radius:999px;
  transition:transform .5s var(--ease),background .4s var(--ease),color .4s var(--ease),border-color .4s var(--ease),opacity .4s var(--ease);
  will-change:transform;
}
.btn--solid{background:var(--ink);color:var(--paper);border:1px solid var(--ink)}
.btn--solid:hover{background:transparent;color:var(--ink);transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--ink);border:1px solid rgba(61,58,48,.4)}
.btn--ghost:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn--full{width:100%}
.btn--lg{padding:1.15em 2.2em;font-size:1rem}

/* ───── Reveal ───── */
.reveal{opacity:0;transform:translateY(22px);transition:opacity 1.1s var(--ease) var(--d,0s), transform 1.1s var(--ease) var(--d,0s)}
.reveal.is-in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ───────────────────────────────────────────────
   NAV
   ─────────────────────────────────────────────── */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:50;
  padding:14px var(--gutter);
  transition:background .4s var(--ease),backdrop-filter .4s var(--ease),padding .4s var(--ease),border-color .4s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.is-scrolled{
  background:rgba(242,235,224,.85);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom-color:var(--line);
  padding:10px var(--gutter);
}
.nav__inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:2rem;color:var(--ink)}

.nav__mark{display:flex;align-items:center;gap:.55rem;font-family:var(--serif);font-weight:600;letter-spacing:.005em;font-size:1.05rem;font-variation-settings:var(--bodoni-text);color:var(--ink);text-decoration:none}
.nav__mark--full{padding:.25rem 0}
.nav__logo{height:44px;width:auto;display:block;object-fit:contain}
.mark-word{font-family:var(--serif);font-variation-settings:'opsz' 14, 'wght' 600;font-size:1.15rem;letter-spacing:.005em;line-height:1;color:var(--ink);white-space:nowrap}
.mark-word em{font-style:italic;font-weight:500;color:var(--accent);font-variation-settings:'opsz' 14, 'wght' 500}
.mark-word__sep{color:var(--serenity);opacity:.6;font-style:normal;font-weight:400;margin:0 .15em}
.mark-glyph{display:inline-flex;width:32px;height:32px;color:var(--accent)}
.mark-glyph svg,
.mark-glyph img{width:100%;height:100%;object-fit:contain;display:block}

.nav__links{margin-left:auto;display:flex;gap:1.8rem;font-size:.84rem;letter-spacing:.06em}
.nav__links a{opacity:.78;transition:opacity .3s var(--ease)}
.nav__links a:hover{opacity:1}

.nav__cta{
  display:inline-flex;align-items:center;
  padding:.6em 1.1em;
  font-size:.8rem;letter-spacing:.08em;
  border-radius:999px;
  border:1px solid currentColor;
  transition:background .3s var(--ease),color .3s var(--ease);
}
.nav__cta:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}

@media (max-width:820px){
  .nav__links{display:none}
}

/* ───────────────────────────────────────────────
   HERO — atmósfera dorada del Zócalo (clara, no oscura)
   ─────────────────────────────────────────────── */
.hero{
  position:relative;
  min-height:100vh;min-height:100svh;
  padding:0;
  display:flex;align-items:flex-end;
  color:var(--ink);
  overflow:hidden;
  isolation:isolate;
}
.hero__media{position:absolute;inset:0;z-index:-1;overflow:hidden}

/* Foto del Zócalo en el Hero — meditación masiva al atardecer */
.hero__bg{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 40%;
}
.hero__vignette{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(20,18,12,.15) 0%, transparent 35%, transparent 55%, rgba(20,18,12,.55) 100%),
    linear-gradient(90deg, rgba(20,18,12,.45) 0%, rgba(20,18,12,.15) 35%, transparent 60%);
  pointer-events:none;
}

.hero__content{
  position:relative;z-index:1;
  width:100%;
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 var(--gutter) clamp(3rem,7vw,6rem);
}

.hero__eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-size:.76rem;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(242,235,224,.85);
  margin-bottom:clamp(1.5rem,3vw,2.4rem);
  font-weight:500;
  text-shadow:0 1px 8px rgba(20,18,12,.7);
}
.dot{width:6px;height:6px;border-radius:50%;background:var(--serenity);box-shadow:0 0 0 4px rgba(164,186,183,.25)}

.hero__title{
  font-family:var(--serif);
  font-variation-settings: 'opsz' 14, 'wght' 600;
  font-weight:600;
  font-size:var(--r7);
  line-height:1.02;
  color:#fff;
  letter-spacing:-.015em;
  max-width:16ch;
  text-shadow:0 2px 24px rgba(20,18,12,.6), 0 1px 3px rgba(20,18,12,.5);
}
.hero__title em{
  font-style:italic;
  color:var(--serenity-soft);
  font-weight:500;
  font-variation-settings: 'opsz' 14, 'wght' 500;
}

.hero__sub{
  margin-top:1.4rem;
  font-size:var(--r3);
  color:rgba(242,235,224,.92);
  max-width:44ch;
  font-weight:400;
  line-height:1.45;
  text-shadow:0 1px 12px rgba(20,18,12,.55);
}
.hero__sub-soft{
  display:inline-block;
  margin-top:.3rem;
  font-family:var(--script,var(--serif));
  font-style:italic;
  color:var(--serenity-soft);
  font-size:1.05em;
}

.hero__meta{
  margin-top:clamp(1.6rem,3vw,2.2rem);
  display:flex;
  align-items:center;
  gap:clamp(1rem,2vw,1.8rem);
  flex-wrap:nowrap;
  max-width:680px;
}
.hero__meta-item{
  display:flex;
  flex-direction:column;
  gap:3px;
  flex:0 0 auto;
  min-width:0;
}
.hero__meta-num{
  font-family:var(--serif);
  font-size:clamp(1.05rem,1.5vw,1.3rem);
  font-weight:600;
  letter-spacing:-.01em;
  color:#fff;
  line-height:1;
  white-space:nowrap;
  text-shadow:0 1px 10px rgba(20,18,12,.6);
}
.hero__meta-lbl{
  font-size:.66rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(242,235,224,.78);
  font-weight:500;
  white-space:nowrap;
  text-shadow:0 1px 8px rgba(20,18,12,.55);
}
.hero__meta-sep{
  width:1px;
  height:28px;
  flex:0 0 1px;
  background:linear-gradient(180deg,transparent,rgba(242,235,224,.5),transparent);
  opacity:.6;
}
@media (max-width:720px){
  .hero__meta{flex-wrap:wrap;gap:1rem 1.6rem;max-width:520px}
  .hero__meta-sep{display:none}
}

.hero__ctas{
  margin-top:clamp(1.8rem,3.5vw,2.6rem);
  display:flex;gap:.9rem;flex-wrap:wrap;
}

.hero__scroll{
  position:absolute;
  right:var(--gutter);
  bottom:clamp(3rem,7vw,6rem);
  display:flex;flex-direction:column;align-items:center;gap:.7rem;
  font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink-mute);
}
.scroll-line{
  width:1px;height:60px;background:linear-gradient(180deg, var(--ink-mute), transparent);
  animation:scrollPulse 2.6s var(--ease) infinite;
}
@keyframes scrollPulse{
  0%{transform-origin:top;transform:scaleY(.2);opacity:.2}
  50%{transform:scaleY(1);opacity:.9}
  100%{transform-origin:bottom;transform:scaleY(.2);opacity:.2}
}

@media (max-width:640px){
  .hero__scroll{display:none}
}

/* ───────────────────────────────────────────────
   CUENTA REGRESIVA
   ─────────────────────────────────────────────── */
.countdown{
  background:var(--paper);
  text-align:center;
  padding-top:clamp(2.5rem,5vw,4.5rem);
  padding-bottom:clamp(2.5rem,5vw,4.5rem);
  border-bottom:1px solid var(--line);
}
.countdown__title{
  font-family:var(--script);
  font-size:var(--r4);
  font-style:italic;
  font-weight:500;
  color:var(--accent);
  letter-spacing:.005em;
}
.countdown__grid{
  margin:clamp(1.2rem,3vw,2.2rem) auto 0;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:clamp(.5rem,2vw,2rem);
  max-width:920px;
}
.cd-cell{
  position:relative;
  padding:clamp(.9rem,2vw,1.6rem) 1rem;
  border-left:1px solid var(--line);
}
.cd-cell:first-child{border-left:0}
.cd-num{
  font-family:var(--serif);
  font-variation-settings: 'opsz' 18, 'wght' 600;
  font-size:clamp(2.8rem,7vw,5rem);
  font-weight:600;
  line-height:1;
  letter-spacing:-.015em;
  font-variant-numeric:tabular-nums;
  color:var(--ink);
}
.cd-lbl{
  margin-top:.6rem;
  font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--ink-mute);
}
.countdown__foot{
  margin-top:clamp(1.4rem,3vw,2.2rem);
  font-size:var(--r2);
  color:var(--ink-soft);
}
.countdown__foot .accent{font-size:1.15em}

/* ───────────────────────────────────────────────
   MANIFIESTO
   ─────────────────────────────────────────────── */
.manifesto{background:var(--paper-2)}
.manifesto__wrap{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:clamp(2rem,5vw,4rem);
  align-items:start;
}
.manifesto__figure{
  margin:0;
  position:sticky;top:120px;
  border-radius:6px;overflow:hidden;
  aspect-ratio:4/5;
  box-shadow:0 30px 60px -30px rgba(61,58,48,.35);
}
.manifesto__figure img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1.4s var(--ease);
}
.manifesto__figure:hover img{transform:scale(1.03)}
@media (max-width:820px){
  .manifesto__wrap{grid-template-columns:1fr}
  .manifesto__figure{position:static;aspect-ratio:5/4;order:-1;max-width:520px}
}
.manifesto__lede{
  font-family:var(--serif);
  font-variation-settings: 'opsz' 16, 'wght' 600;
  font-size:var(--r6);
  letter-spacing:-.01em;
  line-height:1.05;
  margin-bottom:clamp(2.4rem,5vw,3.6rem);
  font-weight:600;
  color:var(--ink);
}
.manifesto__body{
  max-width:62ch;
  margin-left:auto;
  font-size:var(--r3);
  line-height:1.5;
  color:var(--ink-soft);
}
.manifesto__body p{margin-bottom:1.4em}
.manifesto__pull{
  font-family:var(--serif);
  font-variation-settings: 'opsz' 18, 'wght' 600;
  font-size:var(--r4);
  color:var(--ink);
  font-weight:600;
  line-height:1.15;
  margin:1.4em 0;
}
.manifesto__pull em{color:var(--accent);font-style:italic}

/* ───────────────────────────────────────────────
   IMPACTO
   ─────────────────────────────────────────────── */
.impact{background:var(--linen)}
.impact__head{margin-bottom:clamp(3rem,6vw,4.5rem);max-width:780px}
.impact__head h2{font-size:var(--r5);font-variation-settings: 'opsz' 14, 'wght' 600}
.impact__grid{
  list-style:none;padding:0;margin:0;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:0;
  border-top:1px solid var(--line);
}
.impact__cell{
  padding:clamp(1.8rem,3vw,2.8rem) clamp(1rem,2vw,1.6rem);
  border-bottom:1px solid var(--line);
  border-right:1px solid var(--line);
  background:transparent;
  transition:background .5s var(--ease);
}
.impact__cell:last-child{border-right:0}
.impact__cell:hover{background:var(--sand)}
.impact__num{
  font-family:var(--serif);
  font-variation-settings: 'opsz' 16, 'wght' 600;
  font-size:clamp(2.2rem,4.5vw,3.2rem);
  font-weight:600;
  line-height:1;
  letter-spacing:-.015em;
  margin-bottom:1.2rem;
  font-variant-numeric:tabular-nums;
  color:var(--ink);
}
.impact__num--alt{font-style:italic;color:var(--accent);font-weight:500}
.plus{color:var(--accent);margin-left:.05em}
.impact__lbl{
  font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--ink-mute);
  margin-bottom:1rem;
  font-weight:500;
}
.impact__copy{
  font-size:.95rem;line-height:1.55;color:var(--ink-soft);margin:0;
}

@media (max-width:900px){
  .impact__grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .impact__cell:nth-child(2n){border-right:0}
}
@media (max-width:520px){
  .impact__grid{grid-template-columns:1fr}
  .impact__cell{border-right:0}
}

/* ───────────────────────────────────────────────
   CINEMÁTICO — olivo profundo, no negro
   ─────────────────────────────────────────────── */
.cinematic{
  position:relative;
  background:#2E2C24;
  color:var(--paper);
  padding:clamp(3.5rem,7vw,6rem) 0 clamp(11rem,22vw,18rem);
  overflow:hidden;
  isolation:isolate;
}
.cinematic__bg{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  z-index:-2;
  filter:saturate(1.05);
}
.cinematic__veil{
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(55% 30% at 50% 28%, rgba(20,18,12,.5), rgba(20,18,12,.15) 60%, transparent 80%),
    linear-gradient(180deg, rgba(20,18,12,.18) 0%, rgba(20,18,12,.05) 60%, rgba(20,18,12,.22) 100%);
}
.cinematic__inner{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 var(--gutter);
  text-align:center;
}
.cinematic__line{
  font-family:var(--serif);
  font-variation-settings: 'opsz' 18, 'wght' 600;
  font-size:var(--r5);
  font-weight:600;
  line-height:1.15;
  letter-spacing:-.01em;
  color:#fff;
  text-shadow:
    0 2px 12px rgba(20,18,12,.85),
    0 0 40px rgba(20,18,12,.55),
    0 1px 2px rgba(20,18,12,.7);
}
.cinematic__line em{
  font-style:italic;
  color:#fff;
  font-weight:500;
}

/* ───────────────────────────────────────────────
   REGISTRO
   ─────────────────────────────────────────────── */
.register{background:var(--serenity-soft)}
.register__wrap{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(2.5rem,6vw,5rem);
  align-items:start;
}
.register__intro h2{font-size:var(--r5);max-width:14ch}
.register__copy{
  margin-top:1.4rem;
  font-size:var(--r2);
  color:var(--ink-soft);
  max-width:42ch;
}
.register__facts{list-style:none;padding:0;margin:2.5rem 0 0;display:grid;gap:.9rem}
.register__facts li{
  display:grid;grid-template-columns:120px 1fr;gap:1rem;
  padding:.85rem 0;
  border-top:1px solid var(--line);
  font-size:.95rem;
}
.register__facts li:last-child{border-bottom:1px solid var(--line)}
.register__facts span{font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-mute);padding-top:.18rem;font-weight:500}
.register__facts strong{font-weight:500;color:var(--ink)}

.form{
  background:var(--paper);
  padding:clamp(1.6rem,3vw,2.4rem);
  border:1px solid var(--line);
  border-radius:6px;
}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{display:block;margin-bottom:1.1rem}
.field span{
  display:block;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-mute);margin-bottom:.5rem;
  font-weight:500;
}
.field input,.field select{
  width:100%;
  padding:.85rem 0;
  background:transparent;
  border:0;border-bottom:1px solid var(--line);
  font:inherit;
  color:var(--ink);
  border-radius:0;
  transition:border-color .3s var(--ease);
}
.field input:focus,.field select:focus{outline:none;border-bottom-color:var(--accent)}
.check{display:flex;gap:.7rem;align-items:flex-start;margin:1.2rem 0 1.6rem;font-size:.88rem;color:var(--ink-soft)}
.check input{margin-top:.25rem;accent-color:var(--accent)}
.form__hint{
  margin:.9rem 0 0;
  font-size:.78rem;color:var(--ink-mute);text-align:center;
}
.form__success{
  margin:.9rem 0 0;
  font-size:1rem;color:var(--accent);text-align:center;
  font-family:var(--script);font-style:italic;
}

@media (max-width:820px){
  .register__wrap{grid-template-columns:1fr}
  .form__row{grid-template-columns:1fr}
  .register__facts li{grid-template-columns:100px 1fr}
}

/* ───────────────────────────────────────────────
   HAZLO POSIBLE (Fund)
   ─────────────────────────────────────────────── */
.fund{
  background:var(--sand);
  text-align:center;
}
.fund__wrap{max-width:880px;margin:0 auto}
.fund__title{
  font-family:var(--serif);
  font-variation-settings: 'opsz' 16, 'wght' 600;
  font-size:var(--r5);
  font-weight:600;
  margin-bottom:1.4rem;
  line-height:1.1;
  color:var(--ink);
}
.fund__title .accent{font-size:1em}
.fund__copy{
  font-size:var(--r2);color:var(--ink-soft);
  max-width:60ch;margin:0 auto 2.4rem;
}
.fund__progress{margin:2.4rem auto 2rem;max-width:680px}
.fund__bar{
  height:5px;background:rgba(61,58,48,.12);
  border-radius:999px;overflow:hidden;
}
.fund__fill{
  display:block;height:100%;width:var(--p,0%);
  background:var(--accent);
  border-radius:999px;
  transform-origin:left;
  transform:scaleX(0);
  animation:barFill 1.4s var(--ease) .3s forwards;
}
@keyframes barFill{to{transform:scaleX(1)}}
.fund__meta{
  display:flex;justify-content:space-between;margin-top:1rem;
  font-size:.86rem;color:var(--ink-soft);
}
.fund__meta strong{display:block;font-family:var(--serif);font-variation-settings:'opsz' 14, 'wght' 600;font-size:1.3rem;font-weight:600;color:var(--ink);letter-spacing:-.01em}
.fund__meta span{font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-mute);display:block;margin-top:.2rem;font-weight:500}
.fund__meta--alt{text-align:right}
.fund__ctas{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap;margin-top:1.6rem}
.fund__note{margin-top:1.8rem;font-size:.82rem;color:var(--ink-mute);max-width:50ch;margin-left:auto;margin-right:auto}

/* ───────────────────────────────────────────────
   EDICIONES
   ─────────────────────────────────────────────── */
.editions{background:var(--paper)}
.editions__head{max-width:780px;margin-bottom:clamp(3rem,6vw,4.5rem)}
.editions__head h2{font-size:var(--r5)}
.editions__intro{margin-top:1.4rem;font-size:var(--r2);color:var(--ink-soft);max-width:54ch}
.editions__grid{
  list-style:none;padding:0;margin:0;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:clamp(1.4rem,3vw,2.4rem);
}
.edition{
  background:var(--paper-2);
  border-radius:6px;
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .6s var(--ease);
}
.edition:hover{transform:translateY(-3px)}
.edition__img{
  aspect-ratio:4/5;
  position:relative;
  overflow:hidden;
  background:var(--sage-soft);
}
.edition__img img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1.6s var(--ease);
}
.edition:hover .edition__img img{transform:scale(1.05)}
.edition__body{padding:1.6rem 1.6rem 1.8rem;display:flex;flex-direction:column;flex:1}
.edition__no{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);margin:0 0 .8rem;font-weight:500}
.edition__body h3{margin:0 0 .7rem;font-size:1.5rem}
.edition__desc{font-size:.92rem;color:var(--ink-soft);margin:0 0 1.4rem;flex:1}
.edition__meta{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--line)}
.edition__meta span{font-family:var(--serif);font-variation-settings:'opsz' 12, 'wght' 600;font-size:1.1rem;font-weight:600;color:var(--ink)}
.edition__cta{font-size:.85rem;letter-spacing:.06em;color:var(--accent);font-weight:500;transition:transform .3s var(--ease);display:inline-block}
.edition__cta:hover{transform:translateX(3px)}

@media (max-width:820px){.editions__grid{grid-template-columns:1fr}}

/* ───────────────────────────────────────────────
   RESPALDO
   ─────────────────────────────────────────────── */
.backing{background:var(--sage-soft)}
.backing h2{font-size:var(--r5);max-width:18ch;margin-bottom:clamp(2.4rem,5vw,3.6rem)}
.backing__grid{
  list-style:none;padding:0;margin:0;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:0;
  border-top:1px solid var(--line);
}
.backing__cell{
  padding:clamp(1.6rem,3vw,2.4rem) clamp(1rem,2vw,1.8rem);
  border-bottom:1px solid var(--line);
  border-right:1px solid var(--line);
}
.backing__cell:nth-child(2n){border-right:0}
.backing__date{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);margin:0 0 1rem;font-weight:500}
.backing__cell h3{font-size:1.4rem;margin:0 0 .7rem;font-variation-settings:'opsz' 12, 'wght' 600}
.backing__cell p{font-size:.95rem;color:var(--ink-soft);margin:0}

@media (max-width:680px){
  .backing__grid{grid-template-columns:1fr}
  .backing__cell{border-right:0}
}

/* ───────────────────────────────────────────────
   ALIADOS
   ─────────────────────────────────────────────── */
.allies{background:var(--serenity);color:var(--ink)}
.allies h2{font-size:var(--r5);max-width:14ch}
.allies__intro{margin-top:1.4rem;font-size:var(--r2);color:var(--ink-soft);max-width:54ch;margin-bottom:clamp(2.4rem,5vw,3.6rem)}
.allies__grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:1.2rem;
}
.ally{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:1.2rem;
  padding:clamp(1.4rem,3vw,2rem);
  background:rgba(242,235,224,.6);
  border:1px solid rgba(61,58,48,.12);
  border-radius:8px;
  transition:background .4s var(--ease),transform .5s var(--ease);
}
.ally:hover{background:var(--paper);transform:translateY(-2px)}
.ally__role{font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-mute);min-width:140px;font-weight:500}
.ally__title{font-family:var(--serif);font-variation-settings:'opsz' 14, 'wght' 600;font-size:1.3rem;font-weight:600;color:var(--ink)}
.ally__arrow{font-size:1.3rem;color:var(--ink)}

@media (max-width:820px){
  .allies__grid{grid-template-columns:1fr}
  .ally__role{min-width:0}
}

/* ───────────────────────────────────────────────
   CIERRE
   ─────────────────────────────────────────────── */
.closer{
  position:relative;
  background:#1F1D18;
  color:var(--paper);
  text-align:center;
  padding:clamp(7rem,12vw,10rem) 0;
  overflow:hidden;
  isolation:isolate;
}
.closer__bg{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  z-index:-2;
  filter:saturate(.95) brightness(.7);
}
.closer__veil{
  position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg, rgba(20,18,12,.55) 0%, rgba(20,18,12,.4) 50%, rgba(20,18,12,.7) 100%);
}
.closer__line{
  font-family:var(--serif);
  font-variation-settings: 'opsz' 16, 'wght' 600;
  font-size:var(--r6);
  font-weight:600;
  line-height:1.08;
  letter-spacing:-.01em;
  margin:0 0 clamp(2rem,4vw,3rem);
  color:var(--paper);
  text-shadow:0 2px 24px rgba(20,18,12,.4);
}
.closer__line em{font-style:italic;color:var(--serenity);font-weight:500}
.closer .btn--solid{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.closer .btn--solid:hover{background:transparent;color:var(--paper)}

/* ───────────────────────────────────────────────
   FOOTER
   ─────────────────────────────────────────────── */
.footer{
  background:#2E2C24;
  color:rgba(242,235,224,.78);
  padding-top:clamp(4rem,7vw,6rem);
}
.footer__wrap{
  display:grid;
  grid-template-columns:1.2fr 2fr;
  gap:clamp(2rem,5vw,4rem);
  padding-bottom:clamp(3rem,5vw,4rem);
}
.footer__brand .mark-glyph{width:48px;height:48px;color:var(--serenity);margin-bottom:1rem}
.footer__logo{height:96px;width:auto;display:block;margin-bottom:1rem;filter:brightness(0) invert(1) opacity(.92)}
.footer__wordmark{
  font-family:var(--serif);
  font-variation-settings:'opsz' 36, 'wght' 600;
  font-size:clamp(1.8rem,3.2vw,2.4rem);
  line-height:1;
  letter-spacing:.005em;
  color:var(--paper);
  margin:0 0 1.2rem;
  font-weight:600;
}
.footer__wordmark em{
  font-style:italic;
  font-weight:500;
  color:var(--serenity-soft);
  font-variation-settings:'opsz' 36, 'wght' 500;
}
.footer__name{font-family:var(--serif);font-variation-settings:'opsz' 14, 'wght' 600;font-size:1.3rem;color:var(--paper);margin:0 0 .3rem;font-weight:600}
.footer__tag{font-size:.85rem;margin:0;color:rgba(242,235,224,.6)}

.footer__social{
  list-style:none;
  margin:1.6rem 0 0;
  padding:0;
  display:flex;
  gap:.6rem;
  flex-wrap:wrap;
}
.footer__social a{
  display:flex;
  align-items:center;
  justify-content:center;
  width:38px;
  height:38px;
  border-radius:50%;
  border:1px solid rgba(242,235,224,.25);
  color:rgba(242,235,224,.78);
  text-decoration:none;
  transition:background .25s ease, color .25s ease, border-color .25s ease, transform .25s ease;
}
.footer__social a:hover{
  background:var(--serenity);
  color:var(--ink);
  border-color:var(--serenity);
  transform:translateY(-2px);
}
.footer__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.footer__h{font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--serenity);margin:0 0 1rem;font-weight:500}
.footer__cols a{display:block;margin-bottom:.5rem;font-size:.92rem;color:rgba(242,235,224,.85);transition:color .3s var(--ease)}
.footer__cols a:hover{color:var(--paper)}

.footer__legal{
  border-top:1px solid rgba(242,235,224,.12);
  padding:1.4rem 0;
  font-size:.78rem;color:rgba(242,235,224,.55);
}
.footer__legal-row{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}

@media (max-width:820px){
  .footer__wrap{grid-template-columns:1fr}
  .footer__cols{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:520px){
  .footer__cols{grid-template-columns:1fr 1fr}
}

/* ───────────────────────────────────────────────
   ACT — Reserva + Hazlo posible (sección combinada)
   ─────────────────────────────────────────────── */
.act{background:var(--serenity-soft);padding-top:clamp(2.5rem,5vw,4.5rem);padding-bottom:clamp(3.5rem,6vw,6rem)}
.act__head{max-width:760px;margin:0 auto clamp(1.6rem,3.5vw,2.6rem);text-align:center}
.act__title{
  font-family:var(--serif);
  font-variation-settings:'opsz' 14, 'wght' 600;
  font-size:var(--r5);
  font-weight:600;
  line-height:1.05;
  letter-spacing:-.01em;
  color:var(--ink);
}
.act__title .accent{
  font-family:var(--script);
  font-style:italic;
  font-weight:500;
  color:var(--accent);
}
.act__intro{
  margin:1.2rem auto 0;
  font-size:var(--r2);color:var(--ink-soft);
  max-width:54ch;
}

.act__grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:clamp(1.4rem,3vw,2.2rem);
  align-items:start;
}
.act__panel{
  background:var(--paper);
  padding:clamp(1.8rem,3vw,2.6rem);
  border:1px solid var(--line);
  border-radius:6px;
}
.act__panel--fund{background:var(--sand)}
.act__no{
  font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--ink-mute);font-weight:500;margin:0 0 1rem;
}
.act__h{
  font-family:var(--serif);
  font-variation-settings:'opsz' 12, 'wght' 600;
  font-size:clamp(1.6rem,2.4vw,2.1rem);
  font-weight:600;
  line-height:1.1;
  color:var(--ink);
  margin:0 0 .9rem;
  letter-spacing:-.005em;
}
.act__copy{
  font-size:.98rem;color:var(--ink-soft);
  margin:0 0 1.6rem;line-height:1.55;
}

.act__panel--register .form{
  background:transparent;
  padding:0;
  border:0;
  border-radius:0;
}

.act__amounts{
  display:grid;grid-template-columns:repeat(5,minmax(0,1fr));
  gap:.5rem;margin:1.4rem 0 1.2rem;
}
.amount{
  appearance:none;border:1px solid var(--line);background:transparent;
  padding:.7rem .35rem;font:inherit;font-size:.86rem;color:var(--ink);
  border-radius:4px;cursor:pointer;font-weight:500;
  transition:border-color .25s var(--ease),color .25s var(--ease),background .25s var(--ease);
}
.amount:hover{border-color:var(--accent);color:var(--accent)}
.amount--feat{background:var(--paper);border-color:var(--accent);color:var(--accent)}

.act__fund-ctas{display:grid;gap:.6rem;margin-top:1rem}
.act__panel--fund .fund__progress{margin:0 0 .4rem;max-width:none}

.act__note{
  margin:1.4rem 0 0;
  font-size:.78rem;color:var(--ink-mute);text-align:center;
  line-height:1.5;
}

.act__facts{
  list-style:none;
  padding:clamp(1.6rem,3vw,2.2rem) 0 0;
  margin:clamp(2.4rem,4vw,3.2rem) auto 0;
  max-width:880px;
  border-top:1px solid color-mix(in oklab, var(--ink) 14%, transparent);
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(1rem,2.4vw,2rem);
  text-align:center;
}
.act__facts li{
  display:flex;
  flex-direction:column;
  gap:.45rem;
  align-items:center;
}
.act__facts span{
  font-size:.7rem;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--ink-mute);
  font-weight:500;
}
.act__facts strong{
  font-family:var(--serif);
  font-size:1.02rem;
  font-weight:500;
  color:var(--ink);
  letter-spacing:-.005em;
}
@media (max-width:640px){
  .act__facts{grid-template-columns:1fr;text-align:left}
  .act__facts li{
    flex-direction:row;
    align-items:baseline;
    justify-content:space-between;
    gap:1rem;
    padding-bottom:.6rem;
    border-bottom:1px solid color-mix(in oklab, var(--ink) 8%, transparent);
  }
  .act__facts li:last-child{border-bottom:0;padding-bottom:0}
}

@media (max-width:880px){
  .act__grid{grid-template-columns:1fr}
  .act__amounts{grid-template-columns:repeat(3,1fr)}
  .act__amounts .amount:nth-child(4){grid-column:1/3}
  .act__amounts .amount:nth-child(5){grid-column:3/4}
}

/* ───────────────────────────────────────────────
   Programa del día
   ─────────────────────────────────────────────── */
.program{padding:clamp(3rem,5vw,5rem) 0;background:var(--ivory)}
.program__wrap{max-width:920px}
.program__head{max-width:760px;margin:0 auto clamp(48px,7vw,80px);text-align:center}
.program__head h2{font-size:clamp(2rem,3.6vw,3.2rem);line-height:1.08;letter-spacing:-.01em}
.program__lead{
  margin-top:18px;
  font-family:var(--font-serif);
  font-size:1.08rem;
  line-height:1.6;
  color:color-mix(in oklab, var(--ink) 72%, transparent);
}

.program__timeline{
  list-style:none;
  margin:0;
  padding:0;
  position:relative;
  display:flex;
  flex-direction:column;
  gap:28px;
}
.program__timeline::before{
  content:'';
  position:absolute;
  left:80px;
  top:18px;
  bottom:18px;
  width:1px;
  background:color-mix(in oklab, var(--ink) 18%, transparent);
}

.program__step{
  display:grid;
  grid-template-columns:100px 1fr;
  gap:36px;
  align-items:flex-start;
  position:relative;
}

.program__time{
  text-align:right;
  padding-top:18px;
  position:relative;
}
.program__time::after{
  content:'';
  position:absolute;
  right:-22px;
  top:28px;
  width:13px;
  height:13px;
  border-radius:50%;
  background:#fff;
  border:2px solid var(--accent);
  box-shadow:0 0 0 4px var(--ivory);
}
.program__hour{
  display:block;
  font-family:var(--font-display);
  font-size:1.35rem;
  font-weight:500;
  color:var(--ink);
  letter-spacing:-.01em;
  line-height:1;
}
.program__ampm{
  display:block;
  font-family:var(--font-sans);
  font-size:.72rem;
  font-weight:500;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:color-mix(in oklab, var(--ink) 55%, transparent);
  margin-top:4px;
}

.program__card{
  background:#fff;
  border:1px solid color-mix(in oklab, var(--ink) 10%, transparent);
  border-radius:16px;
  padding:24px 28px;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.program__card:hover{
  transform:translateY(-2px);
  border-color:color-mix(in oklab, var(--accent) 35%, transparent);
  box-shadow:0 12px 32px -20px color-mix(in oklab, var(--ink) 30%, transparent);
}
.program__tag{
  display:inline-block;
  font-family:var(--font-sans);
  font-size:.7rem;
  font-weight:600;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:color-mix(in oklab, var(--ink) 60%, transparent);
  margin:0 0 10px;
}
.program__tag--accent{color:var(--accent)}
.program__card h3{
  margin:0 0 8px;
  font-family:var(--font-display);
  font-size:clamp(1.15rem,1.7vw,1.4rem);
  font-weight:500;
  letter-spacing:-.005em;
  line-height:1.25;
}
.program__card p{
  margin:0;
  font-family:var(--font-serif);
  font-size:1rem;
  line-height:1.6;
  color:color-mix(in oklab, var(--ink) 76%, transparent);
}

/* Paso destacado: 14:00 — el momento */
.program__step--hero .program__card{
  background:linear-gradient(180deg, var(--serenity-soft), #fff);
  border-color:color-mix(in oklab, var(--accent) 40%, transparent);
  box-shadow:0 18px 40px -24px color-mix(in oklab, var(--accent) 60%, transparent);
}
.program__step--hero .program__time::after{
  width:17px;height:17px;
  background:var(--accent);
  border-color:var(--accent);
  right:-24px;
  top:26px;
}
.program__step--hero .program__hour{
  font-size:1.6rem;
  color:var(--accent);
}

.program__note{
  margin:clamp(36px,5vw,56px) auto 0;
  max-width:680px;
  text-align:center;
  font-family:var(--font-serif);
  font-size:.96rem;
  line-height:1.55;
  color:color-mix(in oklab, var(--ink) 65%, transparent);
  font-style:italic;
}
.program__note strong{font-style:normal;color:var(--ink)}

@media (max-width:680px){
  .program__timeline::before{left:62px}
  .program__step{grid-template-columns:80px 1fr;gap:26px}
  .program__time::after{right:-19px;top:22px;width:11px;height:11px}
  .program__step--hero .program__time::after{right:-21px;width:15px;height:15px}
  .program__card{padding:20px 22px}
  .program__hour{font-size:1.2rem}
  .program__step--hero .program__hour{font-size:1.4rem}
}

/* ───────────────────────────────────────────────
   Cómo llegar
   ─────────────────────────────────────────────── */
.getthere{padding:clamp(3rem,5vw,5rem) 0;background:var(--serenity-soft)}
.getthere__wrap{max-width:1120px}
.getthere__head{max-width:760px;margin:0 auto clamp(40px,6vw,72px);text-align:center}
.getthere__head h2{font-size:clamp(2rem,3.6vw,3.2rem);line-height:1.08;letter-spacing:-.01em}
.getthere__lead{
  margin-top:18px;
  font-family:var(--font-serif);
  font-size:1.08rem;
  line-height:1.6;
  color:color-mix(in oklab, var(--ink) 72%, transparent);
}

.getthere__grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:clamp(20px,3vw,40px);
  align-items:stretch;
}

.getthere__map{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  background:#000;
  min-height:420px;
  box-shadow:0 18px 48px -28px color-mix(in oklab, var(--ink) 40%, transparent);
}
.getthere__map iframe{
  width:100%;
  height:100%;
  border:0;
  display:block;
  filter:grayscale(.18) contrast(1.02);
  min-height:420px;
}
.getthere__open{
  position:absolute;
  left:16px;bottom:16px;
  background:rgba(255,255,255,.95);
  color:var(--ink);
  padding:10px 16px;
  border-radius:999px;
  font-family:var(--font-sans);
  font-size:.92rem;
  font-weight:500;
  text-decoration:none;
  letter-spacing:.01em;
  box-shadow:0 6px 24px -8px rgba(0,0,0,.3);
  transition:transform .2s ease, background .2s ease;
}
.getthere__open:hover{transform:translateY(-1px);background:#fff}

.getthere__modes{display:flex;flex-direction:column;gap:14px}

.mode{
  display:flex;
  gap:18px;
  align-items:flex-start;
  padding:20px 22px;
  background:#fff;
  border-radius:14px;
  border:1px solid color-mix(in oklab, var(--ink) 10%, transparent);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.mode:hover{
  transform:translateY(-2px);
  border-color:color-mix(in oklab, var(--accent) 35%, transparent);
  box-shadow:0 12px 32px -20px color-mix(in oklab, var(--ink) 30%, transparent);
}
.mode__icon{
  flex:0 0 44px;
  width:44px;height:44px;
  border-radius:50%;
  background:var(--serenity-soft);
  color:var(--accent);
  display:flex;
  align-items:center;
  justify-content:center;
}
.mode__body h3{
  margin:0 0 4px;
  font-family:var(--font-display);
  font-size:1.12rem;
  font-weight:500;
  letter-spacing:-.005em;
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.mode__body p{
  margin:0;
  font-family:var(--font-serif);
  font-size:.98rem;
  line-height:1.55;
  color:color-mix(in oklab, var(--ink) 78%, transparent);
}
.mode__tag{
  display:inline-block;
  font-family:var(--font-sans);
  font-size:.7rem;
  font-weight:600;
  letter-spacing:.06em;
  text-transform:uppercase;
  padding:3px 10px;
  border-radius:999px;
  color:#fff;
}
.mode__tag--blue{background:#1c4ea3}
.mode__tag--red{background:#b9362e}

.getthere__tips{
  list-style:none;
  margin:clamp(36px,5vw,56px) 0 0;
  padding:0;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.getthere__tips li{
  background:#fff;
  border-radius:14px;
  padding:22px 18px;
  text-align:center;
  border:1px solid color-mix(in oklab, var(--ink) 8%, transparent);
}
.tips__num{
  display:block;
  font-family:var(--font-display);
  font-size:1.25rem;
  font-weight:500;
  color:var(--accent);
  letter-spacing:-.005em;
  margin-bottom:4px;
}
.tips__txt{
  display:block;
  font-family:var(--font-sans);
  font-size:.86rem;
  line-height:1.4;
  color:color-mix(in oklab, var(--ink) 70%, transparent);
}

@media (max-width:880px){
  .getthere__grid{grid-template-columns:1fr}
  .getthere__map{min-height:320px}
  .getthere__map iframe{min-height:320px}
  .getthere__tips{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:480px){
  .mode{padding:16px 18px;gap:14px}
  .mode__icon{flex:0 0 38px;width:38px;height:38px}
}

/* ───────────────────────────────────────────────
   FAQ
   ─────────────────────────────────────────────── */
.faq{padding:clamp(3rem,5vw,5rem) 0;background:var(--ivory)}
.faq__wrap{max-width:880px}
.faq__head{text-align:center;margin-bottom:clamp(40px,6vw,72px)}
.faq__head h2{font-size:clamp(2rem,3.6vw,3.2rem);line-height:1.08;letter-spacing:-.01em}
.faq__list{display:flex;flex-direction:column;gap:14px}

.faq__item{
  border:1px solid color-mix(in oklab, var(--ink) 14%, transparent);
  border-radius:14px;
  background:#fff;
  overflow:hidden;
  transition:border-color .25s ease, box-shadow .25s ease;
}
.faq__item[open]{
  border-color:color-mix(in oklab, var(--accent) 40%, transparent);
  box-shadow:0 8px 30px -16px color-mix(in oklab, var(--ink) 30%, transparent);
}

.faq__item > summary{
  list-style:none;
  cursor:pointer;
  padding:22px 26px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  font-family:var(--font-display);
  font-size:clamp(1.05rem,1.6vw,1.25rem);
  font-weight:500;
  color:var(--ink);
  line-height:1.35;
}
.faq__item > summary::-webkit-details-marker{display:none}

.faq__icon{
  width:22px;height:22px;flex:0 0 22px;
  position:relative;
  transition:transform .3s ease;
}
.faq__icon::before,
.faq__icon::after{
  content:'';position:absolute;left:50%;top:50%;
  background:var(--accent);
  transition:transform .3s ease, opacity .3s ease;
}
.faq__icon::before{width:14px;height:1.5px;transform:translate(-50%,-50%)}
.faq__icon::after{width:1.5px;height:14px;transform:translate(-50%,-50%)}
.faq__item[open] .faq__icon::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}

.faq__body{
  padding:0 26px 24px;
  color:color-mix(in oklab, var(--ink) 78%, transparent);
  font-family:var(--font-serif);
  font-size:1.02rem;
  line-height:1.65;
}
.faq__body p{margin:0 0 10px}
.faq__body p:last-child{margin-bottom:0}
.faq__body a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}

@media (max-width:680px){
  .faq__item > summary{padding:18px 20px;font-size:1.02rem}
  .faq__body{padding:0 20px 20px;font-size:.98rem}
}

/* ───────────────────────────────────────────────
   Selección y focus
   ─────────────────────────────────────────────── */
::selection{background:var(--serenity);color:var(--ink)}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}

/* ───────────────────────────────────────────────
   MOBILE FIXES (≤520px) — corrige textos cortados,
   tarjetas comprimidas y paddings excesivos
   ─────────────────────────────────────────────── */
@media (max-width:520px){
  /* Countdown: que "SEGUNDOS" no se corte */
  .countdown__grid{gap:.25rem}
  .cd-cell{padding:.9rem .25rem}
  .cd-num{font-size:2.3rem}
  .cd-lbl{font-size:.6rem;letter-spacing:.18em}
  .countdown__foot{font-size:.95rem;line-height:1.5}

  /* Cinemática: balance entre altura para foto y texto legible */
  .cinematic{padding:3rem 0 8rem;min-height:60vh}
  .cinematic__line{font-size:1.85rem;line-height:1.2}

  /* Aliados: stack vertical limpio dentro de cada tarjeta */
  .ally{
    grid-template-columns:1fr auto;
    gap:.4rem 1rem;
    align-items:start;
  }
  .ally__role{
    grid-column:1 / -1;
    margin-bottom:.2rem;
  }
  .ally__title{font-size:1.15rem;line-height:1.25}
  .ally__arrow{align-self:center}

  /* Reducir el padding vertical de secciones grandes */
  section{padding:clamp(2.4rem,8vw,3.4rem) 0}
  .act{padding-top:2rem;padding-bottom:2.6rem}
  .program{padding:2.4rem 0}
  .getthere{padding:2.4rem 0}
  .faq{padding:2.4rem 0}

  /* Backing: tarjetas a una sola columna sin línea cortada */
  .backing__grid{grid-template-columns:1fr}
  .backing__cell{border-right:0;padding-left:0;padding-right:0}

  /* Footer: tipografía un poco más chica */
  .footer__wordmark{font-size:1.7rem}
}

