/* ============================================================
   Bridges for Dialogue — shared stylesheet
   Sistema aprobado: claro único · azul = acción · dorado = identidad
   Escala tipográfica: 7 pasos. Ningún color ni tamaño fuera de los tokens.
   ============================================================ */

:root{
  /* ── Base ── */
  --bg:#FAFAF8;
  --bg-alt:#F2F2EF;
  --border:#E5E5E2;
  --text:#111111;
  --text-2:#4A4A4A;

  /* ── Acción · azul océano ── */
  --blue:#1C2E4A;
  --blue-hover:#2C4A73;

  /* ── Identidad · dorado ── */
  --gold:#B8965A;
  --gold-dark:#8A6B3A;

  /* ── Escala tipográfica (7 pasos) ── */
  --fs-label:0.8125rem;                          /* 13px */
  --fs-small:0.9375rem;                          /* 15px */
  --fs-body:1.0625rem;                           /* 17px */
  --fs-lead:1.3125rem;                           /* 21px */
  --fs-h3:1.75rem;                               /* 28px */
  --fs-h2:clamp(2.25rem,4.5vw,3.25rem);          /* 36–52px */
  --fs-hero:clamp(3.25rem,7.5vw,5.625rem);       /* 52–90px */

  /* ── Familias ── */
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost','Helvetica Neue',sans-serif;
  --jp:'Noto Serif JP',serif;

  /* ── Ritmo ── */
  --section-pad:7rem;
  --container:1140px;
  --measure:620px;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{animation:none!important;transition:none!important;}
}

body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  font-weight:400;
  font-size:var(--fs-body);
  line-height:1.7;
}

img{display:block;max-width:100%;}
a{color:var(--blue);text-decoration:none;transition:color .25s;}
a:hover{color:var(--blue-hover);}
a:focus-visible,button:focus-visible{outline:2px solid var(--blue);outline-offset:3px;}

.container{max-width:var(--container);margin:0 auto;padding:0 2rem;}

/* ── Piezas tipográficas ── */
.label{
  font-size:var(--fs-label);
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--gold-dark);
  display:block;
  margin-bottom:1.25rem;
}
.section-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:var(--fs-h2);
  line-height:1.1;
  margin-bottom:1.5rem;
}
.section-title em{font-style:italic;color:var(--blue);}
.lead{font-size:var(--fs-lead);font-weight:300;color:var(--text-2);max-width:var(--measure);}
.small{font-size:var(--fs-small);color:var(--text-2);}

.gold-rule{
  width:64px;height:1px;background:var(--gold);
  border:none;margin:0 0 2.5rem;
}

/* Kanji de marca de agua — firma visual */
.kanji-mark{
  position:absolute;
  font-family:var(--jp);
  font-weight:200;
  color:var(--gold);
  opacity:.14;
  line-height:1;
  user-select:none;
  pointer-events:none;
  z-index:0;
}

