/* ============================================================
   ANEXO NORTE — Sitio público
   Bebas Neue + DM Sans · Negro · Blanco · #f6e6b2
============================================================ */
:root {
  --bg:#080808; --surface:#111; --surface-2:#181818; --surface-3:#1f1f1f;
  --border:rgba(255,255,255,0.07); --border-md:rgba(255,255,255,0.13);
  --text:#fff; --text-2:#888; --text-3:#3a3a3a;
  --yellow:#f6e6b2; --ydim:rgba(246,230,178,0.1); --ybrd:rgba(246,230,178,0.22);
  --green:#4caf82;
  --f-d:'Bebas Neue',sans-serif; --f-b:'DM Sans',sans-serif;
  --nav-h:62px; --r:4px; --r-lg:10px; --max-w:1100px;
  --ease:cubic-bezier(0.25,0.46,0.45,0.94);
}
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { background:var(--bg); color:var(--text); font-family:var(--f-b); line-height:1.7; -webkit-font-smoothing:antialiased; }
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }
button { font-family:inherit; }
h1,h2,h3 { font-family:var(--f-d); line-height:1; letter-spacing:.02em; }
p { color:var(--text-2); line-height:1.75; }

.container { max-width:var(--max-w); margin:0 auto; padding:0 2rem; }
.section { padding:5.5rem 0; }
.section-alt { background:var(--surface); }
section[id] { scroll-margin-top:calc(var(--nav-h) + 1rem); }
.section-header { margin-bottom:3.5rem; }
.section-label { display:inline-block; font-size:.68rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--yellow); margin-bottom:.75rem; }
.section-title { font-family:var(--f-d); font-size:clamp(3rem,8vw,5.5rem); line-height:.94; }

/* BUTTONS */
.btn { display:inline-block; padding:.75rem 1.6rem; border-radius:var(--r); font-family:var(--f-b); font-size:.82rem; font-weight:600; letter-spacing:.04em; cursor:pointer; transition:all .2s var(--ease); border:1px solid transparent; line-height:1; text-align:center; }
.btn-primary { background:var(--yellow); color:#080808; border-color:var(--yellow); }
.btn-primary:hover { background:#faefc8; transform:translateY(-1px); box-shadow:0 5px 18px rgba(246,230,178,.22); }
.btn-outline { background:transparent; color:var(--text); border-color:rgba(255,255,255,.22); }
.btn-outline:hover { border-color:var(--text); }
.btn-sm { padding:.5rem 1rem; font-size:.76rem; }

/* NAV */
.nav { position:fixed; top:0; left:0; right:0; z-index:1000; height:var(--nav-h); background:rgba(8,8,8,.92); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px); border-bottom:1px solid var(--border); transition:background .3s; }
.nav.scrolled { background:rgba(8,8,8,.98); }
.nav-inner { max-width:var(--max-w); margin:0 auto; padding:0 2rem; height:100%; display:flex; align-items:center; justify-content:space-between; gap:2rem; }
.nav-logo img { height:30px; width:auto; transition:opacity .2s; }
.nav-logo:hover img { opacity:.75; }
.nav-links { display:flex; align-items:center; gap:2rem; }
.nav-links a { font-size:.76rem; font-weight:500; letter-spacing:.07em; text-transform:uppercase; color:var(--text-2); transition:color .2s; }
.nav-links a:hover, .nav-links a.active { color:var(--text); }
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
.hamburger span { display:block; width:22px; height:1.5px; background:var(--text); transition:all .22s; }
.nav-overlay { display:none; position:fixed; inset:0; z-index:999; background:var(--bg); flex-direction:column; align-items:center; justify-content:center; }
.nav-overlay.open { display:flex; }
.overlay-close { position:absolute; top:1.5rem; right:2rem; background:none; border:none; color:var(--text-2); font-size:1.25rem; cursor:pointer; transition:color .2s; }
.overlay-close:hover { color:var(--text); }
.overlay-links { display:flex; flex-direction:column; align-items:center; gap:1.5rem; }
.overlay-links a { font-family:var(--f-d); font-size:clamp(2.5rem,8vw,4.5rem); color:var(--text-2); transition:color .2s; }
.overlay-links a:hover { color:var(--yellow); }

/* HERO */
.hero { position:relative; min-height:100vh; display:flex; align-items:flex-end; padding:calc(var(--nav-h) + 2rem) 2rem 4rem; max-width:var(--max-w); margin:0 auto; overflow:hidden; }
.hero-video { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; opacity:0.4; -webkit-playsinline:true; }
.hero-overlay { position:absolute; inset:0; z-index:-1; background:linear-gradient(to top, rgba(8,8,8,0.75) 0%, rgba(8,8,8,0.2) 100%); }
.hero-content { max-width:900px; }
.hero-eyebrow { font-family:var(--f-b); font-size:0.72rem; font-weight:600; letter-spacing:0.2em; text-transform:uppercase; color:var(--yellow); margin-bottom:1.25rem; }
.hero-title { font-family:var(--f-d); font-size:clamp(4.5rem,13vw,10rem); line-height:0.92; letter-spacing:0.01em; margin-bottom:1.75rem; animation:heroIn 0.9s var(--ease) both; }
.hero-body { font-size:1.05rem; color:var(--text-2); max-width:480px; margin-bottom:2.5rem; }
.hero-btn { }
@keyframes heroIn { from { opacity:0; transform:translateY(24px); } to { opacity:1; transform:none; } }
.hero-scroll { position:absolute; bottom:2rem; right:2rem; z-index:2; display:flex; flex-direction:column; align-items:center; gap:.3rem; font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.3); transition:color .2s; animation:scrollB 2.5s ease-in-out infinite; }
.hero-scroll:hover { color:rgba(255,255,255,.7); }
.scroll-arrow { font-size:.85rem; }
@keyframes scrollB { 0%,100% { transform:translateY(0); } 50% { transform:translateY(8px); } }

