/* === RESET & TOKENS === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --paper:#ffffff;
  --paper-deep:#fff5b8;
  --ink:#0d0d0d;
  --terracotta:#e62327;
  --verde:#00853f;
  --amarillo:#f7dd00;
  --rule:1px solid var(--ink);
  --shadow:6px 6px 0 var(--ink);
  --shadow-sm:3px 3px 0 var(--ink);
  --container:1320px;
}
html{scroll-behavior:smooth}
body{
  font-family:"Manrope",sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  position:relative;
}
/* grain texture overlay */
body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;
  z-index:1000;
  opacity:.18;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.1 0 0 0 0 0.08 0 0 0 0 0.07 0 0 0 0.5 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}
img,svg{display:block;max-width:100%}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:inherit;text-decoration:none}
.mono{font-family:"JetBrains Mono",monospace;font-weight:500;letter-spacing:.05em;text-transform:uppercase;font-size:11px}
.wrap{max-width:var(--container);margin:0 auto;padding:0 32px}

/* === NAV === */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  background:rgba(255,255,255,.78);
  border-bottom:var(--rule);
}
.nav-row{display:flex;align-items:center;justify-content:space-between;height:68px;gap:24px}
.brand{display:flex;align-items:center;gap:12px}
.crest{
  display:block;
  height:44px;
  width:auto;
  object-fit:contain;
  flex-shrink:0;
}
.brand-text{font-family:"Anton",sans-serif;line-height:.95;font-size:13px;letter-spacing:.02em;text-transform:uppercase}
.brand-text span{display:block;font-family:"JetBrains Mono",monospace;font-size:9px;font-weight:500;letter-spacing:.12em;color:#6a6a6a}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-family:"JetBrains Mono",monospace;font-size:12px;font-weight:500;letter-spacing:.05em;text-transform:uppercase;position:relative}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:2px;background:var(--terracotta);transition:width .25s ease}
.nav-links a:hover::after{width:100%}
.cta-pill{
  background:var(--ink);color:var(--paper);
  padding:11px 22px;border-radius:999px;
  font-family:"Manrope",sans-serif;font-weight:600;font-size:13px;
  letter-spacing:.02em;
  transition:transform .2s ease, background .2s;
}
.cta-pill:hover{background:var(--terracotta);transform:translateY(-2px)}

/* Hamburguesa móvil */
.nav-toggle{
  display:none;
  width:42px;height:42px;
  flex-direction:column;justify-content:center;align-items:center;gap:5px;
  border:1.5px solid var(--ink);
  background:var(--paper);
  border-radius:10px;
  flex-shrink:0;
}
.nav-toggle span{
  display:block;width:20px;height:2px;background:var(--ink);
  transition:transform .25s ease, opacity .2s ease;
}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* === HERO (video de fondo full-bleed) === */
.hero{
  position:relative;
  min-height:100vh;
  min-height:100svh;
  padding:140px 0 100px;
  border-bottom:var(--rule);
  overflow:hidden;
  display:flex;
  align-items:center;
  background:var(--ink);
}
.hero-bg-video{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  z-index:0;
  pointer-events:none;
}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  pointer-events:none;
  background:
    linear-gradient(95deg, rgba(13,13,13,.88) 0%, rgba(13,13,13,.55) 50%, rgba(13,13,13,.18) 100%),
    linear-gradient(180deg, rgba(13,13,13,.35) 0%, rgba(13,13,13,.05) 60%, rgba(13,13,13,.5) 100%);
}
.hero-content{
  position:relative;z-index:2;
  width:100%;
  max-width:var(--container);
}
/* Accents flotando arriba a la derecha */
.hero-accents{
  position:absolute;
  top:108px;right:48px;
  z-index:3;
  display:flex;flex-direction:column;align-items:flex-end;gap:18px;
  pointer-events:none;
}
/* Indicador scroll abajo */
.hero-scroll{
  position:absolute;
  bottom:28px;left:50%;
  transform:translateX(-50%);
  z-index:3;
  font-family:"JetBrains Mono",monospace;
  font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.7);
  animation:bob 2.2s ease-in-out infinite;
}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,6px)}}
.kicker{
  display:inline-flex;align-items:center;gap:10px;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:36px;
  padding:8px 14px;
  border:1.5px solid var(--ink);
  background:var(--amarillo);
  color:var(--ink);
}
.dot{width:8px;height:8px;border-radius:50%;background:var(--terracotta);animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.4)}}
.h1{
  font-family:"Anton",sans-serif;
  font-size:clamp(64px,10vw,168px);
  line-height:.86;
  letter-spacing:-.01em;
  text-transform:uppercase;
  margin-bottom:32px;
}
.h1 .row{display:block;overflow:hidden}
.h1 .word{display:inline-block;transform:translateY(110%);animation:slideUp .9s cubic-bezier(.2,.8,.2,1) forwards}
.h1 .row:nth-child(2) .word{animation-delay:.12s}
.h1 .row:nth-child(3) .word{animation-delay:.24s}
.h1 em{font-style:normal;color:var(--terracotta)}
@keyframes slideUp{to{transform:translateY(0)}}
.deck{
  font-family:"Fraunces",serif;
  font-style:italic;
  font-weight:400;
  font-size:clamp(17px,1.4vw,21px);
  line-height:1.45;
  max-width:520px;
  margin-bottom:36px;
  color:#2a2a2a;
  text-wrap:pretty;
}
.btn-row{display:flex;gap:14px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 26px;
  font-family:"Manrope",sans-serif;font-weight:600;font-size:14px;
  letter-spacing:.02em;
  border:1.5px solid var(--ink);
  transition:transform .2s ease, box-shadow .2s ease, background .2s;
}
.btn-primary{background:var(--ink);color:var(--paper);box-shadow:var(--shadow)}
.btn-primary:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--terracotta)}
.btn-ghost{background:transparent;color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.arrow{display:inline-block;transition:transform .25s}
.btn:hover .arrow{transform:translateX(4px)}

/* Botón play reutilizable (galería video) */
.video-play{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:88px;height:88px;
  border-radius:50%;
  background:var(--amarillo);
  border:2px solid var(--ink);
  box-shadow:var(--shadow);
  display:flex;align-items:center;justify-content:center;
  color:var(--ink);
  z-index:5;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.video-play svg{width:36px;height:36px;margin-left:4px}
.video-play:hover{transform:translate(-50%,-50%) scale(1.08);box-shadow:9px 9px 0 var(--ink);background:var(--paper)}

/* Texto invertido sobre el video oscuro */
.hero-content .h1{color:var(--paper)}
.hero-content .h1 em{color:var(--amarillo)}
.hero-content .deck{color:rgba(255,255,255,.92);max-width:580px}
.hero-content .btn-ghost{border-color:var(--paper);color:var(--paper);background:transparent}
.hero-content .btn-ghost:hover{background:var(--paper);color:var(--ink)}
.hero-content .btn-primary{box-shadow:6px 6px 0 var(--terracotta)}
.hero-content .btn-primary:hover{box-shadow:9px 9px 0 var(--amarillo)}

/* Tarjetas decorativas (bandera + match) */
.flag-card{
  width:120px;height:80px;
  border:1.5px solid var(--ink);
  background:var(--paper);
  box-shadow:var(--shadow);
  transform:rotate(-6deg);
  display:grid;grid-template-rows:1fr 1fr 1fr;
}
.flag-card>*:nth-child(1){background:var(--terracotta)}
.flag-card>*:nth-child(2){background:var(--amarillo)}
.flag-card>*:nth-child(3){background:var(--verde)}
.match-card{
  background:var(--terracotta);color:var(--paper);
  border:1.5px solid var(--ink);
  padding:12px 16px;
  box-shadow:var(--shadow);
  transform:rotate(4deg);
  font-family:"Anton",sans-serif;
  text-transform:uppercase;
}
.match-card .vs{display:flex;align-items:center;gap:14px;font-size:28px;line-height:1}
.match-card .vs span{font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:500}
.match-card .when{font-family:"JetBrains Mono",monospace;font-size:9px;font-weight:500;letter-spacing:.12em;margin-top:8px}

/* === SECTION HEAD === */
.sec-head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:32px;
  padding:80px 0 40px;
  border-bottom:var(--rule);
  margin-bottom:48px;
}
.sec-tag{font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--terracotta)}
.sec-num{font-family:"Anton",sans-serif;font-size:80px;line-height:.9;color:var(--paper-deep);-webkit-text-stroke:1px var(--ink)}
.sec-title{font-family:"Anton",sans-serif;font-size:clamp(40px,5vw,72px);line-height:.92;text-transform:uppercase;letter-spacing:-.005em;margin-top:8px}
.sec-title em{font-family:"Fraunces",serif;font-style:italic;font-weight:400;color:var(--terracotta);text-transform:none;letter-spacing:-.02em}
.sec-title.light{color:var(--paper)}