.btn{
  display:inline-block;
  font-family:var(--sans);
  font-size:var(--fs-small);
  letter-spacing:.08em;
  padding:.95rem 2rem;
  border:1px solid var(--blue);
  transition:background .25s,color .25s,border-color .25s;
}
.btn-primary{background:var(--blue);color:#FFFFFF;}
.btn-primary:hover{background:var(--blue-hover);border-color:var(--blue-hover);color:#FFFFFF;}
.btn-ghost{background:transparent;color:var(--blue);}
.btn-ghost:hover{background:var(--blue);color:#FFFFFF;}
.text-link{font-size:var(--fs-small);letter-spacing:.04em;border-bottom:1px solid var(--gold);padding-bottom:2px;}

/* ============================================================
   NAVEGACIÓN
   ============================================================ */
#nav-toggle{position:absolute;opacity:0;pointer-events:none;}

.site-nav{
  position:sticky;top:0;z-index:100;
  background:rgba(250,250,248,.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--border);
}
.nav-inner{
  max-width:var(--container);margin:0 auto;
  padding:0 2rem;
  display:flex;align-items:center;justify-content:space-between;
  height:72px;
}
.nav-logo{
  font-family:var(--serif);
  font-size:var(--fs-h3);
  font-weight:500;
  color:var(--text);
  white-space:nowrap;
}
.nav-logo span{font-style:italic;font-weight:400;color:var(--gold-dark);}
.nav-links{list-style:none;display:flex;align-items:center;gap:2rem;}
.nav-links>li{position:relative;}
.nav-links a{
  font-size:var(--fs-small);
  letter-spacing:.06em;
  color:var(--text-2);
  padding:.5rem 0;
}
.nav-links a:hover{color:var(--blue);}
.nav-lang{
  font-size:var(--fs-label);
  letter-spacing:.18em;
  color:var(--gold-dark);
  border:1px solid var(--gold);
  padding:.35rem .7rem;
}
.nav-lang:hover{background:var(--gold);color:#FFFFFF;}

/* Dropdown escritorio */
.nav-dropdown{
  position:absolute;top:100%;left:50%;transform:translateX(-50%);
  background:var(--bg);
  border:1px solid var(--border);
  border-top:2px solid var(--gold);
  min-width:240px;
  padding:1.25rem 1.5rem;
  opacity:0;visibility:hidden;
  transition:opacity .25s,visibility .25s;
}
.nav-has-dropdown:hover .nav-dropdown,
.nav-has-dropdown:focus-within .nav-dropdown{opacity:1;visibility:visible;}
.dropdown-group{
  font-size:var(--fs-label);letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold-dark);margin:.75rem 0 .35rem;
}
.dropdown-group:first-child{margin-top:0;}
.nav-dropdown a{display:block;padding:.35rem 0;color:var(--text);white-space:nowrap;}
.nav-dropdown a:hover{color:var(--blue);padding-left:.35rem;transition:padding .2s,color .2s;}

/* Hamburguesa */
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.5rem;}
.nav-hamburger span{width:24px;height:1.5px;background:var(--text);transition:transform .25s,opacity .25s;}

/* Menú móvil */
.nav-mobile{display:none;}

@media (max-width:900px){
  .nav-links{display:none;}
  .nav-hamburger{display:flex;}
  .nav-mobile{
    display:block;
    max-height:0;overflow:hidden;
    transition:max-height .35s ease;
    background:var(--bg);
    border-bottom:0 solid var(--border);
  }
  #nav-toggle:checked ~ .nav-mobile{max-height:480px;border-bottom-width:1px;}
  #nav-toggle:checked ~ .nav-inner .nav-hamburger span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
  #nav-toggle:checked ~ .nav-inner .nav-hamburger span:nth-child(2){opacity:0;}
  #nav-toggle:checked ~ .nav-inner .nav-hamburger span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}
  .nav-mobile ul{list-style:none;padding:1rem 2rem 1.5rem;}
  .nav-mobile a{display:block;padding:.65rem 0;font-size:var(--fs-body);color:var(--text);border-bottom:1px solid var(--border);}
  .nav-mobile .mobile-group{
    font-size:var(--fs-label);letter-spacing:.16em;text-transform:uppercase;
    color:var(--gold-dark);padding:1rem 0 .25rem;
  }
  .nav-mobile .mobile-sub a{padding-left:1rem;color:var(--text-2);}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  padding:8rem 0 7rem;
  overflow:hidden;
}
.hero .kanji-mark{
  top:50%;right:-2rem;
  transform:translateY(-50%);
  font-size:clamp(16rem,32vw,26rem);
}
.hero-content{position:relative;z-index:1;max-width:780px;}
.hero-tagline{
  font-size:var(--fs-label);letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-dark);margin-bottom:2rem;
}
.hero-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:var(--fs-hero);
  line-height:1.02;
  margin-bottom:2.5rem;
}
.hero-title em{font-style:italic;color:var(--blue);}
.hero-quote{
  font-family:var(--serif);
  font-size:var(--fs-lead);
  font-style:italic;
  color:var(--text-2);
  border-left:1px solid var(--gold);
  padding-left:1.5rem;
  margin-bottom:2rem;
  max-width:var(--measure);
}
.hero-quote em{color:var(--gold-dark);}
.hero-text{max-width:var(--measure);margin-bottom:3rem;color:var(--text-2);}
.hero-actions{display:flex;gap:1.25rem;flex-wrap:wrap;align-items:center;}

