/* ============================================================
   VEEDURÍA FLORENCIA RENACE PARA LA AMAZONÍA 3
   Estilos principales — Diseño editorial amazónico moderno
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;600;700;800;900&family=Inter:wght@300;400;500;600&family=Playfair+Display:ital,wght@0,700;1,600&display=swap');

/* ── TOKENS ───────────────────────────────────────────────── */
:root {
  --azul:      #00AEEF;
  --azul-dark: #0080B0;
  --azul-deep: #003F5C;
  --amarillo:  #FFED00;
  --dorado:    #F9C74F;
  --naranja:   #FF7A00;
  --verde:     #00B14F;
  --verde-dark:#006B2F;
  --negro:     #1C2C1F;
  --crema:     #F8F5EE;
  --blanco:    #FFFFFF;
  --gris-suave:#F0EDE6;
  --gris-texto:#4A5568;
  --sombra:    0 4px 24px rgba(0,0,0,.10);
  --sombra-lg: 0 12px 48px rgba(0,0,0,.15);
  --radio:     12px;
  --radio-lg:  20px;
  --trans:     cubic-bezier(.4,0,.2,1);
}

/* ── RESET BASE ───────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:'Inter',sans-serif;
  color:var(--negro);
  background:var(--blanco);
  overflow-x:hidden;
  line-height:1.7;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* ── UTILIDADES ───────────────────────────────────────────── */
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.section-title{
  font-family:'Montserrat',sans-serif;
  font-size:clamp(1.8rem,4vw,2.8rem);
  font-weight:800;
  line-height:1.2;
  color:var(--negro);
}
.section-title span{color:var(--azul)}
.section-subtitle{
  font-size:1.05rem;
  color:var(--gris-texto);
  max-width:620px;
  margin-top:.6rem;
}
.badge{
  display:inline-block;
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:.3rem .9rem;
  border-radius:50px;
  background:var(--amarillo);
  color:var(--negro);
  margin-bottom:1rem;
}
.badge.verde{background:var(--verde);color:#fff}
.badge.azul{background:var(--azul);color:#fff}
.badge.naranja{background:var(--naranja);color:#fff}

/* ── BOTONES ──────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.85rem 2rem;
  border-radius:50px;
  font-weight:700;
  font-size:.95rem;
  transition:all .3s var(--trans);
  letter-spacing:.02em;
}
.btn-primary{
  background:linear-gradient(135deg,var(--azul),var(--azul-dark));
  color:#fff;
  box-shadow:0 4px 16px rgba(0,174,239,.35);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,174,239,.5)}
.btn-secondary{
  background:transparent;
  color:#fff;
  border:2px solid rgba(255,255,255,.7);
}
.btn-secondary:hover{background:rgba(255,255,255,.15);border-color:#fff}
.btn-verde{
  background:linear-gradient(135deg,var(--verde),var(--verde-dark));
  color:#fff;
}
.btn-verde:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,177,79,.4)}
.btn-outline{
  border:2px solid var(--azul);
  color:var(--azul);
  background:transparent;
}
.btn-outline:hover{background:var(--azul);color:#fff}

/* ── HEADER / NAV ─────────────────────────────────────────── */
#header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:all .4s var(--trans);
}
#header.scrolled{
  background:rgba(28,44,31,.97);
  backdrop-filter:blur(12px);
  box-shadow:0 2px 24px rgba(0,0,0,.25);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:.9rem 1.5rem;
  max-width:1300px;margin:0 auto;
}
.nav-logo{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
.nav-logo img{width:52px;height:52px;object-fit:contain;border-radius:50%;
  box-shadow:0 0 0 2px var(--amarillo)}
.nav-logo-text{
  font-family:'Montserrat',sans-serif;
  font-weight:800;font-size:.8rem;
  color:#fff;line-height:1.25;max-width:180px;
}
.nav-logo-text small{font-weight:400;opacity:.75;font-size:.68rem;display:block}
.nav-menu{display:flex;align-items:center;gap:.2rem}
.nav-link{
  color:rgba(255,255,255,.88);
  font-size:.82rem;font-weight:600;
  padding:.5rem .75rem;border-radius:8px;
  transition:all .25s;letter-spacing:.01em;
}
.nav-link:hover,.nav-link.active{color:#fff;background:rgba(0,174,239,.25)}
.nav-cta{
  background:linear-gradient(135deg,var(--verde),var(--verde-dark));
  color:#fff !important;
  padding:.5rem 1.1rem !important;border-radius:50px !important;
}
.nav-cta:hover{transform:scale(1.04)}
.hamburger{
  display:none;flex-direction:column;gap:5px;padding:.5rem;
  border-radius:8px;z-index:1001;
}
.hamburger span{
  width:24px;height:2px;background:#fff;border-radius:2px;
  transition:all .35s var(--trans);display:block;
}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── HERO ─────────────────────────────────────────────────── */
#inicio{
  position:relative;min-height:100vh;
  display:flex;align-items:center;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,
    rgba(0,63,92,.88) 0%,
    rgba(28,44,31,.80) 50%,
    rgba(0,174,239,.25) 100%);
}
.hero-content{
  position:relative;z-index:2;
  max-width:1200px;margin:0 auto;padding:8rem 1.5rem 4rem;
  display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;
}
.hero-tag{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(0,174,239,.25);border:1px solid rgba(0,174,239,.5);
  color:var(--azul);border-radius:50px;
  font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:.4rem 1rem;margin-bottom:1.2rem;
  backdrop-filter:blur(4px);
}
.hero-tag::before{content:'';width:6px;height:6px;background:var(--azul);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}}
.hero-title{
  font-family:'Montserrat',sans-serif;
  font-size:clamp(2.2rem,5vw,3.8rem);
  font-weight:900;color:#fff;
  line-height:1.1;margin-bottom:1.2rem;
}
.hero-title .highlight{
  background:linear-gradient(90deg,var(--amarillo),var(--dorado));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero-desc{
  color:rgba(255,255,255,.85);font-size:1.1rem;
  margin-bottom:2rem;line-height:1.7;
}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap}
.hero-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;
  margin-top:2.5rem;
}
.stat-box{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  border-radius:var(--radio);
  padding:1rem;text-align:center;
  backdrop-filter:blur(8px);
}
.stat-num{
  font-family:'Montserrat',sans-serif;
  font-size:1.8rem;font-weight:900;color:var(--amarillo);
}
.stat-label{color:rgba(255,255,255,.75);font-size:.78rem}
.hero-visual{display:flex;justify-content:center;align-items:center}
.logo-hero-wrap{
  position:relative;
  width:280px;height:280px;
  animation:float 6s ease-in-out infinite;
}
@keyframes float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-16px)}
}
.logo-hero-wrap img{
  width:100%;height:100%;object-fit:contain;
  filter:drop-shadow(0 24px 48px rgba(0,0,0,.5));
}
.hero-scroll{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  z-index:2;display:flex;flex-direction:column;align-items:center;gap:.4rem;
  color:rgba(255,255,255,.6);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;
  animation:bounce 2s infinite;
}
.hero-scroll::after{
  content:'';width:1px;height:32px;
  background:linear-gradient(to bottom,rgba(255,255,255,.5),transparent);
}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}