/* === HISTORIA (dark) === */
.historia{
  background:var(--ink);color:var(--paper);
  padding:120px 0;
  position:relative;
  overflow:hidden;
  border-top:var(--rule);
  border-bottom:var(--rule);
}
.marquee{
  position:absolute;top:50%;left:0;right:0;
  transform:translateY(-50%);
  font-family:"Anton",sans-serif;
  font-size:clamp(120px,18vw,260px);
  line-height:1;
  white-space:nowrap;
  color:rgba(255,255,255,.05);
  text-transform:uppercase;
  pointer-events:none;
  animation:marquee 38s linear infinite;
}
@keyframes marquee{from{transform:translate(0,-50%)}to{transform:translate(-50%,-50%)}}
.historia .wrap{position:relative;z-index:2}
.historia .sec-head{border-bottom:1px solid rgba(255,255,255,.2);padding-top:0}
.historia .sec-num{color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.4)}
.historia .sec-tag{color:var(--amarillo)}
.historia-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.route-svg{width:100%;height:auto}
.route-svg .path{stroke-dasharray:1200;stroke-dashoffset:1200;transition:stroke-dashoffset 2.4s ease 0.3s}
.route-svg.in .path{stroke-dashoffset:0}
.route-svg .pin{opacity:0;transform-origin:center;transition:opacity .5s ease}
.route-svg.in .pin{opacity:1}
.route-svg.in .pin.b{transition-delay:.4s}
.route-svg.in .pin.m{transition-delay:1.8s}
.route-svg .plane{opacity:0;transition:opacity .4s ease 1s}
.route-svg.in .plane{opacity:1;animation:fly 4s ease-in-out infinite alternate}
@keyframes fly{from{transform:translate(0,0) rotate(15deg)}to{transform:translate(8px,-4px) rotate(15deg)}}
.pull{
  font-family:"Fraunces",serif;
  font-style:italic;
  font-weight:400;
  font-size:clamp(20px,2.2vw,28px);
  line-height:1.35;
  border-left:3px solid var(--terracotta);
  padding:8px 0 8px 24px;
  margin-top:32px;
  text-wrap:balance;
}
.pull cite{display:block;margin-top:14px;font-style:normal;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--amarillo)}
.historia p{font-size:16px;line-height:1.6;color:#cccccc;max-width:480px}
.historia .hl{color:var(--amarillo)}

/* Bracket dentro de historia */
.bracket{margin-top:36px;border-top:1px solid rgba(255,255,255,.2);padding-top:24px}
.bracket-title{color:var(--amarillo);margin-bottom:14px}
.bracket-list{display:flex;flex-direction:column;gap:8px;font-family:"JetBrains Mono",monospace;font-size:13px}
.bracket-row{display:flex;justify-content:space-between;border-bottom:1px dashed rgba(255,255,255,.18);padding:8px 0}
.bracket-row.last{border-bottom:none}
.bracket-row .muted{color:#909090}
.bracket-row .win{color:var(--verde)}
.bracket-row .hl{color:var(--amarillo)}

/* === STATS === */
.stats{padding:0;border-bottom:var(--rule);background:var(--paper-deep)}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
}
.stat{
  padding:48px 28px;
  border-right:var(--rule);
  position:relative;
  min-height:220px;
  display:flex;flex-direction:column;justify-content:space-between;
}
.stat:last-child{border-right:none}
.stat .num{font-family:"Anton",sans-serif;font-size:clamp(72px,9vw,120px);line-height:.9;letter-spacing:-.02em}
.stat .num em{font-style:normal;color:var(--terracotta)}
.stat .label{font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#6a6a6a}
.stat .top{font-family:"JetBrains Mono",monospace;font-size:10px;font-weight:600;color:var(--terracotta);letter-spacing:.14em}

/* === PLAN: timeline visual === */
.plan{padding-bottom:120px}
.timeline{
  position:relative;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:24px;
}
.timeline::before{
  content:"";
  position:absolute;top:36px;left:8%;right:8%;height:2px;
  background:var(--ink);
  z-index:0;
}
.phase{
  position:relative;
  background:var(--paper);
  border:1.5px solid var(--ink);
  box-shadow:var(--shadow);
  padding:32px 26px 26px;
  z-index:1;
  transition:transform .3s ease,box-shadow .3s ease;
}
.phase:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--terracotta)}
.phase .circle{
  width:64px;height:64px;border-radius:50%;
  background:var(--paper);
  border:1.5px solid var(--ink);
  display:flex;align-items:center;justify-content:center;
  font-family:"Anton",sans-serif;font-size:32px;
  margin-top:-66px;margin-bottom:20px;
  box-shadow:var(--shadow-sm);
}
.phase:nth-child(2) .circle{background:var(--terracotta);color:var(--paper)}
.phase:nth-child(3) .circle{background:var(--ink);color:var(--amarillo)}
.phase h3{font-family:"Anton",sans-serif;text-transform:uppercase;font-size:26px;line-height:1;letter-spacing:-.01em;margin-bottom:6px}
.phase .sub{font-family:"Fraunces",serif;font-style:italic;font-size:15px;color:#6a6a6a;margin-bottom:18px}
.phase ul{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.phase li{display:flex;gap:10px;font-size:14px;line-height:1.45}
.phase li::before{content:"→";color:var(--terracotta);font-weight:700;flex-shrink:0}
.phase .foot{
  display:flex;justify-content:space-between;align-items:flex-end;
  border-top:1px dashed var(--ink);
  padding-top:14px;
  font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
}
.phase .cost{font-family:"Anton",sans-serif;font-size:22px;color:var(--terracotta);letter-spacing:0}

/* === EQUIPO (gallery) === */
.equipo{background:var(--paper-deep);border-top:var(--rule);border-bottom:var(--rule);padding-bottom:120px}
.equipo-intro{
  font-family:"Fraunces",serif;
  font-style:italic;
  font-size:clamp(18px,1.6vw,22px);
  line-height:1.45;
  max-width:680px;
  margin-bottom:48px;
  color:#2a2a2a;
}
/* Sub-bloques por evento */
.event{margin-bottom:72px}
.event:last-of-type{margin-bottom:48px}
.event-head{
  display:flex;flex-direction:column;gap:6px;
  border-top:var(--rule);
  padding-top:20px;margin-bottom:24px;
}
.event-tag{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--terracotta);
}
.event-title{
  font-family:"Anton",sans-serif;
  font-size:clamp(28px,3.4vw,44px);
  line-height:.95;
  text-transform:uppercase;
  letter-spacing:-.005em;
}
.event-sub{
  font-family:"Fraunces",serif;
  font-style:italic;
  font-size:16px;line-height:1.4;
  color:#2a2a2a;
  max-width:520px;
  margin-top:4px;
}
#event-amistosos .event-tag{color:var(--terracotta)}
#event-bolivia-vs .event-tag{color:var(--verde)}
#event-copa-america .event-tag{color:#a18d00}

.gallery{
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr;
  grid-template-rows:1fr 1fr;
  gap:18px;
  margin-bottom:24px;
}
/* Variante: 3 tiles (1 feature grande + 2 chicas apiladas a la derecha) */
.gallery--3{
  grid-template-columns:1.8fr 1fr;
}
.gallery--3 .tile-feat{grid-column:1;grid-row:1 / span 2}
.gallery--3 .tile-1{grid-column:2;grid-row:1}
.gallery--3 .tile-2{grid-column:2;grid-row:2}
.tile{
  position:relative;
  border:1.5px solid var(--ink);
  background:var(--ink);
  overflow:hidden;
  transition:transform .3s ease, box-shadow .3s ease;
}
.tile img,.tile video{
  display:block;
  width:100%;height:100%;
  object-fit:cover;
  background:var(--paper-deep);
}
.tile:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.tile-feat{grid-column:1;grid-row:1 / span 2;box-shadow:8px 8px 0 var(--terracotta)}
.tile-feat:hover{box-shadow:11px 11px 0 var(--terracotta);transform:translate(-2px,-4px)}
.tile-1{grid-column:2;grid-row:1}
.tile-2{grid-column:3;grid-row:1}
.tile-3{grid-column:2;grid-row:2}
.tile-4{grid-column:3;grid-row:2}
.tile-1{box-shadow:5px 5px 0 var(--amarillo)}
.tile-2{box-shadow:5px 5px 0 var(--verde)}
.tile-3{box-shadow:5px 5px 0 var(--terracotta)}
.tile-4{box-shadow:5px 5px 0 var(--amarillo)}
.tile-tag{
  position:absolute;
  bottom:10px;
  background:var(--amarillo);
  border:1.5px solid var(--ink);
  padding:5px 10px;
  font-family:"JetBrains Mono",monospace;
  font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  box-shadow:var(--shadow-sm);
  z-index:3;
}
.tile-tag.tag-rot-l{left:10px;transform:rotate(-2deg)}
.tile-tag.tag-rot-r{right:10px;transform:rotate(2deg)}
.tile-feat .tile-tag{background:var(--terracotta);color:var(--paper);font-size:11px;padding:6px 12px}
.tile-play{
  width:72px;height:72px;
}
.tile-play svg{width:30px;height:30px}
.tile.playing .video-play{opacity:0;pointer-events:none;transition:opacity .25s ease}

/* Cuerpo técnico */
.coach-card{
  display:grid;
  grid-template-columns:280px 1fr;
  gap:36px;
  align-items:center;
  background:var(--paper);
  border:1.5px solid var(--ink);
  padding:32px;
  margin:0 0 32px;
  box-shadow:var(--shadow);
}
.coach-photo{
  position:relative;
  aspect-ratio:1;
  border:1.5px solid var(--ink);
  overflow:hidden;
  background:var(--paper-deep);
}
.coach-photo img{width:100%;height:100%;object-fit:cover;display:block}
.coach-flag{
  position:absolute;left:0;right:0;bottom:0;
  display:grid;grid-template-columns:1fr 1fr 1fr;
  height:8px;
  border-top:1.5px solid var(--ink);
}
.coach-flag i{display:block}
.coach-flag i:nth-child(1){background:var(--terracotta)}
.coach-flag i:nth-child(2){background:var(--amarillo)}
.coach-flag i:nth-child(3){background:var(--verde)}
.coach-body .event-tag{display:inline-block;margin-bottom:10px;color:var(--terracotta)}
.coach-name{
  font-family:"Anton",sans-serif;
  font-size:clamp(40px,4.5vw,64px);
  line-height:.92;
  text-transform:uppercase;
  letter-spacing:-.01em;
  margin-bottom:6px;
}
.coach-role{
  font-family:"JetBrains Mono",monospace;
  font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:#6a6a6a;
  margin-bottom:14px;
}
.coach-bio{
  font-family:"Fraunces",serif;
  font-size:16px;line-height:1.5;
  max-width:580px;
  color:#2a2a2a;
  margin-bottom:16px;
}
.coach-extras{
  list-style:none;
  display:flex;flex-direction:column;gap:6px;
  padding-top:14px;
  border-top:1px dashed var(--ink);
  max-width:580px;
}
.coach-extras li{
  display:flex;gap:10px;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;font-weight:500;letter-spacing:.04em;
  color:#6a6a6a;
  line-height:1.4;
}
.coach-extras li::before{
  content:"→";
  color:var(--terracotta);
  font-weight:700;
  flex-shrink:0;
}

/* Botón descarga del deck */
.deck-download{
  display:flex;
  align-items:center;
  gap:20px;
  background:var(--ink);
  color:var(--paper);
  padding:18px 24px;
  border:1.5px solid var(--ink);
  margin:0 0 56px;
  text-decoration:none;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.deck-download:hover{
  background:var(--terracotta);
  transform:translate(-2px,-2px);
  box-shadow:6px 6px 0 var(--amarillo);
}
.deck-icon{
  flex-shrink:0;
  width:52px;height:52px;
  background:var(--terracotta);
  color:var(--paper);
  border:1.5px solid var(--paper);
  display:flex;align-items:center;justify-content:center;
  font-family:"Anton",sans-serif;
  font-size:14px;letter-spacing:.05em;
}
.deck-download:hover .deck-icon{background:var(--ink);border-color:var(--paper)}
.deck-label{flex:1;display:flex;flex-direction:column;gap:2px;line-height:1.2}
.deck-label strong{
  font-family:"Anton",sans-serif;
  font-size:18px;
  letter-spacing:.005em;
  text-transform:uppercase;
}
.deck-label small{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;font-weight:500;letter-spacing:.06em;
  color:#cccccc;
}
.deck-download:hover .deck-label small{color:rgba(255,255,255,.85)}
.deck-arrow{
  font-family:"Anton",sans-serif;
  font-size:28px;
  transition:transform .25s ease;
}
.deck-download:hover .deck-arrow{transform:translateY(4px)}

.equipo-quote{
  position:relative;
  border:1.5px solid var(--ink);
  background:var(--paper);
  padding:48px 56px 40px;
  max-width:880px;
  margin:0 auto;
  box-shadow:var(--shadow);
}
.equipo-quote::before{
  content:"";
  position:absolute;top:0;left:0;right:0;height:6px;
  background:linear-gradient(90deg,
    var(--terracotta) 0,var(--terracotta) 33.33%,
    var(--amarillo) 33.33%,var(--amarillo) 66.66%,
    var(--verde) 66.66%,var(--verde) 100%);
}
.equipo-quote .q-mark{
  position:absolute;top:14px;left:24px;
  font-family:"Fraunces",serif;font-size:96px;line-height:1;
  color:var(--terracotta);
  pointer-events:none;
}
.equipo-quote p{
  font-family:"Fraunces",serif;
  font-style:italic;
  font-size:clamp(22px,2.4vw,30px);
  line-height:1.3;
  text-wrap:balance;
  margin-left:48px;
}
.equipo-quote cite{
  display:block;
  margin-top:18px;margin-left:48px;
  font-style:normal;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:#6a6a6a;
}

/* === PRESUPUESTO (dark) === */
.budget{
  background:var(--ink);color:var(--paper);
  padding:120px 0;
  border-top:var(--rule);border-bottom:var(--rule);
}
.budget .sec-head{padding-top:0;border-bottom:1px solid rgba(255,255,255,.2)}
.budget .sec-num{color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.4)}
.budget .sec-tag{color:var(--amarillo)}
.budget-top{
  display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:center;
  margin-bottom:64px;
}
.total-card{
  border:1.5px solid var(--paper);
  padding:32px;
  background:var(--terracotta);
  box-shadow:8px 8px 0 var(--amarillo);
}
.total-card .lbl{font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px}
.total-card .amount{font-family:"Anton",sans-serif;font-size:clamp(72px,9vw,128px);line-height:.85;letter-spacing:-.02em}
.total-card .currency{font-family:"Anton",sans-serif;font-size:24px;letter-spacing:.04em;margin-top:4px}
.total-card .note{font-family:"Fraunces",serif;font-style:italic;font-size:16px;margin-top:18px;border-top:1px solid rgba(255,255,255,.4);padding-top:14px}

/* Donut */
.donut-wrap{display:flex;align-items:center;gap:32px}
.donut{width:280px;height:280px;flex-shrink:0;position:relative}
.donut svg{transform:rotate(-90deg);width:100%;height:100%}
.donut .center{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-family:"Anton",sans-serif;
}
.donut .center .pct{font-size:44px;line-height:1;color:var(--amarillo)}
.donut .center .pct-lbl{font-family:"JetBrains Mono",monospace;font-size:9px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--paper);margin-top:4px;text-align:center}
.donut circle.bg{stroke:rgba(255,255,255,.1);fill:none;stroke-width:28}
.donut circle.seg{fill:none;stroke-width:28;stroke-linecap:butt}

