/* Juventus Cuernavaca Academy - Secuencia Gráfica estándar */
:root{
  --bg:#0b0b0f;
  --bg2:#0f1018;
  --card:#121321;
  --text:#f4f4f7;
  --muted:#b6b7c4;
  --line:rgba(255,255,255,.10);
  --accent:#c6a24a; /* dorado */
  --shadow: 0 20px 60px rgba(0,0,0,.45);
  --radius: 22px;
  --radius2: 16px;
  --container: 1140px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--text);
  background: radial-gradient(1200px 500px at 20% -10%, rgba(198,162,74,.18), transparent 60%),
              radial-gradient(900px 500px at 80% 0%, rgba(255,255,255,.06), transparent 60%),
              var(--bg);
  line-height:1.55;
}

a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
.container{width:min(var(--container), calc(100% - 40px)); margin:0 auto}

.header{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(12px);
  background: rgba(11,11,15,.65);
  border-bottom:1px solid var(--line);
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 18px;
}

.brand{display:flex; align-items:center; gap:12px; min-width: 220px}
.brand__logo{width:44px; height:44px; border-radius:12px; box-shadow: 0 10px 30px rgba(0,0,0,.35)}
.brand__name{font-weight:900; letter-spacing:.12em; font-size:12px}
.brand__sub{font-size:12px; color:var(--muted)}

.nav{display:flex; align-items:center; gap:14px}
.nav a{
  font-size:14px;
  color: rgba(244,244,247,.92);
  padding:10px 12px;
  border-radius:12px;
  transition: .2s ease;
}
.nav a:hover{background: rgba(255,255,255,.06)}
.nav__cta{
  background: linear-gradient(135deg, rgba(198,162,74,.95), rgba(198,162,74,.70));
  color:#101015;
  font-weight:800;
}
.nav__cta:hover{filter:brightness(1.03)}

.navToggle{
  display:none;
  width:46px; height:42px;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--line);
  border-radius: 14px;
  cursor:pointer;
}
.navToggle span{display:block; height:2px; background:var(--text); margin:7px 10px; opacity:.9}

.hero{
  position:relative;
  min-height: 78vh;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.hero__bg{
  position:absolute; inset:0;
  background-image: url("../img/hero.jpg");
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
  filter: saturate(1.05) contrast(1.05) brightness(.92);
}
.hero__overlay{
  position:absolute; inset:0;
  background: linear-gradient(90deg, rgba(11,11,15,.82), rgba(11,11,15,.35) 55%, rgba(11,11,15,.75)),
              radial-gradient(800px 600px at 20% 30%, rgba(198,162,74,.16), transparent 55%);
}
.hero__content{position:relative; padding:68px 0 38px}
.badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border:1px solid rgba(198,162,74,.35);
  border-radius: 999px;
  background: rgba(198,162,74,.10);
  color: rgba(244,244,247,.95);
  font-weight:700;
  letter-spacing:.02em;
  width: fit-content;
}
.hero h1{
  margin:14px 0 10px;
  font-size: clamp(34px, 5vw, 56px);
  line-height: 1.05;
  letter-spacing: -.02em;
}
.accent{color: var(--accent)}
.lead{max-width: 58ch; color: rgba(244,244,247,.92); font-size: 18px}

.hero__actions{display:flex; gap:12px; flex-wrap:wrap; margin-top:18px}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px;
  padding:12px 16px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.06);
  color: var(--text);
  font-weight: 750;
  transition:.18s ease;
}
.btn:hover{transform: translateY(-1px); background: rgba(255,255,255,.09)}
.btn--primary{
  background: linear-gradient(135deg, rgba(198,162,74,.98), rgba(198,162,74,.75));
  color:#101015;
  border-color: rgba(198,162,74,.45);
}
.btn--ghost{background: rgba(255,255,255,.04)}
.btn--block{width:100%}
.btn--small{padding:10px 14px; border-radius: 14px}

.hero__stats{
  margin-top: 26px;
  display:flex; gap:14px; flex-wrap:wrap;
}
.stat{
  background: rgba(18,19,33,.55);
  border: 1px solid var(--line);
  border-radius: var(--radius2);
  padding: 14px 16px;
  min-width: 140px;
  box-shadow: 0 18px 50px rgba(0,0,0,.25);
}
.stat__num{font-weight: 900; font-size: 18px}
.stat__label{color: var(--muted); font-size: 12px; margin-top:2px}