/* ============================================================
   SECCIONES
   ============================================================ */
.section{position:relative;padding:var(--section-pad) 0;overflow:hidden;}
.section-alt{background:var(--bg-alt);}
.section-head{position:relative;z-index:1;margin-bottom:4rem;}

/* ── Franja de próximo evento ── */
.event-strip{
  position:relative;z-index:1;
  display:flex;align-items:center;gap:2rem;
  background:var(--bg);
  border:1px solid var(--border);
  border-left:3px solid var(--gold);
  padding:1.5rem 2rem;
  margin-bottom:2.5rem;
  color:var(--text);
  transition:transform .3s,box-shadow .3s;
}
.event-strip:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(28,46,74,.08);color:var(--text);}
.event-date{display:flex;flex-direction:column;align-items:center;min-width:84px;border-right:1px solid var(--border);padding-right:1.75rem;}
.event-day{font-family:var(--serif);font-size:var(--fs-h2);font-weight:400;line-height:1;color:var(--blue);}
.event-month{font-size:var(--fs-label);letter-spacing:.14em;text-transform:uppercase;color:var(--gold-dark);margin-top:.35rem;white-space:nowrap;}
.event-info{display:flex;flex-direction:column;gap:.3rem;}
.event-eyebrow{font-size:var(--fs-label);letter-spacing:.18em;text-transform:uppercase;color:var(--gold-dark);}
.event-title{font-family:var(--serif);font-weight:500;font-size:var(--fs-h3);line-height:1.2;}
.event-detail{font-size:var(--fs-small);color:var(--text-2);}
.event-arrow{margin-left:auto;font-size:var(--fs-h3);color:var(--gold-dark);transition:transform .3s;}
.event-strip:hover .event-arrow{transform:translateX(6px);}

/* ── Iniciativas ── */
.initiative-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;
}
.initiative-card{
  background:var(--bg);
  border:1px solid var(--border);
  border-top:2px solid var(--gold);
  display:flex;flex-direction:column;
  transition:transform .3s,box-shadow .3s;
}
.initiative-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(28,46,74,.08);}
.card-media{position:relative;aspect-ratio:16/9;overflow:hidden;}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s;}
.initiative-card:hover .card-media img{transform:scale(1.04);}
.card-kanji{
  position:absolute;top:1rem;right:1.25rem;
  font-family:var(--jp);font-weight:200;
  font-size:2.5rem;line-height:1;
  color:#FFFFFF;
  text-shadow:0 1px 8px rgba(0,0,0,.45);
}
.card-body{padding:2rem 2rem 2.25rem;display:flex;flex-direction:column;flex:1;}
.card-eyebrow{
  font-size:var(--fs-label);letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold-dark);margin-bottom:.75rem;
}
.card-title{
  font-family:var(--serif);font-weight:500;
  font-size:var(--fs-h3);line-height:1.15;margin-bottom:.5rem;
}
.card-sub{font-size:var(--fs-small);color:var(--text-2);margin-bottom:1.5rem;}
.card-meta{
  list-style:none;
  border-top:1px solid var(--border);
  margin-bottom:1.75rem;
}
.card-meta li{
  display:flex;justify-content:space-between;gap:1rem;
  padding:.6rem 0;
  border-bottom:1px solid var(--border);
  font-size:var(--fs-small);
}
.card-meta .k{color:var(--text-2);letter-spacing:.04em;}
.card-meta .v{text-align:right;}
.card-body .text-link{margin-top:auto;align-self:flex-start;}

