@import url('https://fonts.googleapis.com/css2?family=Barlow:ital,wght@0,300;0,400;0,500;0,600;1,300&family=Barlow+Condensed:wght@400;500;600;700;800&display=swap');

:root{
  --bg:#0b1220;
  --card:#0f1a33;
  --text:#eaf0ff;
  --muted:rgba(234,240,255,.72);
  --line:rgba(234,240,255,.12);
  --accent:#ff2d2d;
  --accent2:#ff7a00;
  --paper:#0a1020;
  --shadow:0 14px 40px rgba(0,0,0,.35);
  --radius:18px;
  --radius2:26px;
  --max:1120px;
  /* ── Tipografía ── */
  --font-body:    'Barlow', system-ui, sans-serif;
  --font-display: 'Barlow Condensed', system-ui, sans-serif;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family: var(--font-body);
  background: #f5f5f7;
  color: #0a0a0a;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
.container{ width:min(var(--max), calc(100% - 40px)); margin:0 auto; }

/* ─── NAVBAR ─── */
.nav-center{ display:flex; gap:32px; }
.nav-full{
  width:100%;
  max-width:1300px;
  margin:0 auto;
  padding:14px 50px;
}
.nav-wrap{
  position:sticky;
  top:0;
  z-index:50;
  transition:.25s ease;
  border-bottom:1px solid transparent;
  background: rgba(5, 8, 18, 1);
}
.nav-right{ margin-left:auto; }
.nav-wrap.is-scrolled{
  background:rgba(5,8,18,.78);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{
  width:100%;
  display:flex;
  align-items:center;
  gap:18px;
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand-logo{ width:42px; height:auto; border-radius:0; background:none; border:none; padding:0; }
.brand-text{ display:flex; flex-direction:column; line-height:1.1; }
.brand-text strong{
  font-family: var(--font-display);
  font-size:13px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color:#fff;
}
.brand-text small{
  font-family: var(--font-body);
  font-size:11px;
  font-weight: 300;
  letter-spacing: .04em;
  color:rgba(255,255,255,.6);
}

.nav-links{
  display:flex; align-items:center; gap:18px;
  list-style:none; margin:0; padding:0;
}
.nav-links a{
  padding:10px; border-radius:12px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: .85rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color:rgba(234,240,255,.9);
}
.nav-links a:hover{ background:rgba(255,255,255,.06); }

.nav-toggle{
  display:none; width:44px; height:44px;
  border-radius:14px; background:rgba(255,255,255,.06);
  border:1px solid var(--line); cursor:pointer;
}
.nav-toggle span{
  display:block; width:20px; height:2px;
  margin:5px auto; background:rgba(234,240,255,.9); border-radius:2px;
}

.nav-cta {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  font-size: .78rem;
}

/* ─── HERO 2 (video) ─── */
.hero2{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.hero2-bg{
  position:absolute; inset:0; z-index:-20;
}
.hero2-video{
  width:100%; height:100%; object-fit:cover; display:block;
}
.hero2-overlay{
  position:absolute; inset:0; z-index:-10;
  background:
    radial-gradient(ellipse 70% 80% at 0% 50%, rgba(180,0,0,.35), transparent 65%),
    linear-gradient(180deg, rgba(8,10,18,.30) 0%, rgba(8,10,18,.65) 50%, rgba(8,10,18,.95) 100%);
}
.hero2-container{
  padding-top:120px; padding-bottom:80px;
  padding-left:40px; padding-right:40px;
  width:100%;
}
.hero2-content{ max-width:760px; }

.hero2-pill{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 16px; border-radius:999px;
  background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.15);
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color:rgba(255,255,255,.90);
  font-size:12px; margin:0 0 20px;
}
.hero2-dot{
  width:9px; height:9px; border-radius:999px;
  background:var(--accent); box-shadow:0 0 0 5px rgba(255,45,45,.20); flex-shrink:0;
}
.hero2-title{
  margin:0;
  font-family: var(--font-display);
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  line-height: 1.05;
  color:#fff;
  font-size:clamp(32px,4.8vw,64px);
}
.hero2-title span{
  font-family: var(--font-display);
  font-weight: 800;
  color:rgba(255,255,255,.65);
}
.hero2-lead{
  margin:18px 0 0; max-width:600px;
  font-family: var(--font-body);
  font-size:clamp(15px,1.6vw,18px);
  font-weight: 300;
  line-height:1.65;
  letter-spacing: .02em;
  color:rgba(255,255,255,.72);
}
.hero2-actions{ margin-top:32px; display:flex; gap:12px; flex-wrap:wrap; }

.hero2-btn{
  padding:13px 28px; border-radius:999px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: .82rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  border:1px solid transparent; cursor:pointer; transition:all .2s ease;
}
.hero2-btn-primary{
  background:var(--accent); color:#fff;
  box-shadow:0 12px 30px rgba(255,45,45,.30);
  text-decoration:none; display:inline-flex; align-items:center; justify-content:center;
}
.hero2-btn-primary:hover{ box-shadow:0 16px 40px rgba(255,45,45,.55); transform:translateY(-2px); }
.hero2-btn-ghost{
  background:rgba(255,255,255,.08); color:rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.20);
}
.hero2-btn-ghost:hover{ background:rgba(255,255,255,.14); transform:translateY(-2px); }

/* ─── SECCIONES ─── */
.section{
  padding: 54px 0;
  margin: 0;
}
.section-alt{
  background: #f5f5f7;
  border-top: none;
  border-bottom: none;
}
.section-head{
  display:flex; justify-content:space-between;
  align-items:flex-end; gap:16px; margin-bottom:24px;
}

h2{
  margin:0 0 6px;
  font-family: var(--font-display);
  font-size: clamp(22px, 2.4vw, 30px);
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color:#0a0a0a;
}
h3{
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color:#0a0a0a;
}
.muted{
  font-family: var(--font-body);
  font-weight: 400;
  color:rgba(10,10,10,.52);
}
.tiny{ font-size:12px; }

/* ─── BOTONES ─── */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px; padding:12px 16px; border-radius:16px;
  border:1px solid transparent;
  background:linear-gradient(180deg, rgba(255,45,45,.92), rgba(255,45,45,.72));
  color:#fff;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: .78rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  box-shadow:0 10px 26px rgba(255,45,45,.18); cursor:pointer;
}
.btn:hover{ transform:translateY(-1px); }
.btn-ghost{
  background:rgba(0,0,0,.05);
  color:#0a0a0a;
  border:1px solid rgba(0,0,0,.12);
  box-shadow:none;
}
.btn-ghost:hover{ background:rgba(0,0,0,.09); }
.btn-sm{ padding:10px 12px; border-radius:14px; }
.btn-block{ width:100%; }

/* ─── FILTROS / CHIPS ─── */
.chip{
  border:1px solid rgba(0,0,0,.12);
  background:#fff; color:rgba(10,10,10,.75);
  padding:9px 14px; border-radius:999px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: .72rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  cursor:pointer;
  transition: background .18s, border-color .18s, color .18s, transform .18s;
}
.chip:hover{ transform:translateY(-1px); }
.chip.is-active{
  border-color:rgba(255,45,45,.45);
  background:rgba(255,45,45,.08);
  color:#cc1a1a;
}

/* ─── GRIDS ─── */
.grid{ display:grid; gap:14px; }
.cards{ grid-template-columns:repeat(4,1fr); }
.news{ grid-template-columns:repeat(3,1fr); }
.team{ grid-template-columns:repeat(4,1fr); }
.gallery{ grid-template-columns:repeat(3,1fr); }

/* ─── CARDS EVENTOS ─── */
.card{
  background:#fff;
  border:1px solid rgba(0,0,0,.09);
  border-radius:var(--radius2);
  padding:0;
  overflow:hidden;
  box-shadow:0 2px 12px rgba(0,0,0,.06);
  color:#0a0a0a;
  transition: transform .25s ease, box-shadow .25s ease;
}
.card:hover{
  transform: translateY(-5px);
  box-shadow: 0 12px 32px rgba(0,0,0,.11);
}
.card-img{
  width:100%; height:150px; object-fit:cover; display:block;
}
.card-body{ padding:14px 16px 16px; }
.card-top{
  display:flex; align-items:center;
  justify-content:space-between; margin-bottom:10px;
}
.date{
  font-family: var(--font-display);
  font-weight: 600;
  font-size: .72rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding:8px 10px; border-radius:14px;
  background:rgba(0,0,0,.06); border:1px solid rgba(0,0,0,.09);
  color:#0a0a0a;
}
.tag{
  font-family: var(--font-display);
  font-weight: 600;
  font-size: .72rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding:8px 10px; border-radius:999px;
  border:1px solid rgba(255,45,45,.30);
  background:rgba(255,45,45,.07); color:#cc1a1a;
}
.card h3{
  margin:0 0 6px;
  font-family: var(--font-display);
  font-size: .95rem;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  line-height: 1.3;
  color:#0a0a0a;
}
.card .muted{
  font-family: var(--font-body);
  font-weight: 400;
  font-size: .85rem;
}
.card-actions{
  display:flex; justify-content:space-between;
  align-items:center; margin-top:14px;
}
.link{
  font-family: var(--font-display);
  font-weight: 700;
  font-size: .75rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color:var(--accent);
}
.meta{
  font-family: var(--font-body);
  color:rgba(10,10,10,.45);
  font-weight: 400;
  font-size:12px;
}

/* ─── NOTICIAS ─── */
.news-card{
  overflow:hidden; border-radius:var(--radius2);
  border:1px solid rgba(0,0,0,.09);
  background:#fff;
  box-shadow:0 2px 12px rgba(0,0,0,.06);
  transition: transform .25s ease, box-shadow .25s ease;
}
.news-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 10px 28px rgba(0,0,0,.10);
}
.news-card img{ height:180px; width:100%; object-fit:cover; }
.news-body{ padding:14px; }
.news-meta{
  margin:0 0 6px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: .68rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color:rgba(10,10,10,.46);
}
.news-body h3{
  margin:0 0 6px;
  font-family: var(--font-display);
  font-size: .92rem;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  line-height: 1.3;
  color:#0a0a0a;
}
.news-body .muted{
  font-family: var(--font-body);
  font-weight: 400;
}

