/* Racing San Luis — sistema de estilos compartido (v2) */
:root{
  --ink:#0a2240; --ink2:#103258; --paper:#ffffff; --bone:#f4f1ea;
  --line:#e5e1d8; --muted:#6a7585; --accent:#1aa3dd; --gold:#b98a32;
  --d:'Archivo',sans-serif; --s:'Inter',sans-serif; --e:'Anton',sans-serif;
  --mw:1240px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--s);color:var(--ink);background:var(--paper);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--mw);margin:0 auto;padding:0 28px}
.kick{font-family:var(--d);font-weight:600;text-transform:uppercase;letter-spacing:.24em;font-size:12px;color:var(--accent)}
.kick .n{display:none}
h2{font-family:var(--e);font-weight:400;text-transform:uppercase;letter-spacing:.01em;line-height:1.0;font-size:clamp(34px,5vw,64px)}
h3{font-family:var(--d);font-weight:700;text-transform:uppercase;letter-spacing:.01em}
.lead{font-size:clamp(18px,2vw,22px);line-height:1.6;color:#2b3744}
p.body{color:#41505f;font-size:17px}
.serif{font-family:var(--e)}
.rule{height:1px;background:var(--line);border:0}
.btn{font-family:var(--d);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:13px;padding:15px 28px;display:inline-block;transition:.2s;cursor:pointer;border:1.5px solid transparent}
.btn-fill{background:var(--accent);color:#06232f}.btn-fill:hover{background:#1488bd}
.btn-ink{background:var(--ink);color:#fff}.btn-ink:hover{background:var(--ink2)}
.btn-line-l{border-color:rgba(255,255,255,.5);color:#fff}.btn-line-l:hover{background:#fff;color:var(--ink)}
.btn-line-d{border-color:var(--ink);color:var(--ink)}.btn-line-d:hover{background:var(--ink);color:#fff}
section{position:relative}
.pad{padding:clamp(64px,9vw,128px) 0}
.sec-bone{background:var(--bone)}

/* TOPBAR + NAV */
.topbar{background:var(--ink);color:#8fa0b3;font-family:var(--d);text-transform:uppercase;letter-spacing:.18em;font-size:10.5px}
.topbar .wrap{display:flex;justify-content:space-between;padding-top:9px;padding-bottom:9px}
header{position:absolute;top:34px;left:0;right:0;z-index:40}
header.stuck{position:fixed;top:0;background:var(--ink);box-shadow:0 1px 0 rgba(255,255,255,.08)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{display:flex;align-items:center;gap:13px}
.brand img{height:48px;width:auto;background:#fff;border-radius:10px;padding:5px}
.brand .wm{font-family:var(--d);font-weight:800;text-transform:uppercase;letter-spacing:.02em;font-size:18px;color:#fff;line-height:1}
.brand .wm small{display:block;font-weight:500;letter-spacing:.16em;font-size:9.5px;color:#8fa0b3;margin-top:3px}
.links{display:flex;align-items:center;gap:26px}
.links a{font-family:var(--d);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:12.5px;color:#dfe6ee}
.links a:hover{color:#fff}
.links a.active{color:#fff;box-shadow:inset 0 -2px 0 var(--accent)}
.links .socio{border:1.5px solid rgba(255,255,255,.45);padding:11px 20px;box-shadow:none}
.links .socio:hover{background:#fff;color:var(--ink)}
.burger{display:none;background:none;border:0;color:#fff;cursor:pointer;width:30px;height:22px;position:relative}
.burger span{position:absolute;left:0;right:0;height:2px;background:#fff;transition:.25s}
.burger span:nth-child(1){top:0}.burger span:nth-child(2){top:10px}.burger span:nth-child(3){top:20px}

/* HERO (home) */
.hero{min-height:100vh;display:flex;align-items:flex-end;color:#fff;position:relative;background:var(--ink)}
.hero .bg{position:absolute;inset:0;overflow:hidden}
.hero .bg img{width:100%;height:100%;object-fit:cover;object-position:center 28%;filter:brightness(.6) contrast(1.08) saturate(1.14)}
.hero .bg:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,12,19,.62) 0%,rgba(7,12,19,.42) 30%,rgba(7,12,19,.74) 66%,rgba(7,12,19,.97) 100%)}
.hero .bg:before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(7,12,19,.88) 0%,rgba(7,12,19,.4) 44%,transparent 72%)}
.hero .kick,.subhero .kick{color:#aadef5}
.hero-in{position:relative;z-index:2;width:100%;padding-bottom:clamp(40px,6vw,80px);padding-top:160px}
.hero h1{font-family:var(--e);font-weight:400;text-transform:uppercase;line-height:.9;letter-spacing:.005em;font-size:clamp(62px,12vw,164px)}
.hero h1 .e{font-family:var(--e);font-style:normal;text-transform:uppercase;letter-spacing:.005em;color:#43c0f2}
.hero p{max-width:520px;font-size:clamp(16px,1.6vw,19px);color:#d6dde6;margin:26px 0 32px}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap}
.hero .scroll{position:absolute;right:28px;bottom:34px;z-index:2;writing-mode:vertical-rl;font-family:var(--d);text-transform:uppercase;letter-spacing:.22em;font-size:11px;color:#9aa7b6}
.creds{border-top:1px solid rgba(255,255,255,.16);margin-top:clamp(40px,6vw,72px);display:grid;grid-template-columns:repeat(4,1fr)}
.creds div{padding:22px 22px 4px 0}
.creds b{font-family:var(--e);font-weight:500;font-size:clamp(34px,4vw,52px);line-height:1;display:block}
.creds span{font-family:var(--d);text-transform:uppercase;letter-spacing:.14em;font-size:10.5px;color:#9aa7b6;display:block;margin-top:10px}
.creds div+div{border-left:1px solid rgba(255,255,255,.16);padding-left:22px}

/* SUBHERO (paginas internas) */
.subhero{min-height:60vh;display:flex;align-items:flex-end;color:#fff;position:relative;background:var(--ink)}
.subhero .bg{position:absolute;inset:0;overflow:hidden}
.subhero .bg img{width:100%;height:100%;object-fit:cover;object-position:center 32%;filter:brightness(.48) contrast(1.06)}
.subhero .bg:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,12,19,.64) 0%,rgba(7,12,19,.52) 38%,rgba(7,12,19,.95) 100%)}
.subhero-in{position:relative;z-index:2;width:100%;padding-top:150px;padding-bottom:clamp(34px,5vw,60px)}
.subhero h1{font-family:var(--e);font-weight:400;text-transform:uppercase;line-height:.94;letter-spacing:.005em;font-size:clamp(48px,8vw,104px);margin-top:14px}
.crumb{font-family:var(--d);text-transform:uppercase;letter-spacing:.16em;font-size:11px;color:#9aa7b6}
.crumb a:hover{color:#fff}

/* HERITAGE */
.heritage{background:var(--ink);color:#eef1f5;overflow:hidden}
.heritage .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,70px);align-items:center}
.bigyear{font-family:var(--e);font-weight:500;font-size:clamp(120px,21vw,300px);line-height:.8;letter-spacing:-.03em;background:linear-gradient(180deg,#e6f5fd 0%,#3f9fcf 130%);-webkit-background-clip:text;background-clip:text;color:transparent}
.heritage .quote{font-family:var(--s);font-style:italic;font-weight:500;font-size:clamp(19px,2.2vw,27px);line-height:1.5;color:#dfe5ec;margin:18px 0 0;max-width:520px}
.heritage .photo{aspect-ratio:4/5;overflow:hidden}
.heritage .photo img,.duo{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.08) brightness(.95)}
.heritage .cap,.cap{font-family:var(--d);text-transform:uppercase;letter-spacing:.18em;font-size:10px;color:#8fa0b3;margin-top:12px}

/* SPLIT editorial */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,72px);align-items:center}
.split.rev .txt{order:2}
.split .ph{position:relative}
.split .ph img{width:100%;aspect-ratio:5/6;object-fit:cover}
.split .ph .tag{position:absolute;left:0;bottom:0;background:var(--ink);color:#fff;font-family:var(--d);text-transform:uppercase;letter-spacing:.14em;font-size:10.5px;padding:11px 18px}
.txt h2{margin:14px 0 18px}
.txt .kick{display:block;margin-bottom:0}
ul.clean{list-style:none;margin:24px 0 0}
ul.clean li{padding:14px 0;border-top:1px solid var(--line);display:flex;gap:16px;align-items:baseline;font-size:16px;color:#3a4858}
ul.clean li .ix{font-family:var(--e);font-style:italic;color:var(--accent);font-size:18px;min-width:26px}

/* PROSE */
.prose{max-width:760px}
.prose p{color:#41505f;font-size:17px;margin-bottom:20px}
.prose h3{font-size:21px;margin:34px 0 12px}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.chip{border:1px solid var(--line);padding:7px 13px;font-size:12.5px;font-family:var(--d);text-transform:uppercase;letter-spacing:.04em;color:#3a4858}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:18px}
.card{display:block;background:var(--paper);border:1px solid var(--line);padding:22px;transition:transform .2s,border-color .2s}
a.card{color:inherit}
a.card:hover{border-color:var(--accent);transform:translateY(-3px)}
.sec-bone .card{background:#fff}
.news-home{display:grid;grid-template-columns:1.5fr 1fr;gap:26px;align-items:stretch}
.news-feat{position:relative;display:block;overflow:hidden;min-height:440px;color:#fff}
.news-feat>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s}
.news-feat:hover>img{transform:scale(1.05)}
.news-feat:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,16,26,0) 30%,rgba(8,16,26,.9) 100%)}
.news-feat .ov{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:32px}
.tag{display:inline-block;background:var(--accent);color:#06232f;font-family:var(--d);text-transform:uppercase;letter-spacing:.08em;font-size:10.5px;font-weight:600;padding:5px 11px}
.news-feat h3{font-family:var(--e);text-transform:uppercase;font-size:clamp(24px,2.8vw,38px);line-height:1.0;color:#fff;margin-top:14px}
.news-feat .date{font-family:var(--d);text-transform:uppercase;letter-spacing:.1em;font-size:10.5px;color:#cfe0ef;margin-top:12px}
.news-list{display:flex;flex-direction:column}
.news-item{display:flex;gap:16px;padding:18px 0;border-top:1px solid var(--line);align-items:flex-start;color:inherit}
.news-item:first-child{border-top:0;padding-top:0}
.news-item .th{width:108px;height:76px;flex:0 0 auto;overflow:hidden;background:var(--bone)}
.news-item .th img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.news-item:hover .th img{transform:scale(1.07)}
.news-item .meta{font-family:var(--d);text-transform:uppercase;letter-spacing:.08em;font-size:10px;color:var(--accent)}
.news-item h4{font-size:16px;margin-top:5px;line-height:1.22}
.news-item:hover h4{color:var(--accent)}

/* TIMELINE */
.timeline{border-left:2px solid var(--line);margin-top:34px;max-width:720px}
.tl{position:relative;padding:0 0 36px 34px}
.tl:before{content:"";position:absolute;left:-7px;top:5px;width:12px;height:12px;border-radius:50%;background:var(--accent)}
.tl .yr{font-family:var(--e);font-style:italic;color:var(--accent);font-size:23px}
.tl h4{font-family:var(--d);text-transform:uppercase;font-size:15px;margin:3px 0 6px}
.tl p{color:#41505f;font-size:15px}

/* INFOCARDS (mision/vision/valores, dirigencia) */
.infocards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.icard{border-top:2px solid var(--ink);padding-top:18px}
.icard .ix{font-family:var(--e);font-style:italic;color:var(--accent);font-size:20px}
.icard h3{font-size:17px;margin:8px 0}
.icard p{color:#41505f;font-size:15px}

/* PLANTEL / staff */
.plantel{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.player .pf{aspect-ratio:3/4;overflow:hidden;background:var(--bone);display:flex;align-items:center;justify-content:center}
.player .pf img{width:100%;height:100%;object-fit:cover;filter:grayscale(1);transition:.35s}
.player:hover .pf img{filter:none}
.player .pf .init{font-family:var(--e);font-style:italic;font-size:40px;color:#b9b3a4}
.player h4{font-family:var(--d);text-transform:uppercase;font-size:14px;margin-top:13px;letter-spacing:.02em}
.player span{color:var(--muted);font-size:13px}

/* PRIMER EQUIPO record/palmares */
.equipo-dark{background:var(--ink);color:#fff}
.palmares{list-style:none;margin:6px 0 0}
.palmares li{display:flex;gap:18px;align-items:baseline;padding:16px 0;border-top:1px solid rgba(255,255,255,.14);color:#cdd6e0;font-size:16px}
.palmares li .yr{font-family:var(--e);font-style:italic;color:#9fc2ff;font-size:17px;min-width:54px}
.record{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.14);margin-top:30px;border:1px solid rgba(255,255,255,.14)}
.record div{background:var(--ink);padding:20px}
.record span{font-family:var(--d);text-transform:uppercase;letter-spacing:.14em;font-size:10px;color:#8fa0b3}
.record b{font-family:var(--e);font-weight:500;font-size:26px;display:block;margin-top:6px}
.exnote{font-size:12px;color:#8fa0b3;margin-top:14px;font-style:italic}

/* CATEGORIAS (cantera) */
.cats{border-top:2px solid var(--ink)}
.cat{display:grid;grid-template-columns:.5fr 1.1fr 1.4fr;gap:24px;align-items:center;padding:24px 14px;border-bottom:1px solid var(--line)}
.cat .age{font-family:var(--e);font-style:italic;font-size:24px;color:var(--ink)}
.cat h4{font-family:var(--d);text-transform:uppercase;font-size:17px}
.cat p{color:var(--muted);font-size:14px}

/* SEDES */
.sedes{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.sede{border:1px solid var(--line);padding:26px}
.sede h4{font-family:var(--d);text-transform:uppercase;font-size:16px;margin-bottom:8px}
.sede p{color:var(--muted);font-size:14.5px;line-height:1.7}

/* GALLERY MOSAIC */
.mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:10px}
.mosaic a{overflow:hidden;display:block}
.mosaic img{width:100%;height:100%;object-fit:cover;transition:.5s}
.mosaic a:hover img{transform:scale(1.05)}
.mosaic .w2{grid-column:span 2}.mosaic .h2{grid-row:span 2}

/* SOCIOS membership */
.socios{background:var(--bone)}
.socios .head{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end;margin-bottom:46px}
.purpose{font-family:var(--e);font-size:clamp(19px,2.2vw,26px);line-height:1.45;color:#2b3744}
.mtable{border-top:2px solid var(--ink)}
.mrow{display:grid;grid-template-columns:1.1fr 1.4fr 2.2fr .8fr;gap:24px;align-items:center;padding:26px 18px;border-bottom:1px solid var(--line);transition:.2s}
.mrow:hover{background:#fff}
.mrow.feat{background:#fff;box-shadow:inset 3px 0 0 var(--accent)}
.mrow .tname{font-family:var(--d);font-weight:700;text-transform:uppercase;letter-spacing:.02em;font-size:18px}
.mrow .feat-tag{font-family:var(--d);font-size:9.5px;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);display:block;margin-top:4px}
.mrow .who{color:var(--muted);font-size:14.5px}
.mrow .gives{font-size:14px;color:#3a4858}
.mrow .price{font-family:var(--e);font-weight:500;font-size:22px;text-align:right}
.mrow .price small{font-family:var(--s);font-size:12px;color:var(--muted);display:block;font-weight:400}
.socios .foot{display:flex;justify-content:space-between;align-items:center;margin-top:34px;flex-wrap:wrap;gap:18px}
.socios .foot p{font-size:13px;color:var(--muted);font-style:italic}

/* STEPS numerados */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:10px}
.step .sn{font-family:var(--e);font-style:italic;font-size:34px;color:var(--accent)}
.step h4{font-family:var(--d);text-transform:uppercase;font-size:16px;margin:8px 0 6px}
.step p{color:#41505f;font-size:15px}

/* BENEFITS editorial list */
.benefits{display:grid;grid-template-columns:repeat(2,1fr);gap:0 40px;border-top:1px solid var(--line)}
.benefit{display:flex;gap:16px;align-items:baseline;padding:18px 0;border-bottom:1px solid var(--line)}
.benefit .ix{font-family:var(--e);font-style:italic;color:var(--accent);font-size:18px;min-width:26px}
.benefit b{font-family:var(--s);font-weight:600}
.benefit span{color:#41505f;font-size:15px}

/* IMPACTO */
.impacto .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:34px}
.imp .im{aspect-ratio:3/2;overflow:hidden;margin-bottom:20px}
.imp .im img{width:100%;height:100%;object-fit:cover}
.imp .ix{font-family:var(--e);font-style:italic;color:var(--accent);font-size:20px}
.imp h3{font-size:19px;margin:10px 0 8px}
.imp p{color:#41505f;font-size:15px}

/* FORM */
.form{display:grid;gap:18px;max-width:580px}
.form label{font-family:var(--d);text-transform:uppercase;letter-spacing:.1em;font-size:11px;color:var(--muted);display:block;margin-bottom:8px}
.form input,.form select,.form textarea{width:100%;padding:13px 15px;border:1px solid var(--line);background:#fff;font-family:var(--s);font-size:15px;color:var(--ink);border-radius:0}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--accent)}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form textarea{min-height:140px;resize:vertical}

/* FAQ */
.faq{max-width:780px;border-top:1px solid var(--line)}
.qa{border-bottom:1px solid var(--line);padding:24px 0}
.qa h4{font-family:var(--d);text-transform:uppercase;font-size:15px;margin-bottom:8px}
.qa p{color:#41505f;font-size:15px}

/* LOGIN (acceso socios) */
.login{max-width:430px;margin:0 auto;border:1px solid var(--line);padding:40px 36px;text-align:center;background:#fff}
.login .note{font-size:13px;color:var(--muted);margin-top:18px;line-height:1.6}

/* CTA BAND */
.cta-band{background:var(--ink);color:#fff;text-align:center}
.cta-band h2{margin-bottom:22px}

/* SPONSORS */
.sponsors{background:var(--ink);color:#fff;text-align:center}
.logogrid{display:grid;grid-template-columns:repeat(6,1fr);gap:20px;margin-top:46px}
.logogrid .lg{height:84px;display:flex;align-items:center;justify-content:center;padding:14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08)}
.logogrid img{max-height:100%;max-width:100%;object-fit:contain;filter:grayscale(1) brightness(0) invert(1);opacity:.55;transition:.25s}
.logogrid .lg:hover img{filter:none;opacity:1}

/* FOOTER */
footer{background:#070d15;color:#9fadbd;padding:72px 0 28px}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px}
footer .brand img{height:54px}
footer h4{font-family:var(--d);text-transform:uppercase;letter-spacing:.14em;font-size:12px;color:#fff;margin-bottom:16px}
footer a{display:block;padding:6px 0;font-size:14px}
footer a:hover{color:#fff}
.fcontact{font-size:14px;line-height:2}
.fbar{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;border-top:1px solid rgba(255,255,255,.1);margin-top:48px;padding-top:22px;font-family:var(--d);text-transform:uppercase;letter-spacing:.1em;font-size:10.5px;color:#67768a}

@media(max-width:900px){
  .links{position:fixed;inset:0 0 0 auto;width:78%;max-width:340px;background:var(--ink);flex-direction:column;align-items:flex-start;justify-content:center;gap:8px;padding:40px;transform:translateX(100%);transition:.3s;z-index:39}
  .links.open{transform:none}
  .links a{font-size:18px;padding:12px 0}
  .links a.active{box-shadow:none;color:#9fc2ff}
  .burger{display:block;z-index:41}
  .hero h1{font-size:clamp(46px,15vw,84px)}
  .heritage .wrap,.split,.equipo .grid,.socios .head,.impacto .grid,.fgrid,.infocards,.benefits,.steps,.sedes,.news-home{grid-template-columns:1fr;gap:30px}
  .news-feat{min-height:300px}
  .split.rev .txt{order:0}
  .creds{grid-template-columns:1fr 1fr}.creds div:nth-child(odd){border-left:0;padding-left:0}
  .record,.plantel{grid-template-columns:1fr 1fr}
  .mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}
  .logogrid{grid-template-columns:repeat(3,1fr)}
  .mrow{grid-template-columns:1fr;gap:6px}.mrow .price{text-align:left}
  .cat{grid-template-columns:1fr;gap:6px}
  .bigyear{font-size:clamp(110px,40vw,220px)}
  .form .row2{grid-template-columns:1fr}
}