/* ── Fundadoras ── */
.founders-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;gap:4rem;
}
.founder-portrait{
  border:1px solid var(--gold);
  padding:10px;
  margin-bottom:1.75rem;
}
.founder-portrait img{
  width:100%;aspect-ratio:3/4;object-fit:cover;object-position:top;
  filter:grayscale(15%);
}
.founder-role{
  font-size:var(--fs-label);letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold-dark);margin-bottom:.6rem;
}
.founder-name{
  font-family:var(--serif);font-weight:500;
  font-size:var(--fs-h3);margin-bottom:.4rem;
}
.founder-credentials{font-size:var(--fs-small);color:var(--blue);margin-bottom:1.25rem;}
.founder-bio{color:var(--text-2);margin-bottom:1.5rem;}

/* ── Trayectoria ── */
.timeline{position:relative;z-index:1;max-width:820px;}
.phase{
  position:relative;
  padding:0 0 3rem 2.5rem;
  border-left:1px solid var(--gold);
}
.phase:last-child{padding-bottom:0;}
.phase::before{
  content:"";
  position:absolute;left:-5px;top:.5rem;
  width:9px;height:9px;border-radius:50%;
  background:var(--bg-alt);
  border:1px solid var(--gold-dark);
}
.phase-years{
  font-family:var(--serif);font-size:var(--fs-h3);font-weight:400;
  line-height:1.1;
}
.phase-tag{
  font-size:var(--fs-label);letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold-dark);margin:.35rem 0 .75rem;
}
.phase-title{font-weight:500;font-size:var(--fs-body);margin-bottom:.5rem;}
.phase p{color:var(--text-2);max-width:var(--measure);}