/* PLACEHOLDERS */
.img-ph { width:100%; height:100%; min-height:220px; display:flex; align-items:center; justify-content:center; background:var(--surface-2); border:1px dashed var(--border); color:var(--text-3); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; font-family:var(--f-b); }
.img-ph-tall { width:100%; min-height:480px; display:flex; align-items:center; justify-content:center; background:var(--surface); border:1px dashed var(--border); color:var(--text-3); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; font-family:var(--f-b); border-radius:var(--r-lg); }

/* AGENDA EMPTY */
.agenda-empty { padding:3rem 0; }
.agenda-empty p { font-size:1rem; margin-bottom:1.5rem; max-width:400px; }

/* FEATURED */
.featured { display:grid; grid-template-columns:1fr 1fr; gap:0; border:1px solid var(--border-md); border-radius:var(--r-lg); overflow:hidden; margin-bottom:3rem; }
.featured-img-wrap { aspect-ratio:4/3; overflow:hidden; background:var(--surface-2); }
.featured-img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform .4s var(--ease); }
.featured:hover .featured-img-wrap img { transform:scale(1.03); }
.featured-img-ph { width:100%; height:100%; min-height:320px; background:var(--surface-2); }
.featured-body { padding:2.5rem; background:var(--surface-2); display:flex; flex-direction:column; justify-content:center; gap:1.25rem; }
.featured-tags { display:flex; gap:.5rem; align-items:center; flex-wrap:wrap; }
.tag-proximo { font-size:.65rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--yellow); background:var(--ydim); border:1px solid var(--ybrd); padding:.2rem .65rem; border-radius:999px; }
.tag-venue { font-size:.65rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--text-2); border:1px solid var(--border); padding:.2rem .65rem; border-radius:999px; }
.featured-fecha { display:flex; flex-direction:column; gap:.1rem; }
.f-dia { font-size:.7rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--text-3); }
.f-num { font-family:var(--f-d); font-size:3.5rem; line-height:1; color:var(--yellow); }
.f-anio { font-size:.78rem; color:var(--text-2); }
.featured-nombre { font-family:var(--f-d); font-size:clamp(1.8rem,4vw,2.8rem); line-height:1.05; }
.featured-horario { font-size:.88rem; color:var(--text-2); }
.featured-desc { font-size:.9rem; color:var(--text-2); line-height:1.7; }
.featured-cta { margin-top:.5rem; }

/* MORE LABEL */
.more-label { font-size:.68rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--text-3); margin-bottom:1rem; padding-bottom:.6rem; border-bottom:1px solid var(--border); }

/* AGENDA LIST */
.agenda-list { display:flex; flex-direction:column; }
.agenda-item { display:grid; grid-template-columns:72px 90px 1fr auto; align-items:center; gap:1.5rem; padding:1.5rem 0; border-bottom:1px solid var(--border); transition:background .18s; }
.agenda-item:first-child { border-top:1px solid var(--border); }
.agenda-item:hover { background:rgba(255,255,255,.015); }
.agenda-fecha { display:flex; flex-direction:column; gap:.1rem; flex-shrink:0; }
.a-dia { font-size:.65rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--text-3); }
.a-num { font-family:var(--f-d); font-size:1.6rem; line-height:1; color:var(--yellow); }
.agenda-thumb { width:90px; height:60px; border-radius:var(--r); overflow:hidden; flex-shrink:0; }
.agenda-thumb img { width:100%; height:100%; object-fit:cover; }
.agenda-thumb-ph { background:var(--surface-3); border:1px dashed var(--border); }
.agenda-info { min-width:0; }
.agenda-nombre { font-family:var(--f-d); font-size:clamp(1.2rem,2.5vw,1.75rem); line-height:1.05; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-bottom:.4rem; }
.agenda-meta { display:flex; gap:.75rem; align-items:center; flex-wrap:wrap; }
.agenda-venue { font-size:.68rem; font-weight:600; letter-spacing:.07em; text-transform:uppercase; color:var(--yellow); padding:.18rem .55rem; border:1px solid var(--ybrd); border-radius:999px; background:var(--ydim); }
.agenda-horario { font-size:.78rem; color:var(--text-2); }
.agenda-cta { flex-shrink:0; }