.strip{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background: rgba(255,255,255,.02);
}
.strip__inner{display:flex; align-items:center; justify-content:space-between; padding: 14px 0; gap:14px}
.strip__title{font-weight:900; letter-spacing:.08em; font-size:12px; color: rgba(244,244,247,.92)}
.strip__links{display:flex; gap:10px; flex-wrap:wrap}
.chip{
  border:1px solid rgba(255,255,255,.12);
  padding:8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.04);
  color: rgba(244,244,247,.92);
  font-weight:700;
  font-size: 13px;
}
.chip:hover{background: rgba(255,255,255,.07)}

.section{padding: 64px 0}
.section--alt{background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0))}
.section__head{max-width: 70ch; margin-bottom: 22px}
.section__head h2{margin:0 0 8px}
.section__head p{margin:0}

h2{font-size: clamp(26px, 3vw, 36px); line-height:1.12; margin:0 0 14px}
h3{margin:0 0 8px}
p{margin:0 0 12px}
.muted{color: var(--muted)}
.small{font-size: 13px}

.grid-2{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 26px;
  align-items:start;
}

.checklist{padding-left: 18px; margin: 14px 0 0}
.checklist li{margin: 10px 0; color: rgba(244,244,247,.92)}
.cards{display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:12px; margin-top: 16px}
.card{
  border:1px solid var(--line);
  border-radius: var(--radius2);
  background: rgba(18,19,33,.55);
  padding: 16px;
}
.card__kicker{font-size: 12px; letter-spacing:.10em; color: rgba(244,244,247,.78)}
.card__title{font-weight: 900; margin-top:6px; font-size: 18px}
.card__text{color: var(--muted); margin-top:6px; font-size: 13px}

.media{display:grid; grid-template-columns: 1fr 1fr; gap: 12px}
.media__frame{
  border-radius: var(--radius);
  overflow:hidden;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.03);
  box-shadow: var(--shadow);
}
.media__frame img{width:100%; height: 100%; object-fit: cover; aspect-ratio: 4/3}

.features{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 12px;
}
.feature{
  border:1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(18,19,33,.55);
  padding: 18px;
  box-shadow: 0 16px 45px rgba(0,0,0,.22);
}
.feature__icon{font-size: 22px; margin-bottom: 8px}
.feature p{color: var(--muted); margin:0}

.note{
  margin-top: 18px;
  display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap;
  border:1px solid rgba(198,162,74,.28);
  border-radius: var(--radius);
  background: rgba(198,162,74,.08);
  padding: 16px;
}
.note__title{font-weight: 900}
.note__text{color: rgba(244,244,247,.88)}

.gallery{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 12px;
}
.gallery__item{
  padding:0; border:1px solid var(--line);
  background: rgba(255,255,255,.03);
  border-radius: var(--radius);
  overflow:hidden;
  cursor:pointer;
  box-shadow: 0 14px 40px rgba(0,0,0,.22);
  transition: .18s ease;
}
.gallery__item:hover{transform: translateY(-2px)}
.gallery__item img{width:100%; height: 100%; object-fit: cover; aspect-ratio: 4/3}

.videoCard, .mapCard, .embed{
  border:1px solid var(--line);
  border-radius: var(--radius);
  overflow:hidden;
  background: rgba(255,255,255,.02);
  box-shadow: var(--shadow);
}
.videoCard__ratio, .mapCard{aspect-ratio: 16/10}
.videoCard iframe, .mapCard iframe, .embed iframe{width:100%; height:100%}
.embed{height: 600px}

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

.schedule{
  border:1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(18,19,33,.55);
  overflow:hidden;
}
.schedule__row{
  display:flex; justify-content:space-between; gap:16px;
  padding: 14px 16px;
  border-bottom:1px solid var(--line);
}
.schedule__row:last-child{border-bottom:none}
.schedule__day{font-weight: 900}
.schedule__time{color: var(--muted)}