/* ── Galería ── */
.gallery-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;
}
.gallery-grid figure{position:relative;aspect-ratio:4/3;overflow:hidden;cursor:pointer;margin:0;}
.gallery-grid img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.85);
  transition:filter .4s,transform .4s;
}
.gallery-grid figure:hover img,
.gallery-grid figure:focus-visible img{filter:saturate(1);transform:scale(1.04);}
.gallery-grid figcaption{
  position:absolute;inset:auto 0 0 0;
  padding:1.75rem 1rem .75rem;
  font-size:var(--fs-small);
  color:#FFFFFF;
  background:linear-gradient(transparent,rgba(17,17,17,.65));
  opacity:0;transition:opacity .4s;
}
.gallery-grid figure:hover figcaption,
.gallery-grid figure:focus-visible figcaption{opacity:1;}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:200;
  background:rgba(17,17,17,.92);
  display:none;
  align-items:center;justify-content:center;
  flex-direction:column;
  padding:3rem 1.5rem;
}
.lightbox.open{display:flex;}
.lightbox img{max-width:min(92vw,1000px);max-height:78vh;object-fit:contain;}
.lightbox-cap{color:#FFFFFF;font-size:var(--fs-small);margin-top:1rem;opacity:.85;}
.lightbox button{
  position:absolute;
  background:none;border:none;cursor:pointer;
  color:#FFFFFF;font-family:var(--sans);font-size:2rem;line-height:1;
  padding:.75rem;opacity:.75;transition:opacity .2s;
}
.lightbox button:hover{opacity:1;}
.lb-close{top:1.25rem;right:1.5rem;}
.lb-prev{left:1rem;top:50%;transform:translateY(-50%);}
.lb-next{right:1rem;top:50%;transform:translateY(-50%);}

/* ── Franja CTA · único bloque azul ── */
.cta-band{
  position:relative;
  background:var(--blue);
  padding:var(--section-pad) 0;
  overflow:hidden;
}
.cta-band .kanji-mark{
  color:var(--gold);opacity:.18;
  font-size:clamp(12rem,22vw,18rem);
  top:50%;right:-1rem;transform:translateY(-50%);
}
.cta-inner{position:relative;z-index:1;max-width:740px;}
.cta-band .label{color:var(--gold);}
.cta-band .gold-rule{background:var(--gold);}
.cta-title{
  font-family:var(--serif);font-weight:400;
  font-size:var(--fs-h2);line-height:1.15;
  color:#FFFFFF;margin-bottom:1.5rem;
}
.cta-title em{font-style:italic;color:var(--gold);}
.cta-band p{color:rgba(255,255,255,.78);max-width:var(--measure);margin-bottom:2.5rem;}
.cta-actions{display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap;}
.btn-light{background:#FFFFFF;color:var(--blue);border-color:#FFFFFF;}
.btn-light:hover{background:transparent;color:#FFFFFF;}
.cta-band .text-link{color:#FFFFFF;}
.cta-band .text-link:hover{color:var(--gold);}
.cta-place{
  position:relative;z-index:1;
  margin-top:3.5rem;
  font-size:var(--fs-label);letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.5);
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  border-top:1px solid var(--border);
  padding:4.5rem 0 2.5rem;
  background:var(--bg);
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:3rem;
  margin-bottom:3.5rem;
}
.footer-brand .nav-logo{font-size:var(--fs-lead);}
.footer-brand p{font-size:var(--fs-small);color:var(--text-2);margin-top:.75rem;}
.footer-col h4{
  font-size:var(--fs-label);letter-spacing:.16em;text-transform:uppercase;
  font-weight:400;color:var(--gold-dark);margin-bottom:1rem;
}
.footer-col ul{list-style:none;}
.footer-col a{
  display:block;padding:.3rem 0;
  font-size:var(--fs-small);color:var(--text-2);
}
.footer-col a:hover{color:var(--blue);}
.footer-bottom{
  border-top:1px solid var(--border);
  padding-top:1.75rem;
  display:flex;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;
  font-size:var(--fs-small);color:var(--text-2);
}

/* ============================================================
   PÁGINAS INTERIORES
   ============================================================ */
.page-header{
  position:relative;
  padding:6rem 0 4.5rem;
  border-bottom:1px solid var(--border);
  overflow:hidden;
}
.page-header .kanji-mark{
  top:50%;right:-2rem;transform:translateY(-50%);
  font-size:clamp(12rem,24vw,20rem);
}
.page-header-content{position:relative;z-index:1;max-width:780px;}
.page-title{
  font-family:var(--serif);font-weight:400;
  font-size:var(--fs-hero);line-height:1.05;
  margin-bottom:1.75rem;
}
.page-title em{font-style:italic;color:var(--blue);}
.breadcrumb{
  font-size:var(--fs-label);letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold-dark);margin-bottom:1.75rem;
}
.breadcrumb a{color:var(--gold-dark);}
.breadcrumb a:hover{color:var(--blue);}

/* ── Narrativa ── */
.narrative{max-width:var(--measure);position:relative;z-index:1;}
.narrative p{margin-bottom:1.4rem;color:var(--text-2);}
.narrative p:last-child{margin-bottom:0;}
.narrative strong{color:var(--text);font-weight:500;}
.narrative em{font-style:italic;}

/* ── Estado de fase ── */
.badge{
  display:inline-block;
  font-size:var(--fs-label);letter-spacing:.14em;text-transform:uppercase;
  padding:.25rem .7rem;
  border:1px solid var(--border);
  color:var(--text-2);
}
.badge-active{border-color:var(--blue);color:var(--blue);}
.badge-dev{border-color:var(--gold);color:var(--gold-dark);}

/* ── Chips de hitos ── */
.chips{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.25rem;}
.chips li{
  font-size:var(--fs-label);letter-spacing:.06em;
  color:var(--gold-dark);
  border:1px solid var(--gold);
  padding:.3rem .75rem;
}

/* ── Manifiesto ── */
.manifesto{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border:1px solid var(--border);
  background:var(--bg);
}
.manifesto-cover{
  background:var(--bg-alt);
  border-right:1px solid var(--border);
  padding:3rem 2.5rem;
  display:flex;flex-direction:column;justify-content:center;
}
.manifesto-cover .label{margin-bottom:.75rem;}
.manifesto-cover h3{
  font-family:var(--serif);font-weight:500;
  font-size:var(--fs-h3);line-height:1.2;margin-bottom:1.5rem;
}
.manifesto-cover blockquote{
  font-family:var(--serif);font-style:italic;
  font-size:var(--fs-lead);font-weight:400;
  color:var(--text-2);
  border-left:1px solid var(--gold);
  padding-left:1.25rem;
}
.manifesto-form{padding:3rem 2.5rem;}
.manifesto-form p{font-size:var(--fs-small);color:var(--text-2);margin-bottom:1.5rem;}
.form-field{margin-bottom:1.25rem;}
.form-field label{
  display:block;
  font-size:var(--fs-label);letter-spacing:.12em;text-transform:uppercase;
  color:var(--text-2);margin-bottom:.4rem;
}
.form-field input{
  width:100%;
  font-family:var(--sans);font-size:var(--fs-body);
  padding:.75rem 1rem;
  background:var(--bg);
  border:1px solid var(--border);
  color:var(--text);
}
.form-field input:focus{outline:2px solid var(--blue);outline-offset:1px;border-color:var(--blue);}
.form-note{font-size:var(--fs-label);color:var(--text-2);margin-top:1rem;}
.form-success{display:none;}
.form-success.show{display:block;}
.form-success h4{font-family:var(--serif);font-size:var(--fs-h3);font-weight:500;margin-bottom:.75rem;}
.hp-field{position:absolute;left:-9999px;}

/* ── CTA simple de cierre ── */
.cta-simple{text-align:left;position:relative;z-index:1;max-width:740px;}
.cta-simple .cta-buttons{display:flex;gap:1.25rem;flex-wrap:wrap;margin-top:2.5rem;}

/* ── Formatos de concierto ── */
.format-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;
}
.format-card{
  background:var(--bg);
  border:1px solid var(--border);
  border-top:2px solid var(--gold);
  padding:2.5rem 2.25rem;
}
.format-num{
  font-family:var(--jp);font-weight:200;
  font-size:var(--fs-h2);line-height:1;
  color:var(--gold);
  display:block;margin-bottom:1.25rem;
}
.format-card h3{
  font-family:var(--serif);font-weight:500;
  font-size:var(--fs-h3);line-height:1.15;margin-bottom:.4rem;
}
.format-sub{font-size:var(--fs-small);color:var(--gold-dark);letter-spacing:.06em;margin-bottom:1.5rem;}
.check-list{list-style:none;margin:1.25rem 0 1.75rem;}
.check-list li{
  position:relative;
  padding:.45rem 0 .45rem 1.5rem;
  border-bottom:1px solid var(--border);
  font-size:var(--fs-small);color:var(--text-2);
}
.check-list li::before{
  content:"—";
  position:absolute;left:0;
  color:var(--gold-dark);
}
.format-outcome{font-size:var(--fs-small);}
.format-outcome strong{display:block;font-size:var(--fs-label);letter-spacing:.14em;text-transform:uppercase;color:var(--gold-dark);font-weight:400;margin-bottom:.3rem;}

/* ── Legado en tres ── */
.trio-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem;
}
.trio-item .format-num{font-size:var(--fs-h3);margin-bottom:.75rem;}
.trio-item h3{font-family:var(--serif);font-weight:500;font-size:var(--fs-lead);margin-bottom:.5rem;}
.trio-item p{font-size:var(--fs-small);color:var(--text-2);}