/* ─── COMITÉ ─── */
.person{
  background:#fff; border:1px solid rgba(0,0,0,.09);
  border-radius:var(--radius2); padding:16px; text-align:center;
  box-shadow:0 2px 12px rgba(0,0,0,.06);
  transition: transform .25s ease, box-shadow .25s ease;
}
.person:hover{
  transform: translateY(-4px);
  box-shadow: 0 10px 28px rgba(0,0,0,.10);
}
.avatar{
  width:68px; height:68px; margin:0 auto 10px; border-radius:22px;
  background:
    radial-gradient(28px 28px at 30% 30%, rgba(255,45,45,.20), transparent 70%),
    rgba(0,0,0,.06);
  border:1px solid rgba(0,0,0,.09);
}
.person h3{
  margin:0 0 4px;
  font-family: var(--font-display);
  font-size: .85rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color:#0a0a0a;
}
.person .muted{
  font-family: var(--font-body);
  font-weight: 400;
  font-size: .83rem;
}

/* ─── GALERÍA ─── */
.gallery img{ border-radius:16px; border:1px solid rgba(0,0,0,.07); }

/* ─── CONTACTO ─── */
.contact{
  display:grid; grid-template-columns:1.2fr .8fr;
  gap:16px; align-items:start;
}
.form{
  background:#fff; border:1px solid rgba(0,0,0,.09);
  border-radius:var(--radius2); padding:16px;
  box-shadow:0 2px 12px rgba(0,0,0,.06);
}
label{ display:block; margin-bottom:12px; }
label span{
  display:block;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: .72rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom:6px; color:rgba(10,10,10,.72);
}
input, textarea{
  width:100%; border-radius:16px;
  border:1px solid rgba(0,0,0,.13);
  background:#f8f8fa; color:#0a0a0a;
  font-family: var(--font-body);
  padding:12px; outline:none;
}
input:focus, textarea:focus{ border-color:var(--accent); background:#fff; }
.info{ display:grid; gap:12px; }
.info-card{
  background:#fff; border:1px solid rgba(0,0,0,.09);
  border-radius:var(--radius2); padding:16px;
  box-shadow:0 2px 12px rgba(0,0,0,.06);
}
.info-card h3{
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color:#0a0a0a; margin:0 0 8px;
}

/* ─── FOOTER ─── */
.footer{
  background:#080a10;
  border-top:1px solid rgba(255,255,255,.08);
}
.footer-main{
  display:grid !important;
  grid-template-columns: 1.5fr 1fr 1fr 1fr !important;
  gap:2rem !important;
  align-items:start !important;
  padding:52px 40px 40px;
}
.footer-brand{ max-width:320px; }
.footer-logo-wrap{
  display:flex; align-items:center; gap:14px; margin-bottom:16px;
}
.footer-logo{ width:52px; height:auto; }
.footer-brand-name{
  margin:0;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color:var(--accent); line-height:1.2;
}
.footer-brand-sub{
  margin:2px 0 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: .78rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color:rgba(255,255,255,.55);
}
.footer-desc{
  margin:0;
  font-family: var(--font-body);
  font-size:13px; line-height:1.7;
  font-weight: 300;
  color:rgba(255,255,255,.50);
}
.footer-col-title{
  margin:0 0 18px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: .75rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color:#fff;
}
.footer-links-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:0 16px;
}
.footer-links-grid div{ display:flex; flex-direction:column; gap:12px; }
.footer-links-grid a{
  font-family: var(--font-display);
  font-weight: 500;
  font-size: .8rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color:rgba(255,255,255,.55);
  transition:color .2s;
}
.footer-links-grid a:hover{ color:var(--accent); }
.footer-contact-list{
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column; gap:13px;
}
.footer-contact-list li{
  display:flex; align-items:flex-start; gap:10px;
  font-family: var(--font-body);
  font-size:13px;
  font-weight: 400;
  color:rgba(255,255,255,.55); line-height:1.4;
}
.footer-icon{
  font-size:15px; flex-shrink:0;
  filter:grayscale(1) brightness(0.5) sepia(1) hue-rotate(310deg) saturate(4);
}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.07);
  padding:16px 40px; text-align:center;
}
.footer-bottom p{
  margin:0;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: .7rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color:rgba(255,255,255,.35);
}