.budget-bars{display:flex;flex-direction:column;gap:18px}
.bar-row{display:grid;grid-template-columns:1fr 1.6fr auto;gap:20px;align-items:center}
.bar-row .name{font-family:"Anton",sans-serif;font-size:18px;text-transform:uppercase;letter-spacing:.01em}
.bar-row .name span{display:block;font-family:"JetBrains Mono",monospace;font-size:9px;font-weight:500;letter-spacing:.1em;color:#909090;margin-top:2px}
.bar-track{height:14px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.28);border-radius:8px;position:relative;overflow:hidden}
.bar-fill{position:absolute;top:0;bottom:0;left:0;width:0;background:var(--terracotta);transition:width 1.6s cubic-bezier(.2,.8,.2,1)}
.bar-row.alt .bar-fill{background:var(--amarillo)}
.bar-row.alt2 .bar-fill{background:var(--verde)}
.bar-row .val{font-family:"Anton",sans-serif;font-size:20px;color:var(--amarillo);text-align:right;min-width:120px}
.bar-row .val span{display:block;font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--paper);font-weight:500;letter-spacing:.06em;margin-top:2px}
.budget-foot{
  margin-top:48px;
  text-align:center;
  font-family:"Anton",sans-serif;
  font-size:clamp(40px,6vw,80px);
  line-height:.95;
  text-transform:uppercase;
  border-top:1px solid rgba(255,255,255,.2);
  padding-top:48px;
}
.budget-foot em{font-style:normal;color:var(--terracotta)}