/* FREE PILL */
.free-pill { display:inline-block; font-size:.72rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--green); padding:.25rem .7rem; border:1px solid rgba(76,175,130,.3); border-radius:999px; background:rgba(76,175,130,.08); }
.free-pill.small { font-size:.64rem; padding:.18rem .55rem; }

/* HISTORIAL */
.historial { margin-top:4rem; padding-top:3rem; border-top:1px solid var(--border); }
.historial-title { font-size:.68rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--text-3); margin-bottom:1.5rem; }
.historial-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border); border:1px solid var(--border); border-radius:var(--r-lg); overflow:hidden; }
.historial-item { background:var(--surface-2); overflow:hidden; }
.historial-img { aspect-ratio:16/9; overflow:hidden; }
.historial-img img { width:100%; height:100%; object-fit:cover; filter:grayscale(100%); opacity:.55; transition:opacity .22s; }
.historial-item:hover .historial-img img { opacity:.85; }
.historial-img-ph { aspect-ratio:16/9; background:var(--surface-3); }
.historial-info { padding:.9rem; display:flex; flex-direction:column; gap:.2rem; }
.h-fecha { font-size:.65rem; color:var(--text-3); font-weight:600; letter-spacing:.06em; text-transform:uppercase; }
.h-nombre { font-family:var(--f-d); font-size:1.1rem; line-height:1.1; }
.h-venue { font-size:.7rem; color:var(--text-2); }

/* VENUES */
.venues-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border); border:1px solid var(--border); border-radius:var(--r-lg); overflow:hidden; }
.venue-card { background:var(--surface-2); overflow:hidden; transition:background .2s; }
.venue-card:hover { background:#1c1c1c; }
.venue-card-img { aspect-ratio:4/3; overflow:hidden; }
.venue-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s var(--ease); }
.venue-card:hover .venue-card-img img { transform:scale(1.04); }
.venue-card-body { padding:1.5rem; }
.venue-name { font-family:var(--f-d); font-size:2rem; line-height:1; margin-bottom:.6rem; }
.venue-pill { display:inline-block; font-size:.64rem; font-weight:600; letter-spacing:.07em; text-transform:uppercase; padding:.2rem .7rem; border-radius:999px; margin-bottom:.75rem; }
.venue-pill.active { background:rgba(76,175,130,.1); color:var(--green); border:1px solid rgba(76,175,130,.25); }
.venue-pill.pending { background:var(--ydim); color:var(--yellow); border:1px solid var(--ybrd); }
.venue-card-body p { font-size:.85rem; margin-bottom:.9rem; }
.venue-caps { display:flex; flex-direction:column; gap:.15rem; }
.venue-caps span { font-size:.72rem; color:var(--text-3); }

/* NOSOTROS */
.nosotros-inner { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.nosotros-title { font-size:clamp(3.5rem,10vw,7rem); margin-bottom:1.5rem; }
.nosotros-text p { font-size:1rem; margin-bottom:1rem; }
.nosotros-img { border-radius:var(--r-lg); overflow:hidden; }
.nosotros-img img { width:100%; height:100%; object-fit:cover; }

/* FOOTER */
.footer { background:#000; border-top:1px solid var(--border); padding:3.5rem 0 2rem; }
.footer-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:2rem; flex-wrap:wrap; gap:1rem; }
.footer-logo { height:28px; width:auto; }
.footer-social { display:flex; gap:1.5rem; align-items:center; }
.social-link { display:flex; align-items:center; gap:.45rem; font-size:.78rem; font-weight:500; color:var(--text-2); transition:color .2s; }
.social-link:hover { color:var(--yellow); }
.footer-mid { margin-bottom:2rem; }
.footer-mid p { font-size:.8rem; color:var(--text-3); line-height:1.6; }
.footer-bottom { border-top:1px solid var(--border); padding-top:1.25rem; display:flex; justify-content:space-between; align-items:center; gap:1rem; flex-wrap:wrap; }
.footer-bottom p { font-size:.72rem; color:var(--text-3); }
.footer-link-small { font-size:.72rem; color:var(--text-3); transition:color .2s; }
.footer-link-small:hover { color:var(--yellow); }

/* RESPONSIVE */
@media (max-width:960px) {
  .nav-links { display:none; }
  .hamburger { display:flex; }
  .section { padding:4rem 0; }
  .featured { grid-template-columns:1fr; }
  .venues-grid { grid-template-columns:1fr; }
  .historial-grid { grid-template-columns:repeat(2,1fr); }
  .nosotros-inner { grid-template-columns:1fr; }
  .nosotros-img { display:none; }
  .agenda-item { grid-template-columns:60px 1fr auto; }
  .agenda-thumb { display:none; }
}
@media (max-width:640px) {
  .container { padding:0 1.25rem; }
  .hero-content { padding:0 1.25rem 4rem; }
  .hero-title { font-size:clamp(3.5rem,14vw,5.5rem); }
  .featured-body { padding:1.5rem; }
  .f-num { font-size:2.5rem; }
  .historial-grid { grid-template-columns:1fr; }
  .footer-top { flex-direction:column; align-items:flex-start; }
  .footer-social { flex-wrap:wrap; gap:1rem; }
}