/* ── TICKER DE NOTICIAS ───────────────────────────────────── */
.news-ticker{
  background:var(--negro);
  color:#fff;
  padding:.6rem 0;overflow:hidden;
}
.ticker-wrap{display:flex;align-items:center}
.ticker-label{
  background:var(--naranja);
  color:#fff;font-size:.72rem;font-weight:800;
  letter-spacing:.08em;text-transform:uppercase;
  padding:.35rem .9rem;white-space:nowrap;flex-shrink:0;
}
.ticker-track{
  overflow:hidden;flex:1;margin-left:1rem;
  -webkit-mask-image:linear-gradient(to right,transparent,black 5%,black 95%,transparent);
          mask-image:linear-gradient(to right,transparent,black 5%,black 95%,transparent);
}
.ticker-inner{
  display:flex;gap:3rem;
  animation:ticker 30s linear infinite;
  white-space:nowrap;
}
.ticker-inner:hover{animation-play-state:paused}
.ticker-item{font-size:.82rem;opacity:.85;cursor:pointer;transition:opacity .2s}
.ticker-item:hover{opacity:1;color:var(--dorado)}
.ticker-item::before{content:'🌿  ';margin-right:.3rem}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── QUIÉNES SOMOS ────────────────────────────────────────── */
#quienes{padding:6rem 0;background:var(--crema)}
.quienes-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:4rem;align-items:center;margin-top:3rem;
}
.quienes-img-wrap{position:relative}
.quienes-img-wrap img{
  border-radius:var(--radio-lg);
  height:480px;object-fit:cover;width:100%;
  box-shadow:var(--sombra-lg);
}
.quienes-badge-float{
  position:absolute;bottom:-1.5rem;right:-1.5rem;
  background:var(--azul);color:#fff;
  border-radius:var(--radio);padding:1.2rem 1.5rem;
  box-shadow:var(--sombra-lg);
  font-family:'Montserrat',sans-serif;
  text-align:center;
}
.quienes-badge-float strong{font-size:1.6rem;font-weight:900;display:block}
.quienes-badge-float span{font-size:.75rem;opacity:.85}
.quienes-cards{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.5rem}
.info-card{
  background:#fff;border-radius:var(--radio);
  padding:1.2rem;border-left:4px solid var(--azul);
  box-shadow:0 2px 12px rgba(0,0,0,.06);
}
.info-card.verde{border-color:var(--verde)}
.info-card.naranja{border-color:var(--naranja)}
.info-card.amarillo{border-color:var(--amarillo)}
.info-card h4{font-size:.8rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;color:var(--gris-texto);margin-bottom:.3rem}
.info-card p{font-size:.92rem;font-weight:600;color:var(--negro)}