/* === CTA FINAL === */
.cta-final{
  background:var(--terracotta);
  color:var(--paper);
  padding:160px 0;
  text-align:center;
  border-top:var(--rule);
  position:relative;
  overflow:hidden;
}
.cta-final::before{
  content:"BOLIVIA · MARRUECOS · 2026 · ";
  position:absolute;top:0;left:0;right:0;
  font-family:"Anton",sans-serif;
  font-size:24px;letter-spacing:.2em;
  color:rgba(247,221,0,.4);
  white-space:nowrap;
  padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,.2);
}
.cta-final .h2{
  font-family:"Anton",sans-serif;
  font-size:clamp(72px,12vw,200px);
  line-height:.86;
  text-transform:uppercase;
  letter-spacing:-.015em;
  margin-bottom:48px;
}
.cta-final .h2 em{font-family:"Fraunces",serif;font-style:italic;font-weight:400;color:var(--amarillo);text-transform:none;letter-spacing:-.02em}
.cta-chant{
  font-family:"Anton",sans-serif;
  font-size:24px;
  letter-spacing:.18em;
  margin:-24px 0 40px;
  color:var(--amarillo);
}
.cta-final .btn-row{justify-content:center}
.cta-final .btn-primary{background:var(--ink);box-shadow:6px 6px 0 var(--amarillo)}
.cta-final .btn-primary:hover{box-shadow:8px 8px 0 var(--paper)}
.cta-final .btn-ghost{border-color:var(--paper);color:var(--paper)}
.cta-final .btn-ghost:hover{background:var(--paper);color:var(--terracotta)}

