/* ===== Header ===== */
.site-header{ position:fixed; top:0; left:0; right:0; z-index:50; transition:background .3s ease, box-shadow .3s ease, padding .3s ease; }
.site-header .wrap{ display:flex; align-items:center; justify-content:space-between; padding-block:18px; }
.site-header.scrolled{ background:rgba(20,27,77,.96); backdrop-filter:blur(8px); box-shadow:0 10px 30px -18px rgba(0,0,0,.6); }
.site-header.scrolled .wrap{ padding-block:12px; }
.nav{ display:flex; align-items:center; gap:2rem; }
.nav-links{ display:flex; gap:1.7rem; list-style:none; margin:0; padding:0; font-family:var(--f-head);
  text-transform:uppercase; font-size:.9rem; letter-spacing:.04em; }
.nav-links a{ color:rgba(255,255,255,.85); padding:.3em 0; position:relative; }
.nav-links a:hover{ color:#fff; }
.nav-links a::after{ content:""; position:absolute; left:0; right:100%; bottom:-2px; height:2px; background:var(--pink); transition:right .25s ease; }
.nav-links a:hover::after{ right:0; }
.nav-toggle{ display:none; background:none; border:0; cursor:pointer; padding:8px; }
.nav-toggle span{ display:block; width:26px; height:2px; background:#fff; margin:5px 0; transition:.3s; }
.mobile-menu{ display:none; }

/* ===== Hero ===== */
.hero{ position:relative; min-height:100vh; min-height:100svh; display:flex; align-items:center;
  background:var(--navy); overflow:hidden; }
.hero-photo{ position:absolute; inset:0; z-index:1; }
.hero-photo .ph{ position:absolute; inset:0; border-radius:0; }
/* Foto de fondo del hero (p04-01 "La Marca").
   La foto tiene a los jugadores en la mitad derecha; hacemos zoom hacia ese
   foco para que el grupo llene toda la sección y no quede vacío a la izquierda. */
.hero-photo{ overflow:hidden; }
.hero-bg{ position:absolute; inset:0; background-size:cover; background-position:center 35%;
  transform:scale(1.6); transform-origin:74% 42%; opacity:.6; }
.hero-photo::after{ content:""; position:absolute; inset:0; z-index:2;
  background:linear-gradient(90deg, rgba(20,27,77,.82) 0%, rgba(20,27,77,.5) 50%, rgba(20,27,77,.3) 100%); }
.hero-inner{ position:relative; z-index:4; width:100%; padding-block:120px 60px; }
.hero h1{ font-size:clamp(2.6rem,6.4vw,5.4rem); color:#fff; line-height:.95; margin:.8rem 0 0; }
.hero .ssub{ font-family:var(--f-head); font-weight:500; text-transform:uppercase; color:#fff;
  font-size:clamp(1.1rem,2.2vw,1.9rem); letter-spacing:.02em; line-height:1.05; margin-top:.6rem; max-width:16ch; }
.hero .ssub b{ color:var(--pink); font-weight:700; }
.hero-meta{ display:flex; flex-wrap:wrap; align-items:center; gap:0; margin-top:2.2rem; }
.hero-meta .hm{ color:#fff; font-family:var(--f-head); text-transform:uppercase; font-size:1rem;
  letter-spacing:.04em; padding:0 1.4rem; }
.hero-meta .hm:first-child{ padding-left:0; }
.hero-meta .hm + .hm{ border-left:1px solid rgba(255,255,255,.28); }

/* ===== Componentes de página ===== */
.kicker-row{ display:flex; align-items:center; gap:.8rem; }
.kicker-row::before{ content:""; width:34px; height:2px; background:var(--pink); }

/* beneficios — editorial, numerado */
.benefits{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; }
.bft{ padding:0 clamp(22px,3vw,46px); border-left:1px solid rgba(20,27,77,.14); }
.bft:first-child{ border-left:0; padding-left:0; }
.bft-n{ display:block; font-family:var(--f-head); font-weight:700; font-size:clamp(3.4rem,5vw,5rem);
  line-height:.78; color:transparent; -webkit-text-stroke:1.6px rgba(20,27,77,.26);
  transition:-webkit-text-stroke-color .25s ease, color .25s ease; }
.bft:hover .bft-n{ -webkit-text-stroke-color:var(--pink); }
.bft-line{ width:46px; height:3px; background:var(--pink); margin:1.5rem 0 1.3rem; transition:width .25s ease; }
.bft:hover .bft-line{ width:72px; }
.bft h3{ color:var(--navy); font-size:clamp(1.35rem,1.8vw,1.7rem); margin:0; line-height:1.06; }
.bft p{ color:var(--text-mute); margin:.95rem 0 0; max-width:30ch; }

/* detalles — panel de datos del evento */
.facts{ background:var(--navy); border-radius:var(--r-lg); box-shadow:var(--shadow);
  display:grid; grid-template-columns:repeat(4,1fr); gap:0;
  padding:clamp(32px,4vw,54px) clamp(26px,3vw,44px); }
.fact{ padding:0 clamp(16px,2.4vw,38px); border-left:1px solid rgba(255,255,255,.14); }
.fact:first-child{ border-left:0; padding-left:0; }
.fact .f-lbl{ font-family:var(--f-body); font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  font-size:.72rem; color:var(--pink); }
.fact .f-val{ font-family:var(--f-head); text-transform:uppercase; color:#fff; line-height:1;
  font-size:clamp(1.7rem,2.4vw,2.4rem); margin-top:.7rem; }
.fact .f-sub{ display:block; font-family:var(--f-body); font-weight:500; text-transform:none;
  letter-spacing:0; font-size:.92rem; color:var(--text-on-dark-mute); line-height:1.35; margin-top:.5rem; }
.fact .f-val.addr{ font-size:clamp(1.2rem,1.6vw,1.5rem); }

/* metodología grupos */
.age-pills{ display:flex; flex-wrap:wrap; gap:.6rem; margin:1.4rem 0; }
.age-pill{ font-family:var(--f-head); text-transform:uppercase; background:rgba(255,255,255,.08);
  color:#fff; border:1px solid rgba(255,255,255,.18); padding:.5em 1em; border-radius:999px; font-size:.95rem; letter-spacing:.03em; }
.theme-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; margin-top:1.6rem; }
.theme{ background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); border-radius:var(--r); padding:20px 22px; }
.theme .n{ font-family:var(--f-head); color:var(--pink); font-size:1.6rem; line-height:1; }
.theme .t{ font-family:var(--f-head); text-transform:uppercase; color:#fff; font-size:1.05rem; margin-top:.4rem; }

/* testimonios */
.tst-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.4rem; }
.tst{ background:#fff; border-radius:var(--r-lg); padding:30px 32px; box-shadow:var(--shadow-sm); position:relative; }
.tst .q{ font-family:var(--f-head); color:var(--pink); font-size:3rem; line-height:.5; height:1.2rem; }
.tst p{ font-style:italic; font-weight:300; color:var(--text-body); font-size:1.05rem; }
.tst .who{ display:flex; align-items:center; gap:.7rem; margin-top:1.2rem; }
.tst .av{ width:42px; height:42px; border-radius:50%; background:var(--navy); color:#fff; display:flex; align-items:center; justify-content:center; font-family:var(--f-head); font-size:1.05rem; flex:none; }
.tst .nm{ font-family:var(--f-head); text-transform:uppercase; color:var(--navy); font-size:.98rem; letter-spacing:.03em; line-height:1.1; }
.tst .rl{ color:var(--text-mute); font-size:.82rem; }

/* entrenadores */
.coach{ display:grid; grid-template-columns:300px 1fr; gap:0; background:var(--navy); border-radius:var(--r-lg); overflow:hidden; }
.coach.flip{ grid-template-columns:1fr 300px; }
.coach .ph{ border-radius:0; min-height:340px; }
.coach .c-body{ padding:clamp(26px,3vw,42px); align-self:center; }
.coach .c-body h3{ color:#fff; font-size:1.9rem; }
.coach .c-tag{ color:var(--pink); font-family:var(--f-body); font-weight:700; text-transform:uppercase; letter-spacing:.14em; font-size:.74rem; margin-bottom:.5rem; }
.coach .c-body p{ color:var(--text-on-dark); font-size:.98rem; }
.coach .ph img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:50% 28%; }

/* planes */
.plan-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; align-items:stretch; }
.plan{ background:#fff; border-radius:var(--r-lg); padding:28px 26px; box-shadow:var(--shadow-sm);
  border:1px solid rgba(20,27,77,.08); display:flex; flex-direction:column; transition:transform .2s ease, box-shadow .2s ease; }
.plan:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.plan.feat{ border-top:5px solid var(--pink); }
.plan .pname{ font-family:var(--f-head); text-transform:uppercase; color:var(--navy); font-size:1.35rem; line-height:1; }
.plan .pdesc{ color:var(--text-mute); font-size:.86rem; margin:.5rem 0 1rem; min-height:2.4em; }
.plan .price{ font-family:var(--f-head); color:var(--royal); font-size:2rem; font-weight:600; }
.plan .price small{ font-family:var(--f-body); font-size:.7rem; font-weight:600; color:var(--text-mute); display:block; letter-spacing:.1em; text-transform:uppercase; }
.plan .save{ display:inline-block; background:rgba(227,28,121,.12); color:var(--pink); font-family:var(--f-head);
  text-transform:uppercase; font-size:.8rem; padding:.3em .8em; border-radius:999px; margin-bottom:.8rem; align-self:flex-start; }
.plan .btn{ margin-top:auto; justify-content:center; }

/* FAQ */
.faq{ max-width:820px; margin-inline:auto; }
.faq-item{ border-bottom:1px solid rgba(20,27,77,.12); }
.faq-q{ width:100%; text-align:left; background:none; border:0; cursor:pointer; padding:1.4rem 3rem 1.4rem 0;
  font-family:var(--f-head); text-transform:uppercase; color:var(--navy); font-size:clamp(1.05rem,1.6vw,1.25rem);
  letter-spacing:.02em; position:relative; display:block; }
.faq-q::after{ content:"+"; position:absolute; right:.4rem; top:50%; transform:translateY(-50%); color:var(--pink);
  font-size:1.8rem; font-family:var(--f-head); transition:transform .25s ease; line-height:1; }
.faq-item.open .faq-q::after{ content:"–"; }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .4s ease; }
.faq-item.open .faq-a{ max-height:420px; }
.faq-a p{ padding:0 2rem 1.5rem 0; color:var(--text-body); margin:0; }

/* CTA band */
.cta-band{ position:relative; background:var(--navy); border-radius:var(--r-lg); overflow:hidden;
  padding:clamp(40px,6vw,72px); border-left:6px solid var(--pink);
  background-image:radial-gradient(80% 120% at 100% 0%, rgba(35,79,184,.35), transparent 60%); }
.cta-band > *{ position:relative; z-index:2; }

/* Footer */
.site-footer{ background:var(--navy-deep); color:var(--text-on-dark); }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:2.4rem; padding-block:64px 40px; }
.foot-grid h4{ color:#fff; font-size:1rem; letter-spacing:.08em; margin-bottom:1.1rem; }
.foot-links{ list-style:none; margin:0; padding:0; display:grid; gap:.6rem; }
.foot-links a{ color:var(--text-on-dark-mute); font-size:.92rem; }
.foot-links a:hover{ color:var(--pink); }
.foot-contact a{ color:#fff; display:block; margin-bottom:.5rem; font-size:.95rem; }
.foot-bottom{ border-top:1px solid rgba(255,255,255,.1); padding-block:22px; display:flex; flex-wrap:wrap; gap:.6rem 1.4rem; justify-content:space-between; font-size:.82rem; color:var(--text-on-dark-mute); }

/* section title block */
.sec-head{ max-width:640px; margin-bottom:clamp(2rem,4vw,3rem); }
.sec-head.center{ margin-inline:auto; text-align:center; }
.sec-head.center .kicker-row{ justify-content:center; }
.sec-head.center .kicker-row::before{ display:none; }
.sec-head h2{ margin-top:.7rem; }

/* ===== Responsive ===== */
@media (max-width:1020px){
  .facts{ grid-template-columns:repeat(2,1fr); gap:clamp(24px,4vw,38px) 0; }
  .fact:nth-child(odd){ border-left:0; padding-left:0; }
  .plan-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:760px){
  .benefits{ grid-template-columns:1fr; gap:2.4rem; }
  .bft{ border-left:0; padding-left:0; }
  .bft-line{ margin:1rem 0 .9rem; }
}
@media (max-width:860px){
  .nav-links, .nav .btn{ display:none; }
  .nav-toggle{ display:block; }
  .mobile-menu{ position:fixed; inset:0; background:var(--navy); z-index:60; transform:translateX(100%);
    transition:transform .3s ease; display:flex; flex-direction:column; padding:90px var(--gutter) 40px; gap:.4rem; }
  .mobile-menu.open{ transform:translateX(0); }
  .mobile-menu a{ font-family:var(--f-head); text-transform:uppercase; color:#fff; font-size:1.6rem; padding:.5rem 0; border-bottom:1px solid rgba(255,255,255,.1); }
  .mobile-menu .btn{ margin-top:1.4rem; }
  .m-close{ position:absolute; top:24px; right:var(--gutter); background:none; border:0; color:#fff; font-size:2rem; cursor:pointer; }
  .hero-photo{ inset:0; }
  .hero-photo::after{ background:linear-gradient(180deg, rgba(20,27,77,.6) 0%, rgba(20,27,77,.78) 55%, var(--navy) 100%); }
  .theme-grid{ grid-template-columns:1fr; }
  .coach, .coach.flip{ grid-template-columns:1fr; }
  .coach .ph{ min-height:240px; }
  .coach.flip .ph{ order:-1; }
  .tst-grid{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:2rem 1.4rem; }
}
@media (max-width:560px){
  .facts{ grid-template-columns:1fr; gap:1.8rem; }
  .fact{ border-left:0; padding-left:0; }
  .plan-grid{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr; }
}