/* ── OBJETIVO SOCIAL ──────────────────────────────────────── */
#objetivo{
  padding:6rem 0;
  background:linear-gradient(160deg,var(--azul-deep) 0%,var(--negro) 100%);
  position:relative;overflow:hidden;
}
#objetivo::before{
  content:'';position:absolute;top:-100px;right:-100px;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(0,174,239,.15) 0%,transparent 70%);
}
.objetivo-content{position:relative;z-index:1}
.objetivo-quote{
  background:rgba(255,255,255,.06);
  border-left:4px solid var(--amarillo);
  border-radius:0 var(--radio) var(--radio) 0;
  padding:2rem 2.5rem;
  margin:2rem 0;
  font-family:'Playfair Display',serif;
  font-style:italic;font-size:1.15rem;
  color:rgba(255,255,255,.9);line-height:1.8;
}
.actividades-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:1.2rem;margin-top:2rem;
}
.actividad-item{
  display:flex;align-items:flex-start;gap:1rem;
  background:rgba(255,255,255,.06);
  border-radius:var(--radio);padding:1.3rem;
  border:1px solid rgba(255,255,255,.08);
  transition:all .3s var(--trans);
}
.actividad-item:hover{background:rgba(0,174,239,.12);border-color:rgba(0,174,239,.3);transform:translateY(-3px)}
.actividad-num{
  font-family:'Montserrat',sans-serif;
  font-size:1.5rem;font-weight:900;
  color:var(--amarillo);flex-shrink:0;line-height:1;
  min-width:2rem;
}
.actividad-item p{color:rgba(255,255,255,.8);font-size:.88rem;line-height:1.6}

/* ── NOTICIAS ─────────────────────────────────────────────── */
#noticias{padding:6rem 0;background:#fff}
.noticias-layout{
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:2rem;margin-top:3rem;
}
/* Noticia destacada */
.noticia-featured{
  position:relative;border-radius:var(--radio-lg);overflow:hidden;
  min-height:480px;cursor:pointer;
  box-shadow:var(--sombra-lg);
}
.noticia-featured img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s var(--trans);
}
.noticia-featured:hover img{transform:scale(1.04)}
.noticia-featured-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.88) 0%,transparent 55%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:2rem;
}
.noticia-featured-overlay .badge{margin-bottom:.6rem}
.noticia-featured-overlay h3{
  font-family:'Montserrat',sans-serif;
  font-size:1.5rem;font-weight:800;color:#fff;
  line-height:1.3;margin-bottom:.5rem;
}
.noticia-featured-overlay p{color:rgba(255,255,255,.75);font-size:.88rem}
.noticia-fecha{color:rgba(255,255,255,.55);font-size:.78rem;margin-top:.5rem}

