/* ==========================================================
   CDDE — Club Deportivo Distrito Elite
   Sistema visual: editorial deportivo, asimétrico, denso.
   ========================================================== */

:root{
  --navy:#0A1F3D;
  --navy-2:#0d2747;
  --royal:#1E4A8C;
  --crimson:#C8102E;
  --gold:#D4AF37;
  --gold-soft:#E8C968;
  --bone:#F5F3EE;
  --bone-2:#EAE6DC;
  --ink:#0a0f1c;
  --line:rgba(245,243,238,.14);
  --line-dark:rgba(10,31,61,.12);
  --crest-bg:#0A1F3D;

  --f-display:'Fraunces', Georgia, serif;
  --f-sans:'Archivo', 'Helvetica Neue', Arial, sans-serif;
  --f-mono:'JetBrains Mono', ui-monospace, monospace;

  --max:1440px;
  --pad:clamp(20px, 4vw, 64px);

  --ease:cubic-bezier(.65,0,.05,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--navy);color:var(--bone);font-family:var(--f-sans);-webkit-font-smoothing:antialiased}
html{scroll-behavior:auto}
body{overflow-x:hidden;min-height:100vh;line-height:1.45}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;background:none;border:0;color:inherit;cursor:pointer}
::selection{background:var(--gold);color:var(--navy)}

