/* ===== Variables y reset ===== */
:root{
  --primary:#E21B21; --dark:#000; --text:#444; --light:#fff; --soft:#F7F7F7;
  --heading:'Montserrat',sans-serif; --body:'Roboto',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--text);background:#fff;line-height:1.6;font-weight:300}
.container{max-width:1100px;margin:0 auto;padding:0 20px}
.section-padding{padding:90px 0;opacity:0;transform:translateY(18px);transition:opacity .8s, transform .8s}

/* ===== Tipografía & botones ===== */
h1,h2,h3{font-family:var(--heading);color:var(--dark);text-transform:uppercase;font-weight:700;line-height:1.2;text-align:center}
h2{font-size:2.2rem;letter-spacing:1.5px;border-bottom:2px solid var(--primary);display:inline-block;padding-bottom:8px;margin:0 auto 50px}
p{font-size:1.05em}
a{color:var(--primary);text-decoration:none;transition:.25s}
a:hover{color:#c4181d}
.btn{font-family:var(--heading);text-transform:uppercase;font-weight:600;letter-spacing:1px;border:none;border-radius:10px;padding:14px 28px;cursor:pointer;transition:.25s}
.btn-primary{background:var(--primary);color:var(--light);box-shadow:0 6px 16px rgba(226,27,33,.35)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-secondary{background:var(--dark);color:var(--light);box-shadow:0 6px 16px rgba(0,0,0,.25)}
.btn-secondary:hover{transform:translateY(-2px)}

/* ===== Header / Nav ===== */
.header{position:sticky;top:0;z-index:1000;width:100%;background:var(--dark);padding:14px 0;border-bottom:3px solid var(--primary);box-shadow:0 4px 18px rgba(0,0,0,.25)}
.logo{display:flex;align-items:center;max-height:50px;overflow:hidden;text-decoration:none}
.logo-img{max-height:40px}
.logo h1{color:var(--light);font-size:1.5rem;font-weight:600;margin:0}

/* Menú principal */
.nav-list{
  list-style:none;
  display:flex;
  align-items:center;
  gap:0;
  margin:0;
}
.nav-list > li:not(.nav-social){ margin-right:4px; }

.nav-list a{color:var(--light);font-size:.92rem;padding:8px 12px;border-radius:6px}
.nav-list a:hover{background:rgba(255,255,255,.06);color:var(--primary)}

/* Íconos al final del menú */
.nav-social{
  display:flex;
  align-items:center;
  gap:8px;
  margin-left:0;
  padding-left:0;
}
.nav-social a{
  color:#fff;
  font-size:1.18rem;
  line-height:1;
  display:inline-flex;
  padding:2px 4px;
  transition:color .25s ease;
}
.nav-social a:hover{color:var(--primary)}

/* HAMBURGUESA */
.menu-toggle{display:none;flex-direction:column;gap:5px;background:transparent;border:none;cursor:pointer}
.menu-toggle .bar{width:26px;height:3px;background:#fff;border-radius:2px;display:block}

/* ===== HERO: carrusel ===== */
.hero-carousel{position:relative}
.carousel, .carousel-inner, .carousel-item{height:78vh; min-height:520px}
.hero-slide{
  height:100%; width:100%;
  object-fit:cover; object-position:center 35%;
  filter:brightness(.46);
}
.carousel-control-prev-icon,
.carousel-control-next-icon{filter:drop-shadow(0 2px 6px rgba(0,0,0,.6))}

/* Franja inferior del hero */
.hero-bar{
  background:#fff;
  border-top:3px solid var(--primary);
  box-shadow:0 -6px 24px rgba(0,0,0,.06);
  padding:26px 0 34px;
}
.hero-bar__inner{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px}
.hero-bar__title{font-family:var(--heading);text-transform:uppercase;font-weight:800;font-size:2.2rem;letter-spacing:1.5px;margin:0}
.hero-bar__subtitle{margin:0 0 6px 0;color:#555;font-weight:500}
.hero-bar__cta{margin-top:6px}

/* ===== Secciones ===== */
.bg-soft{background:var(--soft)}
.content-wrapper{display:flex;gap:70px;align-items:flex-start}
.image-content{flex:1}
.text-content{flex:1.5}
.about-image{width:100%;height:auto;border:1px solid #eee;border-radius:12px;box-shadow:0 12px 28px rgba(0,0,0,.08);transition:.3s}
.about-image:hover{transform:translateY(-3px)}

/* Subtítulo debajo de “Nuestro Club” */
.section-subtitle{
  margin: 24px 0 10px;
  font-size: 1.35rem;
  font-weight: 700;
  line-height: 1.2;
  text-transform: none;
  position: relative;
  display: inline-block;
  padding-bottom: 6px;
}
.section-subtitle::after{
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 3px;
  background: var(--primary);
  border-radius: 2px;
}

.horarios-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:28px}
.horario-card{background:#fff;border-radius:12px;padding:28px;border-left:4px solid var(--primary);box-shadow:0 10px 26px rgba(0,0,0,.06)}
.horario-card h3{text-align:left;margin-bottom:14px;font-size:1.25rem}
.time-highlight,.price-highlight{color:var(--primary)!important;font-weight:700;font-size:1.15rem}

.eventos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:28px}
.evento-card{border-radius:12px;overflow:hidden;box-shadow:0 12px 28px rgba(0,0,0,.1);display:flex;flex-direction:column;background:#fff}
.event-poster{width:100%;height:300px;object-fit:contain;background:#000}
.evento-card .card-content{padding:20px;display:flex;flex-direction:column;gap:8px;text-align:center}
.event-location{color:var(--primary)!important;font-style:italic}
.evento-card .btn{width:100%;margin-top:10px}

/* Videos */
.videos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px}
.video-item{position:relative;width:100%;aspect-ratio:16/9;background:#000;border-radius:12px;overflow:hidden;box-shadow:0 10px 22px rgba(0,0,0,.12)}
.video-item iframe{position:absolute;inset:0;width:100%;height:100%}
.video-launch{position:absolute;inset:0;border:0;background:transparent;cursor:pointer}

/* Ubicación & Contacto */
address{font-size:1.1rem;letter-spacing:.4px;margin-bottom:20px;color:#111}
.map-container{border:1px solid #eee;border-radius:12px;overflow:hidden;box-shadow:0 12px 28px rgba(0,0,0,.08)}
.map-note{padding:10px 14px;background:#fff}
.contact-info-form{display:grid;grid-template-columns:1fr 1.4fr;gap:36px}
.contact-info{background:#fff;border-radius:12px;border-left:4px solid var(--primary);padding:28px}
.contact-info h3{text-align:left;margin-bottom:14px}
.contact-info p{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.contact-info i{color:var(--primary)}
.contact-form{background:var(--soft);border-radius:12px;padding:28px}
.contact-form h3{text-align:center;margin-bottom:18px}
.form-group{margin-bottom:14px}
.form-group input,.form-group textarea{width:100%;padding:12px;border:1px solid #ccc;border-radius:10px;font-family:var(--body)}
.form-success{margin-top:10px;color:green;font-weight:500}

/* Footer */
.footer{background:var(--dark);color:#fff;text-align:center;padding:24px 0;border-top:3px solid var(--primary);font-size:.9rem}
.footer .developer-note{color:#ccc;font-size:.85rem;letter-spacing:.3px}
.footer .developer-note a{color:#ccc;text-decoration:none;border-bottom:1px dotted #666;transition:color .3s}
.footer .developer-note a:hover{color:var(--primary)}
.social-footer{display:flex;justify-content:center;gap:18px;margin-bottom:10px}
.social-footer a{color:#fff;font-size:1.35rem;line-height:1;display:inline-flex;transition:color .25s ease}
.social-footer a:hover{color:var(--primary)}

/* ===== Botón flotante WhatsApp ===== */
.whatsapp-float{
  position:fixed;
  right:18px;
  bottom:18px;
  width:56px;height:56px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:#25D366;
  color:#fff;
  box-shadow:0 10px 24px rgba(0,0,0,.22);
  z-index:1100;
  transition:transform .2s ease, box-shadow .2s ease;
}
.whatsapp-float i{font-size:28px;line-height:1}
.whatsapp-float:hover{transform:translateY(-2px);box-shadow:0 14px 28px rgba(0,0,0,.28)}
@media (max-width:480px){
  .whatsapp-float{right:14px;bottom:14px;width:54px;height:54px}
}

/* ===== Responsive ===== */
@media (max-width:992px){
  .menu-toggle{display:flex}
  .nav{display:none;position:absolute;left:0;top:64px;width:100%;background:var(--dark);box-shadow:0 10px 24px rgba(0,0,0,.35);z-index:999}
  .nav.active{display:block}

  .nav-list{flex-direction:column}
  .nav-list > li{margin-right:0}
  .nav-list a{display:block;width:100%;text-align:center;padding:14px 18px}

  .nav-social{
    justify-content:center;
    padding:8px 0 2px;
    gap:12px;
    margin-left:0;
  }
  .nav-social a{font-size:1.3rem; padding:6px;}

  .content-wrapper,.contact-info-form{grid-template-columns:1fr;gap:26px}

  .carousel, .carousel-inner, .carousel-item{height:64vh; min-height:420px}
  .hero-slide{object-position:center 25%;}
  .hero-bar__title{font-size:1.8rem}
}

@media (max-width:520px){
  .logo h1{
    display:inline-block;
    font-size:1.2rem;
    font-weight:600;
    letter-spacing:0.5px;
    color:#fff;
  }
  .carousel, .carousel-inner, .carousel-item{height:56vh; min-height:360px}
  .hero-slide{object-position:center 15%;}
  .hero-bar__title{font-size:1.6rem}
}

/* ===== Contacto: íconos de redes ===== */
.contact-info .social-icons{
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 6px;
}
.contact-info .social-icons a{
  display: inline-flex;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}
.contact-info .social-icons i{
  font-size: 20px;
  line-height: 1;
}
.contact-info .social-icons a:hover i{ transform: scale(1.06); }
@media (max-width: 480px){
  .contact-info .social-icons{ gap: 8px; }
  .contact-info .social-icons a{ width: 34px; height: 34px; }
  .contact-info .social-icons i{ font-size: 18px; }
}

/* ==== Profesores (Nuestro Club) ==== */
.coaches-list{
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.coach{
  display: flex;
  align-items: center;
  gap: 18px;
  background: #fff;
  border-radius: 14px;
  padding: 18px 18px;
  border-left: 4px solid var(--primary);
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}
.coach-photo{
  width: 110px;
  height: 110px;
  border-radius: 50%;
  object-fit: cover;
  background: #f3f3f3;
  border: 3px solid #eee;
  flex: 0 0 110px;
}
.coach-info h3{
  margin: 0 0 6px 0;
  text-align: left;     /* sobrescribe h3 global */
  text-transform: none; /* no forzar mayúsculas */
  font-size: 1.2rem;
}
.coach-info .rank{ color:#555; font-weight:600; }
.coach-bullets{
  margin: 0;
  padding-left: 18px;
  line-height: 1.5;
}

@media (max-width: 640px){
  .coach{ align-items: flex-start; }
  .coach-photo{ width: 90px; height: 90px; flex-basis: 90px; }
  .coach-info h3{ font-size: 1.05rem; }
}
