/* ====== Base ====== */
:root{
  --bg:#181818;          /* fondo oscuro */
  --panel:#1f1f1f;       /* tarjetas/paneles */
  --text:#eaeaea;        /* texto principal */
  --muted:#b7b7b7;       /* texto suave */
  --red:#e53935;         /* rojo del club (puedes ajustar) */
  --red-2:#ff5252;       /* acento claro */
  --line:#2b2b2b;        /* bordes sutiles */
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif;
  color:var(--text);
  background:var(--bg);
}

/* ====== Layout helpers ====== */
.container{max-width:1100px;margin-inline:auto;padding:0 16px}
.section{padding:72px 0}
.section-title{font-family:"Cormorant Garamond",serif;font-weight:700;font-size:28px;margin:0 0 16px}
.lead{color:var(--muted);margin:6px 0 18px}

/* ====== Header / Nav ====== */
.site-header{
  position:sticky; top:0; z-index:40;
  backdrop-filter:saturate(180%) blur(8px);
  background:rgba(0,0,0,.45);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; padding:12px 16px; max-width:1100px; margin:0 auto;
}
.brand{display:flex; align-items:center; gap:10px; text-decoration:none; color:var(--text)}
.brand-logo{height:42px; width:auto; display:block}
.brand-name{font-weight:600}
.burger{
  display:none; background:transparent; border:0; padding:8px; cursor:pointer;
}
.burger span{
  display:block; width:22px; height:2px; background:var(--text); margin:5px 0; border-radius:2px;
}
.menu{display:flex; align-items:center; gap:18px; list-style:none; margin:0; padding:0}
.menu a{color:#cfcfcf; text-decoration:none; font-size:14.5px}
.menu a:hover{color:#fff}

/* Mobile */
@media (max-width: 820px){
  .burger{display:block}
  .menu{position:absolute; right:12px; top:64px; background:#101010; border:1px solid var(--line); border-radius:12px;
        padding:10px 12px; display:none; flex-direction:column; gap:10px; min-width:180px}
  .menu.open{display:flex}
}

/* ====== Hero ====== */
.hero{
  position:relative; overflow:hidden;
  background:
    radial-gradient(ellipse at top, rgba(229,57,53,0.12), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,0.02), transparent 30%);
}
.hero-inner{display:grid; grid-template-columns:1.1fr 1fr; gap:28px; align-items:center; max-width:1100px; margin:0 auto; padding:64px 16px}
@media (max-width: 980px){ .hero-inner{grid-template-columns:1fr} }
.headline{font-family:"Cormorant Garamond",serif; font-size:42px; line-height:1.1; margin:0}
.accent{background:linear-gradient(90deg,var(--red),var(--red-2)); -webkit-background-clip:text; background-clip:text; color:transparent}
.subtitle{color:var(--muted); margin:14px 0 0}
.meta{color:#9a9a9a; font-size:12px; margin-top:10px}

.hero-media{position:relative}
.frame{
  margin:0; overflow:hidden; border-radius:20px; border:1px solid var(--line);
  box-shadow:0 20px 60px rgba(0,0,0,.35);
}
.frame img{display:block; width:100%; height:auto; object-fit:cover; aspect-ratio:16/9}
.hero-badge{
  position:absolute; left:-16px; bottom:-16px;
  background:rgba(10,10,10,.75); backdrop-filter:blur(6px);
  border:1px solid var(--line); border-radius:14px; padding:10px 12px; font-size:13px;
}

/* ====== Buttons ====== */
.btn{display:inline-block; padding:12px 18px; border-radius:12px; text-decoration:none; font-weight:600; font-size:14.5px}
.btn.primary{background:linear-gradient(135deg,var(--red),var(--red-2)); color:#111}
.btn.primary:hover{filter:brightness(1.05)}
.btn.ghost{border:1px solid var(--line); color:var(--text)}
.btn.ghost:hover{background:#202020}
.cta-row{display:flex; gap:12px; margin-top:18px; flex-wrap:wrap}

/* ====== Nosotros ====== */
.about{display:grid; grid-template-columns:1.2fr .8fr; gap:28px; align-items:start}
@media (max-width: 980px){ .about{grid-template-columns:1fr} }
.about-text h3{margin:22px 0 8px; font-weight:700; font-family:"Cormorant Garamond",serif}
.about-text p{color:#d6d6d6; line-height:1.7}
.benefits{margin:10px 0 0 0; padding-left:18px; color:#d6d6d6}
.benefits li{margin:8px 0}
.about-stats{
  display:grid; grid-template-columns:repeat(2,1fr); gap:12px;
}
.stat{
  background:var(--panel); border:1px solid var(--line); border-radius:14px; padding:16px;
  display:flex; flex-direction:column; align-items:flex-start; gap:4px;
}
.stat-num{font-size:28px; font-weight:800; line-height:1; background:linear-gradient(90deg,var(--red),var(--red-2)); -webkit-background-clip:text; background-clip:text; color:transparent}
.stat-label{color:#c9c9c9; font-size:13px}

/* ====== Contacto ====== */
.grid-2{display:grid; grid-template-columns:1.1fr .9fr; gap:28px; align-items:center}
@media (max-width: 980px){ .grid-2{grid-template-columns:1fr} }
.contact-list{list-style:none; padding:0; margin:12px 0 18px}
.contact-list li{margin:6px 0; color:#d6d6d6}
.map-frame{
  border:1px solid var(--line); border-radius:16px; overflow:hidden; background:#111;
  height:320px;
}
.map-frame iframe{width:100%; height:100%; display:block; filter:grayscale(20%)}

/* ====== Footer ====== */
.site-footer{border-top:1px solid var(--line); padding:18px 0}
.footer-inner{display:flex; align-items:center; justify-content:space-between; gap:12px; color:#bdbdbd; font-size:14px}
@media (max-width: 720px){ .footer-inner{flex-direction:column} }

/* ====== WhatsApp Float ====== */
.wa-float{
  position:fixed; right:16px; bottom:16px; width:56px; height:56px; border-radius:999px;
  display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg,var(--red),var(--red-2));
  box-shadow:0 10px 30px rgba(0,0,0,.35);
  transition:transform .15s ease-in-out; z-index:60;
}
.wa-float:hover{transform:scale(1.04)}
.wa-float img{width:28px; height:28px; filter:invert(0);}

/* ====== Utilities ====== */
hr{border:none; height:1px; background:var(--line); margin:24px 0}

/* Galería */
.gallery{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:12px;
}
.gallery img{
  width:100%; height:100%;
  object-fit:cover;
  border-radius:12px;
  border:1px solid var(--line);
  transition:transform .3s;
}
.gallery img:hover{transform:scale(1.03)}

/* Formulario de contacto */
.contact-form{
  display:flex;
  flex-direction:column;
  gap:12px;
  margin-top:18px;
}
.contact-form input,
.contact-form textarea{
  padding:12px;
  border-radius:10px;
  border:1px solid var(--line);
  background:var(--panel);
  color:var(--text);
  font-size:14.5px;
}
.contact-form input:focus,
.contact-form textarea:focus{
  outline:none;
  border-color:var(--red-2);
  box-shadow:0 0 0 2px rgba(229,57,53,.3);
}
.contact-form button{align-self:flex-start}


/* ===== Estética mejorada ===== */

/* Fondo con textura + líneas muy sutiles */
body::before{
  content:""; position:fixed; inset:0; z-index:-2;
  background:
    radial-gradient(1200px 600px at 20% -10%, rgba(229,57,53,.10), transparent 60%),
    radial-gradient(1200px 600px at 110% 10%, rgba(255,82,82,.10), transparent 60%);
  pointer-events:none;
}
body::after{
  content:""; position:fixed; inset:0; z-index:-3; opacity:.06;
  background:
    linear-gradient(transparent 31px, #fff 32px),
    linear-gradient(90deg, transparent 31px, #fff 32px);
  background-size:32px 32px;
  mix-blend-mode:overlay; pointer-events:none;
}

/* Kicker (etiqueta pequeña sobre títulos) */
.kicker{
  display:inline-block; font-size:12px; letter-spacing:.12em; text-transform:uppercase;
  color:#ffb3b3; background:rgba(229,57,53,.12); border:1px solid rgba(229,57,53,.3);
  padding:6px 10px; border-radius:999px; margin-bottom:10px;
}

/* Títulos con subrayado animado */
.section-title{
  position:relative; display:inline-block; margin-top:4px;
}
.section-title::after{
  content:""; position:absolute; left:0; bottom:-6px; height:3px; width:0%;
  background:linear-gradient(90deg, var(--red), var(--red-2));
  border-radius:3px; transition:width .6s ease;
}
.section:hover .section-title::after{ width:100%; }

/* Cards con borde degradado elegante */
.card{
  border-radius:16px; padding:18px;
  background:
    linear-gradient(var(--panel), var(--panel)) padding-box,
    linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,0) 40%, rgba(229,57,53,.25)) border-box;
  border:1px solid transparent;
  box-shadow:0 12px 40px rgba(0,0,0,.25);
}
.stat{ background:none; border:none; padding:0; }
.stat .inner{ composes: card; } /* si tu editor no soporta composes, reemplaza con .card */

/* Hover micro-levitación */
.hover-rise{ transition:transform .2s ease, box-shadow .2s ease; }
.hover-rise:hover{ transform:translateY(-3px); box-shadow:0 16px 50px rgba(0,0,0,.35); }

/* Separador con línea + puntos */
.hr-fancy{
  --c: rgba(255,255,255,.08);
  height:12px; margin:26px 0; background:
    linear-gradient(var(--c), var(--c)) center/100% 1px no-repeat,
    radial-gradient(circle at 50% 50%, var(--c) 2px, transparent 3px) left/16px 100% repeat-x;
  mask:linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
}

/* Reveal on scroll */
.reveal{ opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s ease; }
.reveal.is-visible{ opacity:1; transform:none; }

/* Hero badge mejorado */
.hero-badge{
  left:-12px; bottom:-14px; font-weight:600; color:#eaeaea;
  border:1px solid rgba(255,255,255,.08);
}

/* Stats remaquilladas */
.about-stats{ gap:16px; }
.about-stats .stat{ padding:0; }
.about-stats .stat .inner{
  display:flex; flex-direction:column; gap:6px; padding:16px;
  border-radius:16px;
  background:
    linear-gradient(var(--panel), var(--panel)) padding-box,
    linear-gradient(145deg, rgba(255,255,255,.08), rgba(229,57,53,.24)) border-box;
  border:1px solid transparent;
}
.stat-num{ font-size:30px; }

/* Galería tipo “masonry-lite” con tamaños variados */
.gallery{
  --min:220px;
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(var(--min), 1fr));
  gap:12px;
}
.gallery figure{ margin:0; border-radius:14px; overflow:hidden; border:1px solid var(--line); }
.gallery img{ width:100%; height:100%; object-fit:cover; transition:transform .35s ease; display:block; }
.gallery figure:hover img{ transform:scale(1.04); }
.gallery figure.tall  img{ aspect-ratio:3/4; }
.gallery figure.wide  img{ aspect-ratio:16/9; }
.gallery figure.square img{ aspect-ratio:1/1; }

/* Lightbox */
.lightbox{ position:fixed; inset:0; display:none; place-items:center; background:rgba(0,0,0,.8); z-index:999; }
.lightbox.open{ display:grid; }
.lightbox img{ max-width:min(92vw, 1200px); max-height:86vh; border-radius:16px; box-shadow:0 20px 80px rgba(0,0,0,.6); }

/* Botón WhatsApp: pulso sutil */
.wa-float{ animation:floatIn .35s ease-out both; }
.wa-float:hover{ animation:none; transform:translateY(-2px) scale(1.03); }
@keyframes floatIn{ from{ transform:translateY(8px); opacity:.0 } to{ transform:none; opacity:1 } }

/* Mejoras de formulario */
.contact-form{ margin-top:22px; }
.contact-form input, .contact-form textarea{ backdrop-filter:saturate(120%); }


/* ===== Header refinado ===== */
.nav-glass{
  position:sticky; top:0; z-index:60;
  backdrop-filter:saturate(160%) blur(8px);
  background:
    linear-gradient(180deg, rgba(0,0,0,.72), rgba(0,0,0,.52)) 0 0/100% 100%,
    radial-gradient(1800px 220px at 70% -40px, rgba(229,57,53,.18), transparent 60%);
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:box-shadow .2s ease, border-color .2s ease, background .2s ease;
}
.nav-glass.is-scrolled{
  box-shadow:0 6px 28px rgba(0,0,0,.35);
  border-color:rgba(255,255,255,.08);
}

.nav{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:10px 0;
}

/* Marca */
.brand{display:flex; align-items:center; gap:10px; text-decoration:none; color:var(--text)}
.brand-logo{
  width:36px; height:36px; object-fit:contain; display:block;
  border-radius:10px; /* suaviza bordes del PNG */
  background:#181818; /* por si el PNG trae transparencia rara */
}
.brand-name{font-weight:700; letter-spacing:.2px}

/* Menu */
.menu{display:flex; align-items:center; gap:14px; list-style:none; margin:0; padding:0}
.nav-link{
  position:relative; padding:8px 12px; border-radius:999px;
  color:#d8d8d8; text-decoration:none; font-size:14.5px;
  transition:color .15s ease, background .15s ease, transform .15s ease;
}
.nav-link:hover{ color:#fff; background:rgba(255,255,255,.06); }
.nav-link.active{
  color:#111; background:linear-gradient(135deg, var(--red), var(--red-2));
}

/* CTA pill */
.btn-pill{
  display:inline-block; padding:8px 14px; border-radius:999px; text-decoration:none;
  font-weight:700; font-size:14px; color:#111;
  background:linear-gradient(135deg, var(--red), var(--red-2));
  box-shadow:0 8px 24px rgba(229,57,53,.35);
}
.btn-pill:hover{ filter:brightness(1.05); }

/* Burger + drawer móvil */
.burger{display:none; background:transparent; border:0; padding:8px; cursor:pointer}
.burger span{display:block; width:22px; height:2px; background:#eee; margin:5px 0; border-radius:2px}
@media (max-width: 860px){
  .burger{display:block}
  .menu{
    position:fixed; right:12px; top:64px; width:min(92vw, 320px);
    background:#111; border:1px solid rgba(255,255,255,.08); border-radius:16px;
    box-shadow:0 20px 60px rgba(0,0,0,.5);
    padding:12px; display:none; flex-direction:column; align-items:stretch; gap:8px;
  }
  .menu.open{ display:flex; }
  .nav-link, .btn-pill{ display:block; text-align:left; }
}

/* ===== Carrito lateral ===== */
.cart-panel{
  position:fixed; right:-420px; top:0; width:min(92vw,400px); height:100%;
  background:#111; border-left:1px solid rgba(255,255,255,.08);
  box-shadow:-20px 0 60px rgba(0,0,0,.45);
  z-index:80; display:flex; flex-direction:column; transition:right .25s ease;
}
.cart-panel.open{ right:0; }
.cart-backdrop{
  position:fixed; inset:0; background:rgba(0,0,0,.45); backdrop-filter:blur(2px);
  z-index:70; display:none;
}
.cart-backdrop.show{ display:block; }

.cart-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 16px; border-bottom:1px solid rgba(255,255,255,.08);
}
.cart-head strong{ font-size:16px; }
.cart-head button{
  background:transparent; color:#ddd; border:0; font-size:18px; cursor:pointer;
}
.cart-items{ padding:12px 12px 130px 12px; overflow:auto; flex:1; display:grid; gap:10px; }
.cart-item{
  display:grid; grid-template-columns:64px 1fr auto; gap:10px; align-items:center;
  border:1px solid var(--line); border-radius:12px; padding:8px; background:#141414;
}
.cart-item img{ width:64px; height:64px; object-fit:cover; border-radius:8px; }
.cart-item .meta{ font-size:12.5px; color:#bdbdbd; }
.qty-mini{ display:flex; align-items:center; gap:6px; }
.qty-mini input{
  width:52px; padding:6px; text-align:center; border-radius:10px;
  border:1px solid var(--line); background:#0f0f0f; color:#fff;
}
.cart-item .remove{
  background:transparent; border:0; color:#ff8a80; cursor:pointer; font-size:18px; padding:6px;
}

.cart-foot{
  position:absolute; bottom:0; left:0; right:0; border-top:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.02), transparent 40%), #111;
  padding:12px; display:grid; gap:8px;
}
.cart-total{ font-weight:700; }
.cart-actions{ display:flex; gap:8px; justify-content:space-between; }

#cartCount{
  display:inline-block; min-width:20px; padding:0 6px; text-align:center;
  background:#111; border-radius:999px; margin-left:6px;
}


/* Hero con imagen de fondo */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: url('/img/hero.jpg') no-repeat center center/cover;
  color: #fff;
  text-align: center;
}

/* Oscurecer imagen para que resalte el texto */
.hero .overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}

.hero-content {
  position: relative;
  max-width: 800px;
  z-index: 1;
}

.hero .headline {
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 1rem;
}

.hero .subtitle {
  font-size: 1.25rem;
  margin-bottom: 2rem;
  color: #eee;
}

.cta-row {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}

.hero-content {
  animation: fadeInUp 1.5s ease;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.btn.primary:hover {
  background: #c00;
  transform: scale(1.05);
  transition: all 0.3s ease;
}

.btn.ghost:hover {
  background: rgba(255,255,255,0.1);
  border-color: #fff;
}

/* ===== Misión / Visión ===== */
.mv-wrap{
  background:#1b1412;          /* tono oscuro como el ejemplo */
  color:#fff;
  padding: clamp(3rem, 6vw, 5rem) 0;
}

.mv-grid{
  display:grid;
  grid-template-columns: 1fr minmax(220px,360px) 1fr; /* izq | logo | der */
  align-items:center;
  gap: clamp(2rem,4vw,3rem);
}

.mv-col p{
  line-height:1.8;
  font-size: clamp(1rem, 1.1vw + .8rem, 1.25rem);
  color:#f2f2f2;
}

.mv-title{
  font-family: "Cormorant Garamond", serif;
  font-weight: 700;
  font-size: clamp(2rem, 2.2vw + 1rem, 3rem);
  margin: 0 0 1rem 0;
  display:flex;
  align-items:center;
  gap:.6rem;
}

.mv-icon{
  display:inline-flex;
  width: 1.2em;
  height: 1.2em;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background: transparent;
  filter: drop-shadow(0 2px 0 rgba(0,0,0,.2));
}

/* Logo central circular con recorte */
.mv-logo{
  display:flex;
  justify-content:center;
}
.mv-logo img{
  width: 100%;
  max-width: 360px;
  aspect-ratio: 1/1;
  object-fit: contain;
  background: radial-gradient(ellipse at center, rgba(255,255,255,.06), rgba(0,0,0,0));
  border-radius: 50%;
  padding: clamp(1rem, 2vw, 1.5rem);
  box-shadow:
    0 10px 30px rgba(0,0,0,.35),
    inset 0 0 0 1px rgba(255,255,255,.06);
}

/* Responsive */
@media (max-width: 980px){
  .mv-grid{
    grid-template-columns: 1fr;            /* stack */
    text-align:left;
  }
  .mv-logo{
    order: -1;                             /* logo primero en mobile */
    margin-bottom: 1rem;
  }
}

/* ===== Preguntas Frecuentes ===== */
.faq {
  background: #1b1412; /* mismo fondo oscuro de misión/visión */
  color: #fff;
}

.faq .section-title {
  text-align: center;
  margin-bottom: 1rem;
}

.faq .lead {
  text-align: center;
  margin-bottom: 2.5rem;
  color: #ddd;
}

.faq-list {
  max-width: 800px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.faq-list details {
  background: #241c1a;
  border-radius: 8px;
  padding: 1rem 1.25rem;
  cursor: pointer;
  transition: all 0.3s ease;
  border: 1px solid transparent;
}

.faq-list details:hover {
  border-color: rgba(255,255,255,0.1);
}

.faq-list summary {
  font-weight: 600;
  color: #ff4444; /* rojo acorde a tu estilo */
  font-size: 1.1rem;
  list-style: none;
}

.faq-list summary::-webkit-details-marker {
  display: none; /* quita el ícono default */
}

.faq-list p {
  margin-top: 0.75rem;
  line-height: 1.6;
  color: #eee;
}