/* === FOOTER === */
.footer{background:var(--ink);color:var(--paper);padding:80px 0 32px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.foot-col h5{font-family:"JetBrains Mono",monospace;font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--amarillo);margin-bottom:18px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-col a, .foot-col p{font-size:14px;color:#cccccc;line-height:1.45;transition:color .2s}
.foot-col a:hover{color:var(--terracotta)}
.foot-brand{display:flex;align-items:flex-start;gap:14px;margin-bottom:16px}
.foot-brand .crest{height:54px}
.foot-brand .brand-text{color:var(--paper);font-size:15px}
.foot-brand .brand-text span{color:#909090}
.foot-bottom{
  border-top:1px solid rgba(255,255,255,.18);
  padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;
  font-family:"JetBrains Mono",monospace;font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:#909090;
  flex-wrap:wrap;gap:16px;
}

/* === REVEAL === */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease, transform .9s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}

/* === RESPONSIVE === */

/* --- Tablet horizontal / laptop pequeña --- */
@media (max-width:1100px){
  .nav-links{gap:20px}
  .hero-accents{transform:scale(.9);transform-origin:top right}
}

/* --- Tablet vertical --- */
@media (max-width:980px){
  /* Layout: secciones de 2 columnas a 1 */
  .historia-grid,.budget-top{grid-template-columns:1fr;gap:48px}
  .timeline{grid-template-columns:1fr;gap:48px;margin-top:0}
  .timeline::before{display:none}
  .donut-wrap{flex-direction:column;gap:24px}
  .donut{width:220px;height:220px}
  /* Stats: 4 → 2 columnas */
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:var(--rule)}
  /* Galería 5 tiles → 2 columnas con feature ancho */
  .gallery{grid-template-columns:1fr 1fr;grid-template-rows:auto auto auto}
  .tile-feat{grid-column:1 / span 2;grid-row:1;aspect-ratio:16/9}
  .tile-1{grid-column:1;grid-row:2}
  .tile-2{grid-column:2;grid-row:2}
  .tile-3{grid-column:1;grid-row:3}
  .tile-4{grid-column:2;grid-row:3}
  .tile{aspect-ratio:1}
  /* Galería 3 tiles → feature ancho + 2 chicas debajo */
  .gallery--3{grid-template-rows:auto auto}
  .gallery--3 .tile-feat{grid-column:1 / span 2;grid-row:1}
  .gallery--3 .tile-1{grid-column:1;grid-row:2}
  .gallery--3 .tile-2{grid-column:2;grid-row:2}
  /* Footer: 4 → 2 columnas */
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
  /* Nav: hamburguesa + menú desplegable */
  .nav-row{gap:12px}
  .brand{margin-right:auto}
  .nav-toggle{display:flex}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;
    align-items:stretch;
    gap:0;
    background:rgba(255,255,255,.97);
    backdrop-filter:blur(14px) saturate(140%);
    -webkit-backdrop-filter:blur(14px) saturate(140%);
    border-bottom:var(--rule);
    padding:6px 22px 18px;
    transform:translateY(-12px);
    opacity:0;pointer-events:none;
    transition:transform .25s ease, opacity .25s ease;
  }
  .nav-links a{
    padding:14px 2px;
    font-size:13px;
    border-bottom:1px dashed rgba(0,0,0,.14);
  }
  .nav-links a:last-child{border-bottom:none}
  .nav-links a::after{display:none}
  .nav.open .nav-links{transform:none;opacity:1;pointer-events:auto}
  /* Hero accents más chicas */
  .hero-accents{top:96px;right:24px;gap:12px;transform:scale(.8);transform-origin:top right}
}