/* ── Razones para socios ── */
.reasons{
  position:relative;z-index:1;
  list-style:none;
  display:grid;grid-template-columns:1fr 1fr;gap:2rem;
  counter-reset:reason;
}
.reasons li{
  counter-increment:reason;
  border-top:1px solid var(--gold);
  padding-top:1.25rem;
  color:var(--text-2);
}
.reasons li::before{
  content:"0" counter(reason);
  display:block;
  font-family:var(--serif);
  font-size:var(--fs-h3);
  color:var(--gold-dark);
  margin-bottom:.5rem;
}

/* ── Estadísticas ── */
.stats-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;
  border-top:1px solid var(--gold);
  padding-top:2.5rem;
}
.stat-num{
  font-family:var(--serif);font-weight:400;
  font-size:var(--fs-h2);line-height:1;color:var(--blue);
  display:block;margin-bottom:.4rem;
}
.stat-label{font-size:var(--fs-small);color:var(--text-2);}

/* ── Cuadrícula de cuatro ── */
.quad-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;
}

/* ── Formulario completo ── */
.form-field select,.form-field textarea{
  width:100%;
  font-family:var(--sans);font-size:var(--fs-body);
  padding:.75rem 1rem;
  background:var(--bg);
  border:1px solid var(--border);
  color:var(--text);
}
.form-field textarea{min-height:160px;resize:vertical;}
.form-field select:focus,.form-field textarea:focus{outline:2px solid var(--blue);outline-offset:1px;border-color:var(--blue);}
.contact-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1.4fr;gap:4rem;
}