.callout{
  margin-top: 14px;
  border:1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255,255,255,.03);
  padding: 16px;
}
.callout__title{font-weight:900; margin-bottom:6px}
.callout__text{color: var(--muted); margin-bottom: 10px}

.contactCards{display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 12px; margin-top: 14px}
.contactCard{
  display:flex; gap:12px; align-items:center;
  border:1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(18,19,33,.55);
  padding: 14px;
  transition: .18s ease;
}
.contactCard:hover{transform: translateY(-2px); background: rgba(18,19,33,.70)}
.contactCard__icon{font-size: 22px}
.contactCard__title{font-weight: 900}
.contactCard__text{color: var(--muted); font-size: 13px}

.divider{height:1px; background: var(--line); margin: 18px 0}

.form{
  border:1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(18,19,33,.55);
  padding: 16px;
  box-shadow: 0 16px 50px rgba(0,0,0,.25);
}
.form__row{display:flex; flex-direction:column; gap:8px; margin-bottom: 12px}
label{font-weight: 800; font-size: 13px; color: rgba(244,244,247,.92)}
input, textarea{
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  padding: 12px 12px;
  color: var(--text);
  outline: none;
  font-size: 14px;
}
input:focus, textarea:focus{border-color: rgba(198,162,74,.55); box-shadow: 0 0 0 4px rgba(198,162,74,.12)}

.footer{
  padding: 30px 0 18px;
  border-top:1px solid var(--line);
  background: rgba(0,0,0,.22);
}
.footer__inner{display:grid; gap: 16px}
.footer__brand{display:flex; gap: 12px; align-items:center}
.footer__brand img{width:46px; height:46px; border-radius: 14px}
.footer__name{font-weight: 900}
.footer__small{color: var(--muted); font-size: 13px}
.footer__links{display:flex; gap: 12px; flex-wrap:wrap}
.footer__links a{color: rgba(244,244,247,.92); padding:8px 10px; border-radius: 12px}
.footer__links a:hover{background: rgba(255,255,255,.06)}
.footer__bottom{color: var(--muted); font-size: 13px}
.footer__bottom a{color: rgba(244,244,247,.92)}

.float{
  position: fixed;
  right: 16px;
  z-index: 60;
  display:flex; align-items:center; justify-content:center;
  border-radius: 999px;
  border:1px solid var(--line);
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
  background: rgba(18,19,33,.72);
  backdrop-filter: blur(10px);
  transition: .18s ease;
}
.float:hover{transform: translateY(-2px); background: rgba(18,19,33,.86)}
.float--call{
  bottom: 86px;
  width: 52px; height: 52px;
}
.float--wa{
  bottom: 18px;
  padding: 14px 16px;
  gap:10px;
  font-weight: 900;
}
.float--wa span{display:inline-block}
.float--call span{font-size: 22px}

.lightbox{
  position: fixed; inset: 0;
  display:none;
  align-items:center; justify-content:center;
  background: rgba(0,0,0,.72);
  z-index: 80;
  padding: 18px;
}
.lightbox.is-open{display:flex}
.lightbox__img{
  max-width: min(1100px, 100%);
  max-height: 78vh;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: var(--shadow);
}
.lightbox__close{
  position:absolute; top: 14px; right: 14px;
  width: 44px; height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(18,19,33,.75);
  color: var(--text);
  font-size: 28px;
  cursor:pointer;
}

/* Reveal animations */
.reveal{opacity:0; transform: translateY(14px); transition: .6s ease}
.reveal.is-visible{opacity:1; transform: translateY(0)}

/* Responsive */
@media (max-width: 980px){
  .grid-2{grid-template-columns: 1fr}
  .features{grid-template-columns: repeat(2, minmax(0,1fr))}
  .gallery{grid-template-columns: repeat(2, minmax(0,1fr))}
  .contactCards{grid-template-columns: 1fr}
  .embed{height: 520px}
  .hero__content{padding: 54px 0 26px}
}
@media (max-width: 860px){
  .navToggle{display:inline-block}
  .nav{
    position: fixed;
    top: 72px; left: 14px; right: 14px;
    background: rgba(11,11,15,.92);
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 10px;
    display:none;
    flex-direction: column;
    gap: 6px;
  }
  .nav.is-open{display:flex}
  .nav a{padding: 12px 12px}
}