/* --- Tablet pequeña / phone landscape --- */
@media (max-width:780px){
  .wrap{padding:0 22px}
  /* Secciones */
  .sec-head{flex-direction:column;align-items:flex-start;gap:16px;padding:60px 0 28px}
  .sec-num{font-size:56px}
  .historia,.budget,.cta-final{padding:80px 0}
  .equipo{padding-bottom:80px}
  .plan{padding-bottom:80px}
  .equipo-intro{font-size:16px;margin-bottom:36px}
  .event{margin-bottom:48px}
  /* Hero: video full bleed, accents off, overlay vertical */
  .hero{padding:120px 0 80px;min-height:88vh;min-height:88svh}
  .hero-accents{display:none}
  .hero-scroll{display:none}
  .hero-overlay{
    background:linear-gradient(180deg, rgba(13,13,13,.55) 0%, rgba(13,13,13,.35) 45%, rgba(13,13,13,.85) 100%);
  }
  /* Coach card stack temprano para no apretar */
  .coach-card{grid-template-columns:1fr;padding:24px;gap:24px}
  .coach-photo{max-width:280px}
  .coach-name{font-size:clamp(36px,7vw,52px)}
  /* Quote */
  .equipo-quote{padding:42px 28px 32px;margin:0}
  .equipo-quote p,.equipo-quote cite{margin-left:32px}
  .equipo-quote .q-mark{font-size:72px;left:14px;top:8px}
  /* Deck download wrap */
  .deck-download{flex-wrap:wrap;gap:14px;padding:16px 18px}
  .deck-arrow{margin-left:auto}
  /* Donut play button shrink */
  .video-play{width:72px;height:72px}
  .video-play svg{width:28px;height:28px}
  /* Budget bars: name + val arriba, track abajo */
  .budget-bars{gap:22px}
  .bar-row{grid-template-columns:1fr auto;grid-template-areas:"name val" "track track";gap:10px 14px;align-items:center}
  .bar-row .name{grid-area:name}
  .bar-row .name span{margin-top:3px}
  .bar-row .val{grid-area:val;min-width:auto;text-align:right}
  .bar-row .val span{margin-top:3px}
  .bar-row .bar-track{grid-area:track;height:12px}
}