/* Tipografía base */
h1,h2,h3{font-family:var(--f-display);font-weight:600;letter-spacing:-.02em;line-height:.95}
em{font-style:italic;font-family:var(--f-display);color:var(--gold)}
.muted{color:rgba(245,243,238,.5)}
.eyebrow{font:600 11px/1 var(--f-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}

/* ==================== LOADER ==================== */
.loader{
  position:fixed;inset:0;z-index:200;background:var(--navy);
  display:grid;place-items:center;
  transition:transform 1s var(--ease), opacity .4s ease;
}
.loader__grid{
  position:absolute;inset:0;display:grid;
  grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,1fr);
}
.loader__grid span{background:var(--navy);border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.loader__meta{position:absolute;top:24px;left:24px;right:24px;display:flex;justify-content:space-between;font:600 11px/1 var(--f-mono);letter-spacing:.2em;color:var(--gold)}
.loader__word{
  position:relative;display:flex;gap:.04em;font-family:var(--f-display);
  font-weight:900;font-size:clamp(48px,11vw,180px);letter-spacing:-.03em;
  color:var(--bone);
}
.loader__word span{display:inline-block;transform:translateY(110%)}
.loader__word .sep{color:var(--gold);padding:0 .2em}
body:not(.is-loading) .loader{transform:translateY(-100%)}
body:not(.is-loading) .loader__grid span{opacity:0;transition:opacity .3s ease}

/* ==================== CANVAS ==================== */
#fx{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.55}

/* ==================== NAV ==================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;
  gap:24px;padding:18px var(--pad);
  background:linear-gradient(to bottom, rgba(10,31,61,.85), rgba(10,31,61,0));
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid transparent;
  transition:background .4s ease, border-color .4s ease;
}
.nav.is-stuck{background:rgba(10,31,61,.92);border-bottom-color:var(--line)}

.nav__brand{display:flex;align-items:center;gap:12px}
.nav__crest{width:28px;height:34px}
.nav__name{font:800 13px/1.05 var(--f-sans);letter-spacing:.02em;text-transform:uppercase}
.nav__name em{display:block;font:400 10px/1 var(--f-mono);letter-spacing:.2em;color:var(--gold);margin-top:4px;font-style:normal}

.nav__links{display:flex;gap:28px;justify-self:center}
.nav__links a{position:relative;font:600 12px/1 var(--f-mono);letter-spacing:.12em;text-transform:uppercase;padding:6px 0;opacity:.75;transition:opacity .3s}
.nav__links a i{font-style:normal;font-weight:400;color:var(--gold);margin-right:6px;opacity:.6}
.nav__links a:hover{opacity:1}
.nav__links a::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.nav__links a:hover::after{transform:scaleX(1)}

.nav__cta{
  display:inline-flex;align-items:center;gap:10px;padding:10px 18px;
  border:1px solid var(--gold);color:var(--gold);
  font:700 11px/1 var(--f-mono);letter-spacing:.18em;text-transform:uppercase;
  border-radius:999px;transition:background .3s, color .3s, gap .3s;
}
.nav__cta svg{width:16px;height:16px}
.nav__cta:hover{background:var(--gold);color:var(--navy);gap:14px}
.nav__burger{display:none;width:40px;height:40px;position:relative}
.nav__burger span{position:absolute;left:8px;right:8px;height:1.5px;background:var(--bone)}
.nav__burger span:nth-child(1){top:15px}
.nav__burger span:nth-child(2){bottom:15px}

/* ==================== RAIL LATERAL ==================== */
.rail{
  position:fixed;right:18px;top:50%;transform:translateY(-50%);z-index:40;
  display:flex;flex-direction:column;align-items:center;gap:18px;
  font:600 10px/1 var(--f-mono);letter-spacing:.2em;text-transform:uppercase;
  color:rgba(245,243,238,.55);
}
.rail__section{writing-mode:vertical-rl;transform:rotate(180deg);color:var(--gold)}
.rail__progress{position:relative;width:1px;height:120px;background:var(--line)}
.rail__progress i{position:absolute;top:0;left:-2px;width:5px;height:0;background:var(--gold);transition:height .2s linear}
.rail a{writing-mode:vertical-rl;transform:rotate(180deg);transition:color .3s}
.rail a:hover{color:var(--gold)}

/* ==================== HERO ==================== */
section{position:relative;z-index:2}
.hero{
  min-height:100vh;padding:140px var(--pad) 40px;
  display:grid;grid-template-columns:1fr auto;grid-template-rows:auto 1fr auto auto;
  gap:40px;overflow:hidden;
}
.hero__bg{position:absolute;inset:0;z-index:-1;pointer-events:none}
.hero__lines{position:absolute;inset:0;display:grid;grid-template-columns:repeat(6,1fr)}
.hero__lines i{border-right:1px solid var(--line)}
.hero__lines i:last-child{border-right:0}
.hero__halo{
  position:absolute;top:40%;left:60%;width:80vmin;height:80vmin;
  background:radial-gradient(circle, rgba(212,175,55,.18), transparent 60%);
  transform:translate(-50%,-50%);filter:blur(20px);
}

.hero__meta{grid-column:1/-1;display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.chip{
  display:inline-flex;align-items:center;gap:10px;padding:8px 14px;
  border:1px solid var(--line);border-radius:999px;
  font:600 11px/1 var(--f-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--bone);
  background:rgba(245,243,238,.03);
}
.chip i{width:7px;height:7px;border-radius:50%;background:var(--crimson);box-shadow:0 0 10px var(--crimson);animation:pulse 1.8s ease-in-out infinite}
.chip--ghost{background:transparent;color:var(--gold);border-color:var(--gold)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

.hero__title{
  grid-column:1/2;align-self:center;
  font-family:var(--f-display);font-weight:900;
  font-size:clamp(56px, 12vw, 220px);line-height:.86;letter-spacing:-.04em;
  text-transform:lowercase;
}
.hero__title .word{display:inline-block;overflow:hidden;vertical-align:bottom;padding:0 .04em}
.hero__title .word[data-split]>*{display:inline-block}
.hero__title .word em{font-family:var(--f-display);color:var(--gold);font-style:italic}
.hero__title .word--ital{font-style:italic;font-weight:300}
.hero__title .word--accent{color:var(--gold)}

.hero__crest{
  grid-column:2/3;grid-row:2/3;position:relative;
  width:clamp(180px,22vw,320px);aspect-ratio:200/240;
  align-self:center;justify-self:end;
}
.crest{width:100%;height:100%;filter:drop-shadow(0 20px 60px rgba(212,175,55,.25))}
.crest__ring{
  position:absolute;inset:-18%;border:1px solid var(--line);border-radius:50%;
  animation:spin 30s linear infinite;
}
.crest__ring::before{
  content:"· DISTRITO ELITE · CLUB DEPORTIVO · KENNEDY ·";
  position:absolute;top:-9px;left:50%;transform:translateX(-50%);
  background:var(--navy);padding:0 10px;font:600 10px/1 var(--f-mono);letter-spacing:.22em;color:var(--gold);
}
.crest__ring--2{inset:-32%;border-style:dashed;animation-duration:60s;animation-direction:reverse;opacity:.4}
@keyframes spin{to{transform:rotate(360deg)}}

.hero__footer{
  grid-column:1/-1;display:flex;align-items:flex-end;gap:48px;flex-wrap:wrap;
  padding-top:32px;border-top:1px solid var(--line);
}
.hero__stat{display:flex;align-items:baseline;gap:14px}
.hero__stat b{
  font-family:var(--f-display);font-weight:900;font-size:clamp(40px,5vw,72px);line-height:1;
  color:var(--bone);letter-spacing:-.03em;
}
.hero__stat b em{color:var(--gold);font-weight:400}
.hero__stat span{font:600 11px/1.3 var(--f-mono);letter-spacing:.15em;text-transform:uppercase;color:rgba(245,243,238,.6)}
.hero__scroll{margin-left:auto;display:flex;align-items:center;gap:14px;font:600 11px/1 var(--f-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}
.hero__scroll svg{width:14px;height:34px;animation:bob 2s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}

/* ==================== MARQUEE ==================== */
.marquee{
  grid-column:1/-1;margin:0 calc(var(--pad) * -1);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;padding:18px 0;
}
.marquee__track{
  display:flex;gap:36px;white-space:nowrap;
  animation:slide 40s linear infinite;
  font-family:var(--f-display);font-size:clamp(18px,2vw,28px);letter-spacing:-.01em;
}
.marquee__track span{flex-shrink:0}
.marquee__track i{color:var(--gold);font-style:normal;flex-shrink:0}
@keyframes slide{to{transform:translateX(-50%)}}

/* ==================== CHAP / SECTION HEADERS ==================== */
.chap{
  display:flex;align-items:center;gap:18px;padding:120px 0 32px;
  font:600 11px/1 var(--f-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--gold);
}
.chap span{font-family:var(--f-display);font-weight:900;font-size:72px;line-height:.9;color:var(--bone);letter-spacing:-.03em}
.chap em{color:rgba(245,243,238,.55);font-style:normal;font-family:var(--f-mono)}
.chap--light{color:var(--crimson)}
.chap--light span{color:var(--navy)}
.chap--light em{color:rgba(10,31,61,.6)}

.section-title{
  font-size:clamp(40px,7vw,112px);padding-bottom:64px;max-width:1100px;
  font-weight:900;
}

/* ==================== MANIFIESTO ==================== */
.manifiesto{padding:0 var(--pad) 140px}
.manifiesto__grid{display:grid;grid-template-columns:1.2fr .8fr;gap:80px;align-items:start}
.manifiesto__text{
  font-family:var(--f-display);font-weight:300;
  font-size:clamp(26px,3.6vw,56px);line-height:1.12;letter-spacing:-.02em;
}
.manifiesto__text span{display:block;overflow:hidden}
.manifiesto__text b{font-weight:900;color:var(--gold);font-style:normal}
.manifiesto__text em{color:var(--crimson)}

.manifiesto__aside{display:flex;flex-direction:column;gap:40px;position:sticky;top:120px}
.quote{padding:32px;border:1px solid var(--line);background:rgba(245,243,238,.02);position:relative}
.quote__mark{position:absolute;top:-20px;left:20px;font-family:var(--f-display);font-size:120px;line-height:.6;color:var(--gold)}
.quote p{font-family:var(--f-display);font-style:italic;font-size:22px;line-height:1.35;margin-bottom:16px}
.quote footer{font:600 11px/1 var(--f-mono);letter-spacing:.18em;text-transform:uppercase;color:rgba(245,243,238,.5)}
.stamp{width:160px;align-self:center;color:var(--gold);opacity:.8;animation:spin 40s linear infinite}
.stamp text{font:600 8px/1 var(--f-mono);letter-spacing:.25em;fill:currentColor}
.stamp__star{font-size:18px}

/* ==================== BIG NUM ==================== */
.bignum{
  display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:center;
  padding:80px var(--pad);border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:linear-gradient(180deg, transparent, rgba(212,175,55,.04), transparent);
}
.bignum__digit{
  font-family:var(--f-display);font-weight:900;
  font-size:clamp(180px,22vw,380px);line-height:.8;letter-spacing:-.06em;
  color:transparent;-webkit-text-stroke:1px var(--gold);
}
.bignum__body{max-width:820px}
.bignum__body h2{font-size:clamp(30px,3.6vw,56px);margin:16px 0 20px}
.bignum__body p{font-size:18px;line-height:1.55;color:rgba(245,243,238,.75);max-width:640px}
.bignum__body b{color:var(--gold);font-weight:700}

/* ==================== IDENTIDAD ==================== */
.identidad{padding:0 var(--pad) 140px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{
  position:relative;padding:36px 28px;border:1px solid var(--line);
  min-height:520px;display:flex;flex-direction:column;gap:28px;
  background:linear-gradient(180deg, rgba(245,243,238,.03), transparent);
  overflow:hidden;isolation:isolate;
  transition:transform .6s var(--ease), border-color .4s;
}
.card::before{
  content:"";position:absolute;inset:0;background:var(--gold);
  transform:translateY(101%);transition:transform .7s var(--ease);z-index:-1;
}
.card:hover{transform:translateY(-6px);border-color:var(--gold)}
.card:hover::before{transform:translateY(0)}
.card:hover,.card:hover h3,.card:hover h3 em,.card:hover li,.card:hover footer span{color:var(--navy)}
.card:hover .card__idx,.card:hover .card__tag,.card:hover .card__count,.card:hover .card__count em{color:var(--navy)}
.card:hover .card__tag{border-color:var(--navy)}

.card header{display:flex;justify-content:space-between;align-items:center;font:600 10px/1 var(--f-mono);letter-spacing:.2em;text-transform:uppercase}
.card__idx{color:var(--gold)}
.card__tag{padding:6px 10px;border:1px solid var(--line);border-radius:999px;color:rgba(245,243,238,.7)}
.card h3{font-size:clamp(36px,4vw,56px);line-height:.9}
.card h3 em{color:var(--gold);font-weight:300}
.card ul{list-style:none;border-top:1px solid var(--line);padding-top:20px;display:flex;flex-direction:column;gap:12px;margin-top:auto}
.card li{font:600 13px/1 var(--f-mono);letter-spacing:.05em;color:rgba(245,243,238,.8);padding-left:18px;position:relative}
.card li::before{content:"";position:absolute;left:0;top:5px;width:8px;height:2px;background:var(--gold)}
.card footer{display:flex;align-items:baseline;gap:16px;padding-top:24px;border-top:1px solid var(--line)}
.card__count{font-family:var(--f-display);font-weight:900;font-size:72px;line-height:1;letter-spacing:-.03em}
.card__count em{color:var(--gold);font-weight:400;font-size:.6em}
.card footer span{font:600 10px/1.3 var(--f-mono);letter-spacing:.15em;text-transform:uppercase;color:rgba(245,243,238,.55)}
.card__glow{position:absolute;top:-40%;right:-20%;width:60%;height:60%;background:radial-gradient(circle,var(--gold),transparent 70%);opacity:.08;filter:blur(20px);pointer-events:none}

.card--masc .card__glow{background:radial-gradient(circle,var(--royal),transparent 70%);opacity:.18}
.card--fem{background:linear-gradient(180deg, rgba(200,16,46,.08), transparent)}
.card--fem .card__glow{background:radial-gradient(circle,var(--crimson),transparent 70%);opacity:.2}

/* ==================== PACHUCA ==================== */
.pachuca{
  background:var(--bone);color:var(--navy);padding:0 var(--pad) 140px;
  position:relative;overflow:hidden;
}
.pachuca::before{
  content:"";position:absolute;inset:0;opacity:.04;pointer-events:none;
  background-image:radial-gradient(var(--navy) 1px, transparent 1px);
  background-size:22px 22px;
}
.pachuca__hero{
  display:grid;grid-template-columns:1.3fr .7fr;grid-template-rows:auto auto;
  gap:60px 80px;align-items:start;
}
.pachuca__mask{grid-column:1/2}
.pachuca__mask h2{
  font-size:clamp(44px,8vw,132px);line-height:.92;font-weight:900;
}
.pachuca__mask h2 span{display:block;overflow:hidden}
.pachuca__mask h2 em{color:var(--crimson);font-style:italic}
.pachuca__mask p{margin-top:32px;font-size:20px;line-height:1.5;max-width:680px;color:rgba(10,31,61,.8)}
.pachuca__mask p b{color:var(--navy);background:var(--gold);padding:0 6px}

.pachuca__list{
  grid-column:1/2;list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:0;
  border-top:1px solid var(--line-dark);
}
.pachuca__list li{
  display:flex;gap:20px;padding:28px 24px 28px 0;
  border-bottom:1px solid var(--line-dark);
  align-items:flex-start;
}
.pachuca__list li:nth-child(odd){border-right:1px solid var(--line-dark);padding-right:32px}
.pachuca__list li:nth-child(even){padding-left:32px}
.pachuca__list b{font-family:var(--f-display);font-size:48px;line-height:.9;color:var(--crimson);font-weight:900}
.pachuca__list span{font-size:17px;line-height:1.35;color:var(--navy)}

.pachuca__seal{grid-column:2/3;grid-row:1/3;display:grid;place-items:center;align-self:center}
.seal{width:min(100%,380px);aspect-ratio:1;color:var(--crimson);animation:spin 40s linear infinite}
.seal text{font:600 10px/1 var(--f-mono);letter-spacing:.25em;fill:currentColor}
.seal__title{font-family:var(--f-display);font-weight:900;font-size:42px;fill:var(--navy);letter-spacing:-.03em}
.seal__sub{font-size:9px;letter-spacing:.3em;fill:var(--navy)}

/* ==================== STATS ==================== */
.stats{padding:80px var(--pad);border-bottom:1px solid var(--line)}
.stats__row{display:grid;grid-template-columns:repeat(4,1fr);gap:40px}
.stats__cell{display:flex;flex-direction:column;gap:12px;padding-left:20px;border-left:1px solid var(--line);position:relative}
.stats__cell::before{content:"";position:absolute;left:-1px;top:0;width:1px;height:20%;background:var(--gold)}
.stats__cell b{font-family:var(--f-display);font-weight:900;font-size:clamp(60px,7vw,108px);line-height:.9;letter-spacing:-.03em;display:inline-flex;align-items:baseline}
.stats__cell em{color:var(--gold);font-weight:400;font-size:.5em;margin-left:4px}

/* ==================== METODO ==================== */
.metodo{padding:0 var(--pad) 140px}
.timeline{list-style:none;counter-reset:t;display:flex;flex-direction:column}
.timeline li{
  display:grid;grid-template-columns:120px 1fr 2fr;gap:40px;
  padding:36px 0;border-top:1px solid var(--line);
  transition:padding-left .5s var(--ease);position:relative;
}
.timeline li:last-child{border-bottom:1px solid var(--line)}
.timeline li::before{
  content:"";position:absolute;left:0;top:0;height:100%;width:0;
  background:linear-gradient(90deg, rgba(212,175,55,.08), transparent 60%);
  transition:width .7s var(--ease);pointer-events:none;
}
.timeline li:hover{padding-left:24px}
.timeline li:hover::before{width:100%}
.timeline__step{font-family:var(--f-display);font-weight:900;font-size:48px;color:var(--gold);line-height:.9;letter-spacing:-.03em}
.timeline h3{font-size:36px;align-self:start}
.timeline p{font-size:17px;line-height:1.5;color:rgba(245,243,238,.7);max-width:560px;align-self:center}

/* ==================== CANTERA ==================== */
.cantera{padding:0 var(--pad) 80px}
.cantera__grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:16px;
  grid-auto-rows:180px;
}
.tile{position:relative;overflow:hidden;border:1px solid var(--line);isolation:isolate}
.t-1{grid-column:span 3;grid-row:span 2}
.t-2{grid-column:span 3}
.t-3{grid-column:span 2}
.t-4{grid-column:span 2;grid-row:span 2}
.t-5{grid-column:span 2}
.t-6{grid-column:span 4}
.tile__ph{
  width:100%;height:100%;display:grid;place-items:end start;padding:24px;
  background:linear-gradient(135deg, var(--navy-2), var(--navy));
  background-image:
    linear-gradient(135deg, rgba(30,74,140,.6), rgba(10,31,61,.9)),
    repeating-linear-gradient(45deg, transparent 0 12px, rgba(212,175,55,.05) 12px 13px);
  color:var(--gold);transition:transform .8s var(--ease);
}
.tile__ph span{font:600 11px/1 var(--f-mono);letter-spacing:.2em;text-transform:uppercase}
.tile__ph::before{
  content:attr(data-ph);position:absolute;top:16px;right:20px;
  font-family:var(--f-display);font-weight:900;font-size:56px;line-height:1;color:rgba(212,175,55,.25);
}
.tile:hover .tile__ph{transform:scale(1.04)}
.cantera__note{margin-top:40px;font:400 13px/1.4 var(--f-mono);color:rgba(245,243,238,.4);max-width:600px}
.cantera__note em{color:var(--gold);font-style:normal}

/* ==================== SOCIAL ==================== */
.social{padding:120px var(--pad)}
.social__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.sbox{
  position:relative;padding:40px 32px;min-height:260px;
  border:1px solid var(--line);display:flex;flex-direction:column;gap:14px;
  transition:background .5s var(--ease), border-color .3s, color .3s;
  overflow:hidden;
}
.sbox::before{
  content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--gold),var(--gold-soft));
  transform:scale(0);transform-origin:bottom right;transition:transform .6s var(--ease);z-index:-1;
}
.sbox:hover{color:var(--navy);border-color:var(--gold)}
.sbox:hover::before{transform:scale(1.5)}
.sbox__hand{font-family:var(--f-display);font-weight:900;font-size:34px;line-height:1;letter-spacing:-.02em;margin-top:auto}
.sbox__label{font:700 11px/1 var(--f-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}
.sbox:hover .sbox__label{color:var(--navy)}
.sbox__count{font-size:13px;color:rgba(245,243,238,.6)}
.sbox:hover .sbox__count{color:rgba(10,31,61,.8)}
.sbox__arrow{position:absolute;top:28px;right:28px;font-size:24px;transition:transform .4s var(--ease)}
.sbox:hover .sbox__arrow{transform:translate(4px,-4px)}

/* ==================== CONTACTO ==================== */
.contacto{padding:0 var(--pad) 120px}
.contacto__grid{display:grid;grid-template-columns:1.3fr 1fr;gap:80px}
.contacto__lead h2{font-size:clamp(40px,6vw,96px);font-weight:900}
.contacto__lead h2 em{color:var(--gold);font-style:italic}
.contacto__lead p{margin-top:24px;font-size:18px;line-height:1.5;color:rgba(245,243,238,.75);max-width:540px}

.contacto__info{list-style:none;display:flex;flex-direction:column}
.contacto__info li{display:grid;grid-template-columns:140px 1fr;gap:24px;padding:20px 0;border-top:1px solid var(--line)}
.contacto__info li:last-child{border-bottom:1px solid var(--line)}
.contacto__info span{font:600 10px/1 var(--f-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--gold);padding-top:4px}
.contacto__info b{font-weight:400;font-size:16px;line-height:1.4;color:var(--bone)}
.contacto__info a{border-bottom:1px solid var(--gold);transition:color .3s}
.contacto__info a:hover{color:var(--gold)}

/* ==================== FOOT ==================== */
.foot{padding:80px var(--pad) 40px;border-top:1px solid var(--line);overflow:hidden}
.foot__big{
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--f-display);font-weight:900;font-size:clamp(80px,16vw,260px);
  line-height:.85;letter-spacing:-.05em;margin-bottom:60px;
}
.foot__big--out{color:transparent;-webkit-text-stroke:1px var(--bone);font-style:italic}
.foot__row{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
  font:600 11px/1.4 var(--f-mono);letter-spacing:.15em;text-transform:uppercase;color:rgba(245,243,238,.5)}

/* ==================== REVEAL UTILITIES ==================== */
[data-reveal]{display:block;overflow:hidden}
[data-reveal]>*{display:inline-block}

/* ==================== RESPONSIVE ==================== */
@media (max-width: 1100px){
  .nav__links{display:none}
  .nav__burger{display:block}
  .rail{display:none}
  .hero{grid-template-columns:1fr}
  .hero__crest{justify-self:start;grid-column:1;grid-row:3/4;width:180px}
  .hero__footer{order:3}
  .manifiesto__grid{grid-template-columns:1fr;gap:48px}
  .manifiesto__aside{position:static;flex-direction:row;align-items:center}
  .cards{grid-template-columns:1fr;gap:16px}
  .card{min-height:auto}
  .pachuca__hero{grid-template-columns:1fr;gap:40px}
  .pachuca__seal{grid-column:1;grid-row:auto;max-width:260px;justify-self:start}
  .pachuca__list{grid-template-columns:1fr;grid-column:1}
  .pachuca__list li:nth-child(odd){border-right:0;padding-right:0}
  .pachuca__list li:nth-child(even){padding-left:0}
  .stats__row{grid-template-columns:repeat(2,1fr);gap:32px}
  .timeline li{grid-template-columns:80px 1fr;gap:20px}
  .timeline p{grid-column:1/-1;padding-top:8px}
  .cantera__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .t-1,.t-2,.t-3,.t-4,.t-5,.t-6{grid-column:span 1;grid-row:span 1}
  .t-1,.t-4{grid-row:span 2}
  .social__grid{grid-template-columns:1fr;gap:12px}
  .sbox{min-height:180px}
  .contacto__grid{grid-template-columns:1fr;gap:40px}
  .bignum{grid-template-columns:1fr;gap:0}
  .bignum__digit{font-size:160px}
}

@media (max-width: 600px){
  .nav__name em{display:none}
  .hero__footer{gap:24px}
  .hero__stat{min-width:120px}
  .hero__scroll{display:none}
  .chap{padding-top:80px}
  .chap span{font-size:48px}
  .manifiesto__aside{flex-direction:column}
  .contacto__info li{grid-template-columns:1fr;gap:6px}
}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important;transition-duration:.001ms !important}
}