/* Lista lateral de noticias */
.noticias-sidebar{display:flex;flex-direction:column;gap:1.2rem}
.noticia-card{
  display:flex;gap:1rem;align-items:flex-start;
  background:var(--gris-suave);border-radius:var(--radio);
  padding:1rem;cursor:pointer;
  transition:all .3s var(--trans);
  border:1px solid transparent;
}
.noticia-card:hover{background:#fff;border-color:var(--azul);box-shadow:var(--sombra);transform:translateX(4px)}
.noticia-card img{
  width:80px;height:70px;object-fit:cover;
  border-radius:8px;flex-shrink:0;
}
.noticia-card-body{flex:1}
.noticia-card-body .badge{margin-bottom:.35rem;font-size:.65rem}
.noticia-card-body h4{font-size:.9rem;font-weight:700;line-height:1.35;color:var(--negro)}
.noticia-card-body small{color:var(--gris-texto);font-size:.75rem}
.btn-ver-mas{
  display:block;text-align:center;
  margin-top:2.5rem;
}

/* ── JUNTA DIRECTIVA ──────────────────────────────────────── */
#junta{
  padding:6rem 0;
  background:var(--crema);
}
.junta-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:1.5rem;margin-top:3rem;
}
.miembro-card{
  background:#fff;border-radius:var(--radio-lg);
  padding:2rem 1.5rem;text-align:center;
  box-shadow:var(--sombra);
  transition:all .35s var(--trans);
  border-bottom:4px solid transparent;
  position:relative;overflow:hidden;
}
.miembro-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--azul),var(--verde));
}
.miembro-card:hover{transform:translateY(-6px);border-color:var(--azul);box-shadow:var(--sombra-lg)}
.miembro-avatar{
  width:72px;height:72px;border-radius:50%;
  margin:0 auto 1rem;
  display:flex;align-items:center;justify-content:center;
  font-family:'Montserrat',sans-serif;
  font-size:1.5rem;font-weight:900;color:#fff;
  background:linear-gradient(135deg,var(--azul),var(--verde-dark));
}
.miembro-cargo{
  font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--azul);margin-bottom:.4rem;
}
.miembro-nombre{
  font-family:'Montserrat',sans-serif;
  font-size:1rem;font-weight:700;color:var(--negro);line-height:1.3;
}

/* ── GALERÍA / PROYECTOS ──────────────────────────────────── */
#proyectos{padding:6rem 0;background:#fff}
.galeria-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:240px 240px;
  gap:1rem;margin-top:2rem;
}
.galeria-item{
  border-radius:var(--radio);overflow:hidden;
  cursor:pointer;position:relative;
}
.galeria-item:first-child{grid-row:span 2}
.galeria-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s var(--trans);
}
.galeria-item:hover img{transform:scale(1.06)}
.galeria-caption{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,63,92,.85),transparent 50%);
  display:flex;align-items:flex-end;padding:1rem;
  opacity:0;transition:opacity .3s;
}
.galeria-item:hover .galeria-caption{opacity:1}
.galeria-caption span{color:#fff;font-size:.85rem;font-weight:600}

/* ── PARTICIPAR ───────────────────────────────────────────── */
#participar{
  padding:6rem 0;
  background:linear-gradient(135deg,var(--verde-dark) 0%,var(--azul-deep) 100%);
  position:relative;
}
.participar-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:3rem;align-items:center;margin-top:2rem;
}
.asociado-cards{display:flex;flex-direction:column;gap:1.2rem}
.asociado-card{
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);
  border-radius:var(--radio);padding:1.5rem;
  backdrop-filter:blur(8px);
  transition:all .3s;
}
.asociado-card:hover{background:rgba(255,255,255,.18)}
.asociado-card h3{
  font-family:'Montserrat',sans-serif;
  font-size:1.1rem;color:#fff;font-weight:700;margin-bottom:.5rem;
  display:flex;align-items:center;gap:.5rem;
}
.asociado-card p{color:rgba(255,255,255,.8);font-size:.9rem;line-height:1.6}
.derechos-lista{
  display:flex;flex-direction:column;gap:.75rem;margin-top:1rem;
}
.derecho-item{
  display:flex;align-items:flex-start;gap:.75rem;
  color:rgba(255,255,255,.85);font-size:.9rem;
}
.derecho-icon{
  width:28px;height:28px;border-radius:50%;
  background:rgba(0,174,239,.3);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-size:.9rem;
}

