a/* ===== Desert Brew Co · Neo-Mex Base ===== */
:root{
  /* Paleta */
  --bg:#0f0f12;
  --surface:#16171c;
  --text:#EDEDED;
  --muted:#B9BDC6;
  --primary:#F25C05;   /* naranja mezquite */
  --secondary:#17BEBB; /* turquesa */
  --accent:#F9D923;    /* amarillo sarape */
  --ok:#8BC34A;
  --danger:#ff5252;

  --radius:18px;
  --shadow: 0 10px 30px rgba(0,0,0,.35);
  --max: 1150px;
}

/* Reset básico */
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--text);
  font-family:Montserrat,system-ui,-apple-system,Segoe UI,Roboto}
img{max-width:100%;display:block}
a{color:var(--secondary);text-decoration:none}
.container{max-width:var(--max);margin-inline:auto;padding:0 20px}

/* Botones */
.btn{display:inline-block;padding:12px 18px;border-radius:999px;
  font-weight:700;letter-spacing:.3px;transition:.2s ease-in-out}
.btn.primary{background:var(--primary);color:#111}
.btn.primary:hover{transform:translateY(-1px);filter:brightness(1.05)}
.btn.ghost{border:1px solid #333;color:var(--text)}
.btn.ghost:hover{border-color:#555}

/* Header / Nav */
header{position:sticky;top:0;z-index:50;
  background:linear-gradient(180deg,rgba(15,15,18,.9),rgba(15,15,18,.4) 70%,transparent);
  backdrop-filter:saturate(140%) blur(6px);
  border-bottom:1px solid rgba(255,255,255,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:10px 0}
.brand{display:flex;align-items:center;gap:10px}
.brand img{width:40px;height:40px;border-radius:50%;border:2px solid var(--accent)}
.brand h1{font-size:18px;margin:0;font-weight:800;letter-spacing:.5px}
.links a{margin:0 10px;color:var(--muted)}
.links a:hover{color:var(--text)}

/* Hero */
.hero{position:relative;isolation:isolate;padding:90px 0 70px;overflow:hidden;
  background:
    radial-gradient(60% 60% at 90% 10%, rgba(242,92,5,.15), transparent 60%),
    radial-gradient(50% 50% at 20% 0%, rgba(23,190,187,.18), transparent 60%);}
.hero .grid{display:grid;grid-template-columns:1.2fr .8fr;gap:30px;align-items:center}
.kicker{font:600 13px/1 "Josefin Sans", sans-serif;color:var(--accent);
  letter-spacing:.25em;text-transform:uppercase}
.title{font-size:clamp(34px,5vw,56px);margin:.2em 0 .3em;font-weight:800}
.lead{color:var(--muted);max-width:60ch}
.ctas{display:flex;gap:12px;margin-top:18px}
.card{background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.0));
  border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}

/* Secciones */
section{padding:70px 0;border-top:1px solid rgba(255,255,255,.06)}
.section-title{font:800 clamp(22px,3.5vw,34px)/1.1 Montserrat;margin:0 0 16px}
.section-sub{color:var(--muted);margin:0 0 26px}

/* Cervezas */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.beer{overflow:hidden}
.beer img{border-radius:14px;border:1px solid rgba(255,255,255,.08)}
.beer h3{margin:10px 0 4px;font-size:18px}
.pill{font:600 11px/1 "Josefin Sans", sans-serif;padding:6px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.12);color:var(--muted)}

/* Ubicaciones */
.locations{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.map{aspect-ratio:16/10;border-radius:14px;background:#0c0c0f;
  border:1px solid rgba(255,255,255,.08);display:grid;place-items:center;color:#777}

/* Galería */
.mosaic{display:grid;grid-template-columns:2fr 1fr 1fr;gap:12px}
.mosaic div{border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.08);
  background:#0d0e12;min-height:160px}

/* Contacto */
form{display:grid;gap:12px;max-width:560px}
input,textarea{background:#0d0e12;border:1px solid rgba(255,255,255,.12);color:var(--text);
  padding:12px 14px;border-radius:12px;font:500 14px/1.4 Montserrat;outline:none}
input:focus,textarea:focus{border-color:var(--secondary)}

/* Footer */
footer{padding:40px 0;color:#8a8f99}
.footer-grid{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center}
.badges{display:flex;gap:10px;flex-wrap:wrap}
.badge{border:1px dashed rgba(255,255,255,.16);border-radius:999px;
  padding:8px 12px;font:600 12px "Josefin Sans", sans-serif;color:var(--muted)}

/* Responsivo */
@media (max-width:900px){
  .hero .grid{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr 1fr}
  .locations{grid-template-columns:1fr}
  .mosaic{grid-template-columns:1fr 1fr}
}
@media (max-width:600px){
  .grid-3{grid-template-columns:1fr}
  .mosaic{grid-template-columns:1fr}
  .links{display:none}
}



/* === Modal verificación de edad — Estilo Desert Brew Co === */
.age-modal {
  position: fixed;
  inset: 0;
  background: radial-gradient(circle at 30% 20%, rgba(242,92,5,0.12), transparent 60%),
              radial-gradient(circle at 70% 80%, rgba(23,190,187,0.12), transparent 60%),
              rgba(0,0,0,0.90);
  backdrop-filter: blur(6px);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  color: #fff;
  animation: fadeIn 0.4s ease-out;
}

/* Caja central */
.age-box {
  position: relative;
  width: min(92vw, 520px);
  background: #16171c;
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 18px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.45);
  padding: 34px 28px;
  text-align: center;
  overflow: hidden;
}

/* Logo translúcido de fondo */
.age-box::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("img/logo-1.png") center/80% no-repeat;
  opacity: 1;
  pointer-events: none;
}

/* Encabezado */
.age-box h2 {
  margin: 0 0 10px;
  font-weight: 800;
  letter-spacing: .2px;
  color: #ffffff;
  font-size: 1.4rem;
}

.age-box h2::before {
  content: "🍺 ";
  color: #F25C05; /* naranja Desert Brew */
  font-size: 1.4em;
}

.age-box p {
  margin: 8px 0 20px;
  color: #d7d9df;
  font-family: 'Josefin Sans', sans-serif;
}

/* Botonera */
.age-buttons {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

/* Botón principal */
.age-box .btn.primary {
  background: var(--primary);
  color: #fff;
  border: none;
  box-shadow: 0 6px 16px rgba(242,92,5,0.35);
  font-weight: 700;
}
.age-box .btn.primary:hover {
  transform: translateY(-1px);
  filter: brightness(1.1);
}
.age-box .btn.primary:focus {
  outline: 2px solid #fff;
  outline-offset: 2px;
}

/* Botón secundario */
.age-box .btn.ghost {
  background: transparent;
  color: #f1f1f1;
  border: 1px solid rgba(255,255,255,0.28);
  font-weight: 600;
}
.age-box .btn.ghost:hover {
  background: rgba(255,255,255,0.08);
}
.age-box .btn.ghost:focus {
  outline: 2px solid #fff;
  outline-offset: 2px;
}

/* Animación de entrada */
@keyframes fadeIn {
  from {opacity: 0;}
  to {opacity: 1;}
}

/* Responsivo */
@media (max-width: 480px) {
  .age-box { padding: 26px 20px; }
  .age-buttons .btn {
    width: 100%;
    text-align: center;
  }
}

/* ==== Socios / Puntos de venta ==== */
.partners-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.partner-card{
  position:relative;
  overflow:hidden;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,0));
  box-shadow:var(--shadow);
  padding:16px;
  display:flex;
  gap:14px;
  align-items:flex-start;
}

.partner-card .logo{
  min-width:68px; min-height:68px;
  width:68px; height:68px;
  border-radius:12px;
  background:#0e101400 center/cover no-repeat;
  border:1px solid rgba(255,255,255,.12);
}

.partner-card h4{
  margin:2px 0 6px; font-size:18px; font-weight:800;
}
.partner-card p{
  margin:0; color:var(--muted); font-size:14px;
}

.partner-meta{
  margin-top:8px; display:flex; gap:8px; flex-wrap:wrap;
}

.tag{
  font:600 11px/1 "Josefin Sans", sans-serif;
  padding:6px 8px; border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  color:var(--muted);
}

.partner-actions{
  margin-top:12px; display:flex; gap:10px; flex-wrap:wrap;
}

.btn.map{ background:var(--secondary); color: #111; }
.btn.site{ border:1px solid #333; }
.btn.ig{ border:1px dashed rgba(255,255,255,.2); }

@media (max-width:900px){ .partners-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:600px){ .partners-grid{ grid-template-columns:1fr; } }