/* ── Fotos dentro de fases ── */
.phase figure{margin:1.5rem 0 0;max-width:560px;}
.phase figure img{width:100%;border:1px solid var(--gold);padding:8px;background:var(--bg);box-sizing:border-box;}
.phase figcaption{font-size:var(--fs-label);color:var(--text-2);margin-top:.6rem;letter-spacing:.04em;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:900px){
  :root{--section-pad:5rem;}
  .hero{padding:5.5rem 0 5rem;}
  .hero .kanji-mark{font-size:14rem;right:-3rem;opacity:.1;}
  .page-header{padding:4.5rem 0 3.5rem;}
  .page-header .kanji-mark{font-size:11rem;right:-3rem;opacity:.1;}
  .manifesto{grid-template-columns:1fr;}
  .manifesto-cover{border-right:none;border-bottom:1px solid var(--border);}
  .format-grid,.reasons{grid-template-columns:1fr;}
  .trio-grid{grid-template-columns:1fr;gap:2rem;}
  .stats-grid{grid-template-columns:1fr 1fr;}
  .quad-grid{grid-template-columns:1fr 1fr;}
  .contact-grid{grid-template-columns:1fr;gap:3rem;}
  .initiative-grid,.founders-grid{grid-template-columns:1fr;}
  .founders-grid{gap:3.5rem;}
  .gallery-grid{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;}
}

@media (max-width:480px){
  :root{--section-pad:4rem;}
  .container,.nav-inner{padding-left:1.25rem;padding-right:1.25rem;}
  .hero{padding:4rem 0;}
  .hero .kanji-mark{display:none;}
  .hero-actions .btn{width:100%;text-align:center;}
  .event-strip{flex-direction:column;align-items:flex-start;gap:1rem;padding:1.5rem 1.25rem;}
  .event-date{flex-direction:row;align-items:baseline;gap:.6rem;border-right:none;padding-right:0;min-width:0;}
  .event-arrow{display:none;}
  .gallery-grid{grid-template-columns:1fr;}
  .gallery-grid figcaption{opacity:1;}
  .footer-grid{grid-template-columns:1fr;gap:2rem;}
  .card-body{padding:1.5rem 1.25rem 1.75rem;}
  .phase{padding-left:1.75rem;}
  .quad-grid{grid-template-columns:1fr;}
}

/* ── Work With Us como botón destacado en la navegación ── */
.nav-links a.nav-cta {
  background: var(--blue);
  color: #fff;
  padding: .45rem 1.1rem;
  border-radius: 3px;
  transition: background .2s ease;
}
.nav-links a.nav-cta:hover {
  background: var(--blue-hover, #2C4A73);
  color: #fff;
}
.nav-links a.nav-cta::after { display: none; }

/* ── Responsive: grids de conversión del home en móvil ── */
@media (max-width: 760px) {
  .ways-grid { grid-template-columns: 1fr !important; }
  .bm-grid { grid-template-columns: 1fr !important; }
  .bm-golden { font-size: 1.25rem !important; }
  .form-2col { grid-template-columns: 1fr !important; }
}