/* ── TRANSPARENCIA ────────────────────────────────────────── */
#transparencia{padding:5rem 0;background:var(--gris-suave)}
.trans-cards{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1.5rem;margin-top:2.5rem;
}
.trans-card{
  background:#fff;border-radius:var(--radio-lg);
  padding:2rem;text-align:center;
  box-shadow:var(--sombra);
  transition:all .3s var(--trans);
}
.trans-card:hover{transform:translateY(-4px);box-shadow:var(--sombra-lg)}
.trans-icon{
  font-size:2.5rem;margin-bottom:1rem;
  width:68px;height:68px;border-radius:var(--radio);
  background:linear-gradient(135deg,rgba(0,174,239,.12),rgba(0,177,79,.12));
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1rem;
}
.trans-card h3{font-family:'Montserrat',sans-serif;font-size:1rem;font-weight:700;margin-bottom:.5rem}
.trans-card p{font-size:.85rem;color:var(--gris-texto);margin-bottom:1.2rem}
.trans-card .btn{width:100%;justify-content:center;font-size:.85rem;padding:.65rem}

/* ── CONTACTO ─────────────────────────────────────────────── */
#contacto{padding:6rem 0;background:#fff}
.contacto-grid{
  display:grid;grid-template-columns:1fr 1.4fr;
  gap:4rem;align-items:start;margin-top:3rem;
}
.contacto-info h3{
  font-family:'Montserrat',sans-serif;
  font-size:1.3rem;font-weight:700;margin-bottom:1.5rem;
}
.contacto-items{display:flex;flex-direction:column;gap:1rem}
.contacto-item{
  display:flex;align-items:flex-start;gap:1rem;
  padding:1rem;background:var(--gris-suave);
  border-radius:var(--radio);
}
.contacto-item-icon{
  font-size:1.3rem;width:42px;height:42px;
  border-radius:8px;background:var(--azul);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.contacto-item strong{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--gris-texto)}
.contacto-item p{font-weight:600;font-size:.95rem}
.contacto-item a:hover{color:var(--azul)}