/* ─── MODAL ─── */
.modal-overlay{
  position:fixed; inset:0; z-index:200;
  background:rgba(0,0,0,.55); backdrop-filter:blur(6px);
  display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none; transition:opacity .25s ease;
}
.modal-overlay.is-open{ opacity:1; pointer-events:all; }
.modal{
  background:#fff; border-radius:28px;
  padding:28px 28px 0;
  width:min(640px, calc(100% - 40px));
  max-height:90vh; display:flex; flex-direction:column;
  box-shadow:0 24px 60px rgba(0,0,0,.25);
  position:relative;
  transform:translateY(16px); transition:transform .25s ease;
  overflow:hidden;
}
.modal-overlay.is-open .modal{ transform:translateY(0); }
.modal-close{
  position:absolute; top:16px; right:16px;
  width:36px; height:36px; border-radius:999px;
  border:1px solid rgba(0,0,0,.10); background:rgba(0,0,0,.05);
  cursor:pointer; font-size:14px; color:#0a0a0a;
  display:flex; align-items:center; justify-content:center; z-index:10;
}
.modal-close:hover{ background:rgba(0,0,0,.12); }
.modal-title{
  margin:0 0 4px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.2rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color:#0a0a0a;
}
.modal-subtitle{
  margin:0 0 12px;
  font-family: var(--font-body);
  font-size:13px; font-weight: 300;
  color:rgba(10,10,10,.52);
}
.modal-iframe-wrap{ flex:1; overflow-y:auto; margin:0 -28px; }
.modal-iframe-wrap iframe{ width:100%; height:580px; display:block; border:none; }