/* --- Phone --- */
@media (max-width:560px){
  /* Stats apiladas */
  .stats-grid{grid-template-columns:1fr}
  .stat{border-right:none;border-bottom:var(--rule);min-height:auto;padding:36px 22px}
  .stat:last-child{border-bottom:none}
  /* Galería completamente apilada */
  .gallery,.gallery--3{grid-template-columns:1fr;grid-template-rows:auto}
  .tile,.tile-feat,.tile-1,.tile-2,.tile-3,.tile-4{grid-column:1;grid-row:auto;aspect-ratio:1}
  .tile-feat{aspect-ratio:4/3}
  /* Footer apilado */
  .foot-grid{grid-template-columns:1fr;gap:28px}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:8px}
  /* Nav: solo logo + cta + hamburguesa */
  .nav-row{gap:10px}
  .nav-row .brand-text{display:none}
  .cta-pill{padding:9px 16px;font-size:12px}
  .nav-toggle{width:38px;height:38px}
  /* Hero h1 - dejar el clamp tomar el control pero forzar mínimo razonable */
  .h1{font-size:clamp(52px, 13vw, 72px)}
  .deck{font-size:16px}
  .kicker{font-size:10px;padding:7px 12px}
  /* Quote más compacta */
  .equipo-quote{padding:32px 22px 26px}
  .equipo-quote .q-mark{font-size:56px;top:6px;left:12px}
  .equipo-quote p{font-size:20px;margin-left:24px}
  .equipo-quote cite{margin-left:24px}
  /* Total card del presupuesto */
  .total-card{padding:24px}
  /* CTA final h2 más chica */
  .cta-final .h2{font-size:clamp(60px,15vw,96px)}
  .cta-chant{font-size:16px;letter-spacing:.12em}
}

/* --- Phone chico --- */
@media (max-width:420px){
  .wrap{padding:0 18px}
  .h1{font-size:44px;line-height:.9}
  .sec-title{font-size:36px}
  .sec-num{font-size:44px}
  .total-card .amount{font-size:64px}
  .coach-name{font-size:32px}
  .equipo-quote p{font-size:18px}
  .deck-download{gap:10px}
  .deck-icon{width:42px;height:42px;font-size:12px}
}