/* Formulario */
.form-grupo{margin-bottom:1.2rem}
.form-label{
  display:block;font-size:.82rem;font-weight:700;
  margin-bottom:.4rem;color:var(--negro);
}
.form-input,.form-textarea,.form-select{
  width:100%;padding:.85rem 1.1rem;
  border:2px solid #E2E8F0;border-radius:var(--radio);
  font-family:'Inter',sans-serif;font-size:.95rem;
  transition:border-color .25s,box-shadow .25s;
  background:#fff;color:var(--negro);
}
.form-input:focus,.form-textarea:focus,.form-select:focus{
  outline:none;border-color:var(--azul);
  box-shadow:0 0 0 3px rgba(0,174,239,.15);
}
.form-input.error,.form-textarea.error{border-color:#F56565}
.form-textarea{resize:vertical;min-height:130px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-error{color:#F56565;font-size:.78rem;margin-top:.3rem;display:none}
.form-error.show{display:block}
.form-success{
  display:none;text-align:center;padding:2rem;
  background:rgba(0,177,79,.08);border-radius:var(--radio);
  border:2px solid var(--verde);color:var(--verde-dark);
}
.form-success.show{display:block}

/* ── FOOTER ───────────────────────────────────────────────── */
footer{
  background:var(--negro);color:rgba(255,255,255,.75);
  padding:4rem 0 0;
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:2.5rem;padding-bottom:3rem;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.footer-brand img{width:70px;height:70px;object-fit:contain;border-radius:50%;margin-bottom:1rem}
.footer-brand p{font-size:.88rem;line-height:1.7;max-width:280px;opacity:.75}
.footer-brand .nit{
  margin-top:1rem;font-size:.78rem;
  background:rgba(255,255,255,.06);
  border-radius:8px;padding:.5rem .75rem;display:inline-block;
}
.footer-col h4{
  font-family:'Montserrat',sans-serif;
  font-size:.85rem;font-weight:700;color:#fff;
  letter-spacing:.06em;text-transform:uppercase;
  margin-bottom:1.2rem;
}
.footer-col li{margin-bottom:.6rem}
.footer-col a{font-size:.88rem;transition:color .2s}
.footer-col a:hover{color:var(--azul)}
.footer-bottom{
  background:rgba(0,0,0,.25);
  text-align:center;padding:1.2rem;
  font-size:.8rem;opacity:.6;
}

/* ── WHATSAPP FLOTANTE ────────────────────────────────────── */
.whatsapp-float{
  position:fixed;bottom:2rem;right:2rem;z-index:999;
  width:58px;height:58px;border-radius:50%;
  background:linear-gradient(135deg,#25D366,#128C7E);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.5);
  transition:all .3s var(--trans);
  font-size:1.6rem;
}
.whatsapp-float:hover{transform:scale(1.12) translateY(-3px);box-shadow:0 8px 30px rgba(37,211,102,.65)}
.whatsapp-pulse{
  position:absolute;inset:0;border-radius:50%;
  background:rgba(37,211,102,.4);
  animation:wpulse 2.5s ease-out infinite;
}
@keyframes wpulse{
  0%{transform:scale(1);opacity:.8}
  100%{transform:scale(1.7);opacity:0}
}

/* ── SCROLL TOP ───────────────────────────────────────────── */
.scroll-top{
  position:fixed;bottom:2rem;left:2rem;z-index:999;
  width:44px;height:44px;border-radius:50%;
  background:var(--azul);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;box-shadow:var(--sombra);
  opacity:0;pointer-events:none;
  transition:all .3s var(--trans);
}
.scroll-top.visible{opacity:1;pointer-events:all}
.scroll-top:hover{background:var(--azul-dark);transform:translateY(-3px)}

/* ── MODAL GALERÍA ────────────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,.92);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-img{max-width:90vw;max-height:85vh;border-radius:var(--radio);object-fit:contain}
.modal-close{
  position:absolute;top:1.5rem;right:1.5rem;
  color:#fff;font-size:2rem;cursor:pointer;
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
.modal-close:hover{background:rgba(255,255,255,.25)}

/* ── ANIMATIONS ON SCROLL ─────────────────────────────────── */
[data-anim]{opacity:0;transform:translateY(30px);transition:opacity .7s var(--trans),transform .7s var(--trans)}
[data-anim].visible{opacity:1;transform:none}
[data-anim="left"]{transform:translateX(-30px)}
[data-anim="left"].visible{transform:none}
[data-anim="right"]{transform:translateX(30px)}
[data-anim="right"].visible{transform:none}
[data-anim="scale"]{transform:scale(.93)}
[data-anim="scale"].visible{transform:none}

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media (max-width:1024px){
  .noticias-layout{grid-template-columns:1fr}
  .noticia-featured{min-height:380px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:768px){
  .nav-menu{
    position:fixed;top:0;right:-100%;bottom:0;
    width:min(300px,85vw);
    background:rgba(28,44,31,.98);
    flex-direction:column;
    padding:5rem 1.5rem 2rem;
    gap:.5rem;
    transition:right .4s var(--trans);
    align-items:flex-start;
    box-shadow:-8px 0 32px rgba(0,0,0,.3);
  }
  .nav-menu.open{right:0}
  .nav-link{font-size:1rem;padding:.7rem 1rem;width:100%}
  .hamburger{display:flex}
  .hero-content{grid-template-columns:1fr;text-align:center; gap:2rem}
  .hero-btns{justify-content:center}
  .logo-hero-wrap{width:200px;height:200px}
  .hero-stats{grid-template-columns:repeat(3,1fr)}
  .quienes-grid,.participar-grid,.contacto-grid{grid-template-columns:1fr}
  .quienes-badge-float{right:0;bottom:-1rem}
  .galeria-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .galeria-item:first-child{grid-row:auto}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}
@media (max-width:480px){
  .hero-stats{grid-template-columns:1fr}
  .quienes-cards{grid-template-columns:1fr}
  .galeria-grid{grid-template-columns:1fr}
  .hero-title{font-size:2rem}
}