/* ─── CONTACTO CARDS ─── */
.contact-cards{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(260px,1fr));
  gap:1.25rem; margin-top:1.5rem;
}
.contact-card{
  display:flex; align-items:flex-start; gap:1rem;
  padding:1.5rem; border-radius:14px;
  background:#fff; border:1px solid rgba(0,0,0,0.07);
  box-shadow:0 2px 8px rgba(0,0,0,.05);
  transition:box-shadow .2s;
}
.contact-card:hover{ box-shadow:0 4px 16px rgba(192,57,43,.12); }
.contact-card-icon{
  flex-shrink:0; width:44px; height:44px; border-radius:10px;
  background:rgba(192,57,43,.08); color:#c0392b;
  display:flex; align-items:center; justify-content:center;
}
.contact-card-label{
  font-family: var(--font-display);
  font-size:.7rem;
  font-weight: 600;
  text-transform:uppercase; letter-spacing:.1em;
  color:#999; margin-bottom:.2rem;
}
.contact-card-value{
  font-family: var(--font-body);
  font-size:.95rem; font-weight:500; color:#222; line-height:1.5;
}
.contact-card-link{ color:#c0392b; text-decoration:none; }
.contact-card-link:hover{ text-decoration:underline; }

/* ─── ANIMACIONES ─── */
.anim-hero-title{
  opacity:0; transform:translateY(32px);
  animation:heroIn .8s .2s cubic-bezier(.22,.68,0,1.1) forwards;
}
.anim-hero-lead{
  opacity:0; transform:translateY(24px);
  animation:heroIn .8s .45s cubic-bezier(.22,.68,0,1.1) forwards;
}
.anim-hero-actions{
  opacity:0; transform:translateY(20px);
  animation:heroIn .8s .65s cubic-bezier(.22,.68,0,1.1) forwards;
}
@keyframes heroIn{ to{ opacity:1; transform:translateY(0); } }

.si{
  opacity:0; transform:translateY(28px);
  transition: opacity .6s ease, transform .6s cubic-bezier(.22,.68,0,1.1);
  transition-delay:var(--si-delay,0s);
}
.si.in{ opacity:1; transform:translateY(0); }

/* ─── RESPONSIVE ─── */
@media (max-width:980px){
  .cards{ grid-template-columns:repeat(2,1fr); }
  .team{ grid-template-columns:repeat(2,1fr); }
  .news{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:repeat(2,1fr); }
  .contact{ grid-template-columns:1fr; }
}
@media (max-width:768px){
  .footer-main{ grid-template-columns:1fr 1fr !important; }
}
@media (max-width:720px){
  .nav-toggle{ display:inline-block; }
  .nav-links{
    position:absolute; top:72px; right:20px; left:20px;
    display:none; flex-direction:column; gap:10px;
    padding:12px; border-radius:22px;
    border:1px solid var(--line);
    background:rgba(5,8,18,.86); backdrop-filter:blur(12px);
  }
  .nav-links.is-open{ display:flex; }
  .cards{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:1fr; }
  .hero2-container{ padding-top:100px; padding-bottom:60px; }
  .hero2-content{ max-width:100%; }
}
@media (max-width:600px){
  .modal{ padding:24px 20px 0; border-radius:20px; }
  .modal-iframe-wrap{ margin:0 -20px; }
  .modal-iframe-wrap iframe{ height:500px; }
}
@media (max-width:480px){
  .footer-main{ grid-template-columns:1fr !important; }
}
@media (max-width:560px){
  .footer-main{ padding:36px 20px 28px; }
  .footer-bottom{ padding:14px 20px; }
}