
:root {
  --red: #D42B2B;
  --red-dark: #B8232C;
  --red-pale: #FFF2F2;
  --black: #0D0D0D;
  --white: #FFFFFF;
  --off: #F7F7F5;
  --border: #E6E6E2;
  --muted: #8A8A80;
  --text: #1A1A1A;
  --red-soft: rgba(212, 43, 43, 0.08);
  --red-glow: rgba(212, 43, 43, 0.12);
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --charcoal: #3D3832;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Manrope',sans-serif;background:var(--white);color:var(--text);overflow-x:hidden;cursor:none}

/* CURSOR */
#cur{position:fixed;width:9px;height:9px;background:var(--red);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s,height .3s}
#curl{position:fixed;width:34px;height:34px;border:1px solid rgba(212,43,43,.3);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .3s,height .3s,opacity .3s}
@media(max-width:960px){#cur,#curl{display:none}body{cursor:auto}a,button{cursor:pointer}}

/* NAV */
nav{position:fixed;inset:0 0 auto;z-index:500;height:68px;display:flex;align-items:center;justify-content:space-between;padding:0 3rem;transition:background .4s,border-bottom .4s}
nav.scrolled{background:rgba(255,255,255,.94);backdrop-filter:blur(18px);border-bottom:1px solid var(--border)}
.logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.35rem;letter-spacing:-.02em;color:#fff;text-decoration:none;transition:color .35s}
nav.scrolled .logo{color:var(--black)}
.logo em{color:var(--red);font-style:normal}
.nav-links{display:flex;gap:2.2rem;list-style:none}
.nav-links a{font-size:.78rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:rgba(255,255,255,.65);text-decoration:none;transition:color .2s}
nav.scrolled .nav-links a{color:var(--muted)}
.nav-links a:hover{color:var(--red)}
.nav-cta{border-radius: 30px; font-family:'Syne',sans-serif;font-size:.76rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:var(--red);padding:.6rem 1.4rem;text-decoration:none;border:2px solid var(--red);transition:background .25s,color .25s}
.nav-cta:hover{background:transparent;color:var(--red)}
.ham{
  display:none;
  position:relative;
  width:32px;height:32px;
  flex-direction:column;justify-content:center;align-items:center;gap:0;
  cursor:pointer;background:none;border:none;padding:0;
  z-index:650;
}
/* Elevar nav por encima del menú abierto para que la X se vea */
body.menu-open #nav{
  z-index:700 !important;
  background:transparent !important;
  backdrop-filter:none !important;
  border-bottom:none !important;
  box-shadow:none !important;
}
body.menu-open #nav .logo{ color:var(--black) !important; }
body.menu-open #nav .nav-links{ pointer-events:none; opacity:0; }
.ham span{
  display:block;position:absolute;left:5px;right:5px;
  height:1.8px;background:var(--black);border-radius:2px;
  transition: transform .5s cubic-bezier(.22,1,.36,1), top .4s cubic-bezier(.22,1,.36,1), opacity .25s ease, background .3s, width .45s var(--e-out);
  transform-origin:center;
}
.ham span:nth-child(1){ top:10px; }
.ham span:nth-child(2){ top:15px; width:calc(100% - 14px); }
.ham span:nth-child(3){ top:20px; width:calc(100% - 20px); }
.ham:hover span:nth-child(2),
.ham:hover span:nth-child(3){ left:5px; right:5px; width:calc(100% - 10px); }
nav.scrolled .ham span{ background:var(--black); }
/* Estado open: transforma a una "X" */
body.menu-open .ham span:nth-child(1){ top:15px; transform:rotate(45deg); background:var(--red); }
body.menu-open .ham span:nth-child(2){ opacity:0; transform:translateX(-8px); }
body.menu-open .ham span:nth-child(3){ top:15px; transform:rotate(-45deg); background:var(--red); width:calc(100% - 10px); left:5px; right:5px; }
@media(max-width:960px){.nav-links,.nav-cta{display:none}.ham{display:flex}}
@media(max-width:640px){nav{padding:0 1.25rem}}

/* MOB MENU — animación de entrada + stagger */
.mob{
  display:flex;
  position:fixed; inset:0;
  background:#fff;
  z-index:600;
  flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;
  opacity:0;
  pointer-events:none;
  transform:scale(1.015);
  transition: opacity .5s var(--e-out), transform .55s var(--e-out), clip-path .65s var(--e-out);
  clip-path: circle(0% at calc(100% - 2rem) 2rem);
  -webkit-clip-path: circle(0% at calc(100% - 2rem) 2rem);
}
.mob.open{
  opacity:1;
  pointer-events:auto;
  transform:none;
  clip-path: circle(150% at calc(100% - 2rem) 2rem);
  -webkit-clip-path: circle(150% at calc(100% - 2rem) 2rem);
}
.mob::before{
  content:'';
  position:absolute; top:0; left:0; right:0; height:4px;
  background:var(--red);
  transform:scaleX(0); transform-origin:left;
  transition: transform .7s var(--e-out) .15s;
}
.mob.open::before{ transform:scaleX(1); }
.mob a{
  font-family:'Syne',sans-serif;
  font-size:clamp(1.7rem, 6vw, 2.2rem);
  font-weight:800;
  letter-spacing:-.02em;
  color:var(--black);
  text-decoration:none;
  position:relative;
  opacity:0;
  transform:translateY(24px);
  transition: opacity .55s var(--e-out), transform .6s var(--e-out), color .3s;
}
.mob.open a{ opacity:1; transform:none; }
.mob.open a:nth-child(2){ transition-delay:.22s; }
.mob.open a:nth-child(3){ transition-delay:.30s; }
.mob.open a:nth-child(4){ transition-delay:.38s; }
.mob.open a:nth-child(5){ transition-delay:.46s; }
.mob.open a:nth-child(6){ transition-delay:.54s; }
.mob.open a:nth-child(7){ transition-delay:.62s; }
.mob a::after{
  content:''; position:absolute; left:50%; right:50%; bottom:-6px;
  height:1px; background:var(--red);
  transition: left .4s var(--e-out), right .4s var(--e-out);
}
.mob a:hover{ color:var(--red); }
.mob a:hover::after{ left:0; right:0; }
.mob-x{ display:none; }
/* Bloquear scroll del body cuando menú abierto */
body.menu-open{ overflow:hidden; }

/* HERO */
/*#hero{position:relative;height:100vh;min-height:600px;display:flex;align-items:flex-end;overflow:hidden}*/

/* ===== HERO OVERRIDE — SPLIT LAYOUT ===== */
#hero {
  position: relative;
  height: 100vh;
  min-height: 650px;
  display: flex;
  align-items: center;
  padding: 0 3rem;
  background: var(--off);
  overflow: hidden;
}

/* Fondo: rejilla sutil que se desvanece con máscara */
#hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: 80px 80px;
  opacity: .25;
  mask-image: radial-gradient(ellipse 60% 55% at 62% 50%, black 10%, transparent 65%);
  -webkit-mask-image: radial-gradient(ellipse 60% 55% at 62% 50%, black 10%, transparent 65%);
  pointer-events: none;
  z-index: 0;
}

/* Transición suave del hero al siguiente bloque */
#hero::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 120px;
  background: linear-gradient(to top, var(--off) 0%, transparent 100%);
  pointer-events: none;
  z-index: 1;
}

/* ===== HERO DECORATIVE GRAPHIC LAYER =====
   Ocupa TODO el hero horizontalmente para que las marcas crucen la web,
   pero se posicionan en la franja superior e inferior — el vídeo vive en
   el centro vertical, así que nunca coinciden. */
.hero__deco{
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  overflow:hidden;
}
/* Tres líneas verticales discontinuas en el lateral izquierdo del hero
   — empiezan bajo el logo (nav 68px + hueco) y terminan con el hero. */
.hero__deco-lines{
  position:absolute;
  top: 96px;               /* justo debajo del logo/nav */
  bottom: 0;
  left: 2rem;
  width: 44px;             /* ancho que hospeda 3 líneas paralelas */
  pointer-events:none;
  overflow:hidden;         /* se oculta al terminar el hero */
}
.hdl{
  position:absolute;
  top:0; bottom:0;
  width: 4px;                          /* bloques de banda de rodadura */
  background-image: linear-gradient(to bottom,
    rgba(212,43,43,.22) 0,
    rgba(212,43,43,.22) 9px,
    transparent 9px,
    transparent 16px);
  background-size: 100% 16px;
  background-repeat: repeat-y;
  border-radius: 2px;
  filter: blur(.4px);                  /* bordes suaves, marca real */
  opacity: 0;
  transform: translateY(-30px);
  animation: hdlDraw 3.6s var(--ease-out) forwards;
}
/* Cada línea con su tonalidad muy tenue del mismo rojo */
.hdl-1{ left: 0;    animation-delay: .3s;  --o: .85; }
.hdl-2{ left: 14px; animation-delay: .55s; --o: .6;  }
.hdl-3{ left: 28px; animation-delay: .80s; --o: .4;  }
/* Pequeñas variaciones por-línea para que la banda no se vea tipográfica */
.hdl-2{
  background-image: linear-gradient(to bottom,
    rgba(212,43,43,.20) 0,
    rgba(212,43,43,.20) 7px,
    transparent 7px,
    transparent 14px);
  background-size: 100% 14px;
  width: 3.5px;
}
.hdl-3{
  background-image: linear-gradient(to bottom,
    rgba(212,43,43,.18) 0,
    rgba(212,43,43,.18) 11px,
    transparent 11px,
    transparent 18px);
  background-size: 100% 18px;
  width: 3px;
}
@keyframes hdlDraw{
  0%   { opacity:0; transform: translateY(-30px); clip-path: inset(0 0 100% 0); -webkit-clip-path: inset(0 0 100% 0); }
  12%  { opacity: var(--o, 1); }
  100% { opacity: var(--o, 1); transform: translateY(0); clip-path: inset(0 0 0 0); -webkit-clip-path: inset(0 0 0 0); }
}
/* Chip bajo los contadores */
.hero__deco-chip{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  margin-top: 1.5rem;
  padding:.55rem 1rem;
  font-family:'Syne',sans-serif;
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--black);
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(14px);
  border:1px solid var(--border);
  border-radius:40px;
  box-shadow: 0 14px 40px -14px rgba(13,13,13,.25), 0 2px 8px rgba(13,13,13,.05);
  opacity:0;
  transform: translateY(14px);
  animation: heroChipIn .8s var(--ease-spring) 1.4s forwards;
  position: relative;
  z-index:3;
}
.hero__deco-chip-dot{
  width:8px; height:8px; border-radius:50%;
  background:var(--red);
  box-shadow: 0 0 0 4px rgba(212,43,43,.16);
  animation: heroDotPulse 2.4s ease-in-out infinite;
}
@keyframes heroChipIn{
  to{ opacity:1; transform: translateY(0); }
}
@keyframes heroDotPulse{
  0%,100%{ box-shadow: 0 0 0 4px rgba(212,43,43,.16); }
  50%    { box-shadow: 0 0 0 9px rgba(212,43,43,0); }
}

/* Asegurar jerarquía: vídeo y texto por encima del deco */
#hero .hero__wrap{ z-index:2; }
.hero__video-col{ z-index:2; }

/* Mobile: suavizar deco para no saturar */
@media (max-width: 960px){
  .hero__deco-lines{ left: 1rem; width: 32px; }
  .hero__deco-lines .hdl-2{ left: 10px; }
  .hero__deco-lines .hdl-3{ left: 20px; }
  .hero__deco-chip{ font-size:.62rem; padding:.45rem .8rem; }
}
@media (max-width: 640px){
  .hero__deco-lines{ left: .5rem; width: 24px; }
  .hero__deco-lines .hdl-2{ left: 8px; }
  .hero__deco-lines .hdl-3{ left: 16px; }
}
@media (prefers-reduced-motion: reduce){
  .hdl,
  .hero__deco-chip,
  .hero__deco-chip-dot{ animation:none !important; }
  .hdl{ opacity: var(--o, 1); transform:none; clip-path:inset(0 0 0 0); -webkit-clip-path:inset(0 0 0 0); }
  .hero__deco-chip{ opacity:1; transform:none; }
}

/* --- Contenedor centrado --- */
.hero__wrap {
  position: relative;
  z-index: 2;
  max-width: 88%;
  width: 100%;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.15fr;
  align-items: center;
  gap: 0;
}

/* --- Ocultar overlays del hero original --- */
#hero .hfb,
#hero .hgrad,
#hero .hline,
#hero .hscroll,
#hero .hstats { display: none; }

/* --- Columna de texto --- */
#hero .hcont {
  position: static;
  display: block;
  padding: 0;
  width: 100%;
  max-width: 540px;
}

.htag { color: var(--muted) !important; }
.htag-dot { background: var(--red) !important; }

.hh1 {
  color: var(--black) !important;
  font-size: clamp(2.4rem, 5vw, 4.2rem) !important;
  line-height: .93 !important;
  margin-bottom: 1.5rem !important;
}
.hh1 .si { color: var(--red) !important; }

.hsub {
  color: var(--muted) !important;
  font-size: .95rem !important;
  max-width: 420px !important;
  margin-bottom: 2.2rem !important;
}

.hbtns .btn-r {
  background: var(--black) !important;
  color: #fff !important;
  border-color: var(--black) !important;
}
.hbtns .btn-r:hover {
  background: var(--red) !important;
  border-color: var(--red) !important;
}
.hbtns .btn-g {
  color: var(--black) !important;
  border-color: var(--border) !important;
}
.hbtns .btn-g:hover {
  border-color: var(--black) !important;
}

/* --- Contadores --- */
.hero__counters {
  display: flex;
  gap: 2.5rem;
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid var(--border);
}

.hero__counter-n {
  font-family: 'Syne', sans-serif;
  font-size: 2.5rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -.03em;
  color: var(--black);
}
.hero__counter-n span:last-child {
  color: var(--red);
}

.hero__counter-l {
  font-size: .66rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: .3rem;
}

/* --- Columna de vídeo --- */
.hero__video-col {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero__video-box {
  --video-ratio: 4 / 3;
  position: relative;
  width: 100%;
  aspect-ratio: var(--video-ratio);
  overflow: hidden;
  border-radius: 4px;
}

.hero__video-box video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/*
  Máscara: una capa sólida del color de fondo (--off)
  con un agujero central via mask-image.
  El gradiente va de transparente (centro) a negro (bordes),
  lo que deja ver el fondo sólido en los bordes y el vídeo en el centro.
  Resultado: el vídeo se funde limpio en todas las direcciones.
*/
.hero__video-box::after {
  content: '';
  position: absolute;
  inset: -2px;
  pointer-events: none;
  background: var(--off);
  mask-image: radial-gradient(ellipse 72% 72% at 50% 48%, transparent 40%, black 68%);
  -webkit-mask-image: radial-gradient(ellipse 72% 72% at 50% 48%, transparent 40%, black 68%);
}

/* --- Nav siempre claro --- */
nav {
  background: rgba(255,255,255,.96) !important;
  backdrop-filter: blur(18px) !important;
  border-bottom: 1px solid var(--border) !important;
}
nav .logo { color: var(--black) !important; }
nav .nav-links a { color: var(--muted) !important; }
nav .ham span { background: var(--black) !important; }


/* ============================================
   RESPONSIVE
   ============================================ */

@media (max-width: 960px) {
  #hero {
    height: auto;
    min-height: auto;
    padding: 8rem 1.25rem 4rem;
  }
  .hero__wrap {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
  .hero__video-box {
    --video-ratio: 16 / 10;
  }
  .hero__counters {
    gap: 2rem;
  }
}

@media (max-width: 640px) {
  #hero {
    padding: 7rem 1.25rem 3rem;
  }
  .hh1 {
    font-size: clamp(2rem, 8vw, 3rem) !important;
  }
  .hero__counters {
    gap: 1.5rem;
    flex-wrap: wrap;
  }
  .hero__counter-n {
    font-size: 1.6rem;
  }
}




#hvid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hfb{position:absolute;inset:0;background:linear-gradient(115deg,#0f0f0f 0%,#1d0404 35%,rgba(0,0,0,.35) 100%);z-index:0}
.hgrad{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,rgba(0,0,0,.1) 55%);z-index:1}
.hline{position:absolute;bottom:0;left:0;right:0;height:4px;background:var(--red);z-index:10}
.hcont{position:relative;z-index:3;width:100%;padding:4rem 3rem 5rem;display:grid;grid-template-columns:1fr auto;align-items:flex-end;gap:2rem}
@media(max-width:960px){.hcont{grid-template-columns:1fr}}
@media(max-width:640px){.hcont{padding:3rem 1.25rem 4.5rem}}
.htag{display:inline-flex;align-items:center;gap:.5rem;font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:1.25rem}
.htag-dot{width:6px;height:6px;border-radius:50%;background:var(--red)}
.hh1{font-family:'Syne',sans-serif;font-size:clamp(3rem,7.5vw,5.5rem);font-weight:800;line-height:.92;letter-spacing:-.03em;color:#fff;margin-bottom:1.75rem}
.hh1 .si{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--red)}
.hsub{font-size:1rem;color:rgba(255,255,255,.6);max-width:400px;line-height:1.75;font-weight:300;margin-bottom:2.2rem}
.hbtns{display:flex;gap:1rem;flex-wrap:wrap}
.btn-r{font-family:'Syne',sans-serif;font-size:.78rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;background:var(--red);color:#fff;padding:.9rem 1.9rem;text-decoration:none;border:2px solid var(--red);transition:background .25s,color .25s,transform .2s;display:inline-block;border-radius: 30px;}
.btn-r:hover{background:transparent;color:#d42b2b;transform:translateY(-2px)}
.btn-g{border-radius: 30px;font-family:'Syne',sans-serif;font-size:.78rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;background:transparent;color:#fff;padding:.9rem 1.9rem;text-decoration:none;border:2px solid rgba(255,255,255,.3);transition:border-color .25s,transform .2s;display:inline-block}
.btn-g:hover{border-color:rgba(255,255,255,.8);transform:translateY(-2px)}
.hstats{display:flex;flex-direction:column;gap:1.75rem;text-align:right;min-width:100px}
@media(max-width:960px){.hstats{flex-direction:row;text-align:left;gap:2rem}}
.hstat-n{font-family:'Syne',sans-serif;font-size:2.4rem;font-weight:800;color:#fff;line-height:1;letter-spacing:-.04em}
.hstat-l{font-size:.66rem;color:rgba(255,255,255,.4);letter-spacing:.12em;text-transform:uppercase;margin-top:.15rem}
.hscroll{position:absolute;bottom:5.5rem;right:3rem;z-index:4;writing-mode:vertical-rl;display:flex;align-items:center;gap:.7rem;font-size:.65rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.35)}
@media(max-width:640px){.hscroll{display:none}}
.hscroll-l{width:1px;height:44px;background:rgba(255,255,255,.18);animation:sl 2s ease-in-out infinite}
@keyframes sl{0%,100%{opacity:.25;transform:scaleY(1)}50%{opacity:.7;transform:scaleY(.4)}}

/* SECTIONS */
.sec{padding:7rem 3rem}
.sec-sm{padding:5rem 3rem}
.container { max-width: 1140px; margin: 0 auto; }
@media(max-width:640px){.sec,.sec-sm{padding:4rem 1.25rem}}
.wrap{max-width:1160px;margin:0 auto}
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--red);margin-bottom:1.1rem}
.eline{width:20px;height:1px;background:var(--red)}
.stitle{font-family:'Syne',sans-serif;font-size:clamp(2rem,4.5vw,3.5rem);font-weight:800;line-height:1.05;letter-spacing:-.03em;color:var(--black)}
.stitle .si{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--red)}
.sbody{font-size:.97rem;color:var(--muted);line-height:1.8;max-width:47%}

/* ===== HOW IT WORKS ===== */
    .how { background: var(--snow); position: relative; overflow: hidden; }
    .how::before {
      content: ''; position: absolute; top: -200px; right: -200px;
      width: 500px; height: 500px; border-radius: 50%;
      background: radial-gradient(circle, var(--red-soft) 0%, transparent 70%);
      pointer-events: none;
    }
    .how__head { text-align: center; margin-bottom: 4.5rem; }
    .how__head .desc { margin: 0.5rem auto 0; }
    .how__track {
      display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem;
      position: relative;
    }
    .how__track::after {
      content: ''; position: absolute; top: 40px; left: 10%; right: 10%;
      height: 1px;
      background: linear-gradient(90deg, transparent, var(--silk), var(--red-glow), var(--silk), transparent);
    }
    @media (max-width: 900px){
      .how__track{ grid-template-columns: repeat(2, 1fr); gap: 2.5rem 1.5rem; }
      .how__track::after{ display:none; }
      .how__head{ margin-bottom:3rem; }
    }
    @media (max-width: 540px){
      .how__track{
        grid-template-columns: 1fr;
        gap: 0;
        max-width:420px;
        margin:0 auto;
      }
      .how__track .step{
        display:block;
        grid-template-columns:auto 1fr;
        gap:1.1rem;
        text-align:left;
        align-items:flex-start;
        padding:2rem 0;
        border-top:1px solid var(--border);
        position:relative;
      }
      .how__track .step:first-child{ border-top:none; }
      /* Línea vertical que conecta los pasos */
      .how__track .step:not(:last-child)::after{
        content:'';
        position:absolute;
        left:29px;
        top:70px;
        width:1px;
        height:calc(100% - 50px);
        background:linear-gradient(to bottom, var(--border), transparent);
      }
      .how__track .step__circle{
        margin:0;
        width:60px; height:60px;
        flex-shrink:0;
      }
      .how__track .step__circle svg{ width:22px; height:22px; }
      .how__track .step__n{
        width:20px; height:20px;
        font-size:.62rem;
      }
      .how__track .step__label{
        font-family:'Syne',sans-serif;
        font-weight:700;
        font-size:1rem;
        margin-top:.5rem;
        margin-bottom:.35rem;
        color:var(--black);
      }
      .how__track .step__txt{
        font-size:.85rem;
        line-height:1.6;
        color:var(--muted);
        max-width:100%;
      }
    }
    .step {
      text-align: center; position: relative; z-index: 1;
    }
    .step__circle {
      width: 80px; height: 80px; border-radius: 50%;
      background: var(--white);
      border: 1px solid var(--silk);
      display: flex; align-items: center; justify-content: center;
      margin: 0 auto 1.5rem;
      position: relative;
      transition: border-color 0.4s, box-shadow 0.4s, transform 0.4s;
    }
    .step:hover .step__circle {
      border-color: var(--red);
      box-shadow: 0 8px 30px var(--red-glow);
      transform: translateY(-4px);
    }
    .step__circle svg { width: 28px; height: 28px; stroke: var(--charcoal); stroke-width: 1.5; transition: stroke 0.3s; }
    .step:hover .step__circle svg { stroke: var(--red); }
    .step__n {
      position: absolute; top: -6px; right: -6px;
      width: 22px; height: 22px; border-radius: 50%;
      background: var(--red); color: var(--white);
      font-size: 0.65rem; font-weight: 600;
      display: flex; align-items: center; justify-content: center;
    }
    .step__label {
      font-family: var(--font-heading); font-weight: 400; font-size: 1rem;
      margin-bottom: 0.4rem; color: var(--night);
    }
    .step__txt {
      font-size: 0.85rem; font-weight: 300; line-height: 1.6; color: var(--ash);
    }

/* HOW */
#como-funciona{background:var(--off);border-top:1px solid var(--border)}
.how-top{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:end;margin-bottom:5rem}
@media(max-width:760px){.how-top{grid-template-columns:1fr;gap:1.5rem;margin-bottom:3rem}}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.steps::after{content:'';position:absolute;top:19px;left:7%;right:7%;height:1px;background:var(--border);z-index:0}
@media(max-width:760px){.steps{grid-template-columns:1fr 1fr;gap:2rem}.steps::after{display:none}}
@media(max-width:480px){.steps{grid-template-columns:1fr}}
.step{position:relative;z-index:1;padding-right:1.5rem}
.sc{width:38px;height:38px;border:1.5px solid var(--border);background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:2rem;transition:border-color .3s,background .3s}
.step:hover .sc{border-color:var(--red);background:var(--red)}
.sn{font-family:'Syne',sans-serif;font-size:.75rem;font-weight:700;color:var(--muted);transition:color .3s}
.step:hover .sn{color:#fff}
.st{font-family:'Syne',sans-serif;font-size:1rem;font-weight:700;color:var(--black);margin-bottom:.6rem}
.sd{font-size:.86rem;color:var(--muted);line-height:1.7}

/* SERVICES */
#servicios{background:#fff}
.svc-layout{display:grid;grid-template-columns:1fr 2fr;gap:5rem;align-items:start}
@media(max-width:960px){.svc-layout{grid-template-columns:1fr;gap:3rem}}
.svc-sticky{position:sticky;top:100px}
@media(max-width:960px){.svc-sticky{position:static}}
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border)}
@media(max-width:640px){.svc-grid{grid-template-columns:1fr}}
.svc-card{background:#fff;padding:2.25rem 1.75rem;position:relative;overflow:hidden;transition:background .25s}
.svc-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .35s}
.svc-card:hover{background:var(--off)}
.svc-card:hover::after{transform:scaleX(1)}
.svc-num{font-family:'Syne',sans-serif;font-size:.68rem;font-weight:700;color:var(--red);letter-spacing:.1em;margin-bottom:1.25rem}
.svc-ico{width:34px;height:34px;margin-bottom:1.1rem}
.svc-ico svg{width:100%;height:100%;stroke:var(--black);fill:none;stroke-width:1.5}
.svc-name{font-family:'Syne',sans-serif;font-size:.97rem;font-weight:700;color:var(--black);margin-bottom:.55rem}
.svc-desc{font-size:.83rem;color:var(--muted);line-height:1.7}
.svc-badge{display:inline-block;margin-top:.85rem;font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--red);background:var(--red-pale);padding:.22rem .65rem}

/* ===== SERVICE CARDS WITH BACKGROUND IMAGE ===== */
.svc-card--img{background:#111;color:#fff;isolation:isolate;min-height:320px;display:flex;flex-direction:column;justify-content:flex-end}
.svc-card--img .svc-card__bg{position:absolute;inset:0;background-image:url('/assets/images/Licencia.jpg');background-size:cover;background-position:center;z-index:0;transition:transform .9s var(--e-out),filter .6s var(--e-out)}
.svc-card--img .svc-card__bg.dos{position:absolute;inset:0;background-image:url('/assets/images/Precio.jpg');background-size:cover;background-position:center;z-index:0;transition:transform .9s var(--e-out),filter .6s var(--e-out)}
.svc-card--img .svc-card__bg.tres{position:absolute;inset:0;background-image:url('/assets/images/Expres.jpg');background-size:cover;background-position:center;z-index:0;transition:transform .9s var(--e-out),filter .6s var(--e-out)}

.svc-card--img .svc-card__scrim{position:absolute;inset:0;z-index:1;pointer-events:none}
.svc-card--img>:not(.svc-card__bg):not(.svc-card__scrim){position:relative;z-index:2}
.svc-card--img:hover{background:#111}
.svc-card--img:hover .svc-card__bg{transform:scale(1.06)}
.svc-card--img .svc-num{color:#fff;opacity:.9}
.svc-card--img .svc-ico svg{stroke:#fff}
.svc-card--img .svc-name{color:#fff;font-size:1.15rem}
.svc-card--img .svc-desc{color:rgba(255,255,255,.82)}
.svc-card--img .svc-badge{background:rgba(255,255,255,.14);color:#fff;backdrop-filter:blur(8px)}

/* Card 01 — urgencia / warm */
.svc-card--img1 .svc-card__bg{background-position:center 40%;filter:saturate(1.1) contrast(1.05)}
.svc-card--img1 .svc-card__scrim{background:
  linear-gradient(180deg,rgba(20,10,8,.15) 0%,rgba(20,10,8,.45) 50%,rgba(10,5,5,.92) 100%),
  radial-gradient(ellipse at 80% 20%,rgba(230,57,70,.35) 0%,transparent 55%)}

/* Card 04 — precio cerrado / rojo marca */
.svc-card--img4 .svc-card__bg{background-position:70% center;}
.svc-card--img4 .svc-card__scrim{background:
  linear-gradient(160deg,rgba(230,57,70,.72) 0%,rgba(180,30,45,.6) 45%,rgba(10,5,5,.9) 100%)}
.svc-card--img4 .svc-num,
.svc-card--img4 .svc-badge{color:#fff}
.svc-card--img4 .svc-badge{background:rgba(0,0,0,.3)}

/* Card 05 — exprés / cool night */
.svc-card--img5 .svc-card__bg{background-position:30% 70%;}
.svc-card--img5 .svc-card__scrim{background:
  linear-gradient(200deg,rgba(10,15,30,.35) 0%,rgba(5,8,15,.75) 60%,rgba(0,0,0,.95) 100%),
  radial-gradient(circle at 20% 90%,rgba(230,57,70,.22) 0%,transparent 50%)}

/* underline accent override for image cards */
.svc-card--img::after{background:var(--red);height:3px;z-index:3}

/* CARD SERVICES */
#svc{background:var(--off);border-top:1px solid var(--border)}
.svc__head{margin-bottom:3.5rem}
.svc__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
.card{padding:2.25rem 2rem;background:#fff;position:relative;overflow:hidden;transition:background .3s}
.card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .35s}
.card:hover{background:var(--off)}
.card:hover::after{transform:scaleX(1)}
.card__ico{width:40px;height:40px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;transition:border-color .3s,background .3s}
.card:hover .card__ico{border-color:var(--red);background:rgba(212,43,43,.08)}
.card__ico svg{width:19px;height:19px;stroke:var(--muted);stroke-width:1.5;fill:none;transition:stroke .3s}
.card:hover .card__ico svg{stroke:var(--red)}
.card__h{font-family:'Syne',sans-serif;font-weight:700;font-size:1rem;margin-bottom:.5rem;color:var(--black)}
.card__p{font-size:.85rem;font-weight:400;line-height:1.7;color:var(--muted)}
@media(max-width:960px){.svc__grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.svc__grid{grid-template-columns:1fr}}

/* WHY */
#ventajas{background:var(--black)}
.why__grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.why__grid .stitle{color:#fff}
.why__grid .sbody{color:rgba(255,255,255,.4)}
.why__list{margin-top:2.5rem;display:flex;flex-direction:column;gap:1.75rem}
.why__row{display:flex;gap:1.1rem;align-items:flex-start}
.why__dot{flex-shrink:0;width:40px;height:40px;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;transition:border-color .3s,background .3s}
.why__row:hover .why__dot{border-color:var(--red);background:rgba(212,43,43,.1)}
.why__dot svg{width:18px;height:18px;stroke:rgba(255,255,255,.5);stroke-width:1.5;fill:none;transition:stroke .3s}
.why__row:hover .why__dot svg{stroke:var(--red)}
.why__row h4{font-family:'Syne',sans-serif;font-weight:700;font-size:.95rem;margin-bottom:.2rem;color:#fff}
.why__row p{font-size:.82rem;font-weight:300;line-height:1.6;color:rgba(255,255,255,.4)}
.why__stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06)}
.stat{background:var(--black);padding:2rem 1.5rem;text-align:center;transition:background .3s}
.stat:hover{background:#111}
.stat__num{font-family:'Syne',sans-serif;font-size:2.4rem;font-weight:800;color:#fff;letter-spacing:-.04em}
.stat__num span{color:var(--red)}
.stat__lbl{font-size:.68rem;color:rgba(255,255,255,.3);letter-spacing:.12em;text-transform:uppercase;margin-top:.3rem}
@media(max-width:1024px){.why__grid{grid-template-columns:1fr;gap:3.5rem}.why__stats{order:-1;max-width:400px;margin:0 auto}}

/* FAQ */
#faq{background:#fff;border-top:1px solid var(--border)}
.faq-lay{display:grid;grid-template-columns:1fr 1.65fr;gap:6rem;align-items:start}
@media(max-width:900px){.faq-lay{grid-template-columns:1fr;gap:3rem}}
.faq-pin{position:sticky;top:100px}
@media(max-width:900px){.faq-pin{position:static}}
.faq-list{border-top:1px solid var(--border)}
.fi{border-bottom:1px solid var(--border)}
.fq{width:100%;display:flex;justify-content:space-between;align-items:center;padding:1.5rem 0;gap:1.25rem;background:none;border:none;cursor:pointer;text-align:left;font-family:'Syne',sans-serif;font-size:.93rem;font-weight:600;color:var(--black);transition:color .2s}
.fq:hover{color:var(--red)}
.ficon{flex-shrink:0;width:24px;height:24px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;transition:background .25s,border-color .25s,transform .35s}
.ficon svg{width:11px;height:11px;stroke:var(--muted);fill:none;stroke-width:2.2;transition:stroke .2s}
.fi.open .ficon{background:var(--red);border-color:var(--red);transform:rotate(45deg)}
.fi.open .ficon svg{stroke:#fff}
.fa{max-height:0;overflow:hidden;transition:max-height .45s cubic-bezier(.4,0,.2,1),padding .3s;font-size:.9rem;color:var(--muted);line-height:1.8}
.fi.open .fa{max-height:260px;padding-bottom:1.5rem}

/* MAP */
#cobertura{background:var(--off);border-top:1px solid var(--border)}
.map__layout{display:grid;grid-template-columns:1.4fr .6fr;gap:3rem;align-items:start;max-width:1060px;margin:0 auto;margin-top:4rem}
.map__canvas-wrap{position:relative}
#spainCanvas{width:100%;height:auto;display:block}
.map-tooltip{position:absolute;z-index:10;background:var(--white);color:var(--text);padding:.75rem 1.15rem;border-radius:0;font-size:.8rem;font-weight:400;pointer-events:none;opacity:0;transform:translateY(6px);transition:opacity .25s,transform .25s;white-space:nowrap;box-shadow:0 8px 32px rgba(0,0,0,.1);border:1px solid var(--border)}
.map-tooltip::after{content:'';position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--white)}
.map-tooltip.show{opacity:1;transform:translateY(0)}
.map-tooltip strong{font-weight:700;color:var(--red)}
.map__sidebar{padding-top:.5rem}
.map__sidebar-title{font-family:'Syne',sans-serif;font-weight:800;font-size:1.05rem;color:var(--black);margin-bottom:1.25rem}
.map__sidebar-title em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--red)}
.map__city-list{display:flex;flex-direction:column;gap:.3rem}
.city-row{display:flex;align-items:center;gap:.75rem;padding:.6rem .85rem;cursor:pointer;transition:all .25s;border:1px solid transparent}
.city-row:hover,.city-row.active{background:var(--red-pale);border-color:rgba(212,43,43,.12)}
.city-row__dot{width:5px;height:5px;border-radius:50%;background:var(--red);flex-shrink:0}
.city-row__name{font-size:.85rem;font-weight:600;color:var(--black);flex:1;transition:color .3s}
.city-row__info{font-size:.68rem;font-weight:500;color:var(--muted);text-align:right;white-space:nowrap}
.city-row:hover .city-row__name,.city-row.active .city-row__name{color:var(--red)}
@media(max-width:860px){
  .map__layout{grid-template-columns:1fr;gap:2rem}
  .map__sidebar{order:-1}
  .map__city-list{flex-direction:row;flex-wrap:wrap;gap:.4rem}
  .city-row{padding:.4rem .75rem;border:1px solid var(--border);background:var(--off)}
  .city-row__info{display:none}
}

/* CONTACT */
#contacto{background:#fff;border-top:1px solid var(--border)}
.ct-lay{display:grid;grid-template-columns:1fr 1.5fr;gap:6rem;align-items:start;margin-top:4rem}
@media(max-width:900px){.ct-lay{grid-template-columns:1fr;gap:3rem}}
.ci{display:flex;gap:1.1rem;align-items:flex-start;padding:1.4rem 0;border-bottom:1px solid var(--border)}
.cico{width:40px;height:40px;flex-shrink:0;border:1px solid var(--border);display:flex;align-items:center;justify-content:center}
.cico svg{width:17px;height:17px;stroke:var(--red);fill:none;stroke-width:1.5}
.cl{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.25rem}
.cv{font-size:.93rem;font-weight:500;color:var(--black)}
.ff{margin-bottom:1.15rem}
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:640px){.fr2{grid-template-columns:1fr}}
.ff label{display:block;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.45rem}
.ff input,.ff select,.ff textarea{width:100%;padding:.85rem 1rem;border:1px solid var(--border);background:var(--off);font-family:'Manrope',sans-serif;font-size:.9rem;color:var(--black);outline:none;transition:border-color .25s,background .25s;border-radius:0}
.ff input:focus,.ff select:focus,.ff textarea:focus{border-color:var(--black);background:#fff}
.ff textarea{resize:vertical;min-height:118px}
.sbtn{border-radius: 30px; width:100%;font-family:'Syne',sans-serif;font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:var(--black);border:2px solid var(--black);padding:1.05rem;cursor:pointer;transition:background .25s,border-color .25s,transform .2s;display:flex;align-items:center;justify-content:center;gap:.65rem}
.sbtn:hover{background:var(--red);border-color:var(--red);transform:translateY(-2px)}
.sbtn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .2s}
.sbtn:hover svg{transform:translateX(4px)}

.ffPolitica label{
    display: flex;
    align-items: end;
    margin: 0 0 20px;
}
.ffPolitica label > div{
  margin-right: 7px;
}

/* FOOTER */
/* ============================================
   LEGAL PAGES (privacidad, aviso, cookies)
   ============================================ */
.legal{
  padding: 9rem 3rem 6rem;
  max-width: 980px;
  margin: 0 auto;
  color: var(--text);
}
.legal-eyebrow{
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:'Syne',sans-serif;
  font-size:.72rem; font-weight:700;
  letter-spacing:.16em; text-transform:uppercase;
  color: var(--red);
  margin-bottom: 1.25rem;
}
.legal-eyebrow::before{
  content:''; width:26px; height:1.5px; background:var(--red);
}
.legal h1{
  font-family:'Syne',sans-serif;
  font-size: clamp(2.2rem, 5vw, 3.4rem);
  font-weight: 800;
  line-height: 1.02;
  letter-spacing: -.03em;
  color: var(--black);
  margin-bottom: 1.25rem;
}
.legal h1 .si{
  font-family:'Instrument Serif',serif;
  font-style: italic;
  font-weight: 400;
  color: var(--red);
}
.legal__intro{
  font-size: 1.05rem;
  color: var(--muted);
  line-height: 1.7;
  padding-bottom: 2.25rem;
  border-bottom: 1px solid var(--border);
  margin-bottom: 3rem;
}
.legal__updated{
  display:inline-block;
  margin-top: 1.25rem;
  font-size:.72rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  color: var(--muted);
}
.legal h2{
  font-family:'Syne',sans-serif;
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--black);
  margin: 3rem 0 1rem;
  letter-spacing: -.01em;
  position: relative;
  padding-left: 1.25rem;
}
.legal h2::before{
  content:''; position:absolute; left:0; top:.45em; bottom:.45em;
  width: 3px; background: var(--red); border-radius: 2px;
}
.legal h3{
  font-family:'Syne',sans-serif;
  font-size: 1rem;
  font-weight: 700;
  color: var(--black);
  margin: 1.75rem 0 .6rem;
}
.legal p{
  font-size: .95rem;
  line-height: 1.8;
  color: var(--text);
  margin-bottom: 1.1rem;
}
.legal ul, .legal ol{
  margin: 0 0 1.25rem 1.35rem;
  padding: 0;
}
.legal li{
  font-size: .95rem;
  line-height: 1.75;
  margin-bottom: .5rem;
  color: var(--text);
}
.legal strong{ color: var(--black); font-weight: 700; }
.legal a{
  color: var(--red);
  text-decoration: none;
  border-bottom: 1px solid rgba(212,43,43,.3);
  transition: border-color .25s, color .25s;
}
.legal a:hover{ color: var(--red-dark); border-color: var(--red); }
.legal__contact{
  margin-top: 2rem;
  padding: 1.5rem 1.75rem;
  background: var(--off);
  border-left: 3px solid var(--red);
  border-radius: 2px;
}
.legal__contact p{ margin: 0 0 .4rem; font-size: .9rem; }
.legal__contact p:last-child{ margin-bottom: 0; }
.legal__table{
  width: 100%;
  border-collapse: collapse;
  margin: 1rem 0 1.5rem;
  font-size: .88rem;
  border: 1px solid var(--border);
}
.legal__table th,
.legal__table td{
  padding: .85rem 1rem;
  text-align: left;
  border-bottom: 1px solid var(--border);
  vertical-align: top;
}
.legal__table th{
  background: var(--off);
  font-family:'Syne',sans-serif;
  font-size: .74rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--black);
}
.legal__table tr:last-child td{ border-bottom: 0; }
.legal__back{
  display:inline-flex; align-items:center; gap:.55rem;
  margin-top: 3rem;
  font-family:'Syne',sans-serif;
  font-size:.78rem; font-weight:700;
  letter-spacing:.12em; text-transform:uppercase;
  color: var(--black);
  text-decoration: none;
  padding: .85rem 1.35rem;
  border: 1.5px solid var(--black);
  border-radius: 40px;
  transition: background .3s, color .3s, transform .3s;
}
.legal__back:hover{ background: var(--black); color: #fff; transform: translateX(-4px); }
.legal__back::before{ content:'←'; font-size: 1rem; line-height: 1; }
@media (max-width: 640px){
  .legal{ padding: 7rem 1.25rem 4rem; }
  .legal h2{ font-size: 1.15rem; }
}

footer{background:var(--black);padding:2.75rem 3rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;border-top:3px solid var(--red)}
@media(max-width:640px){footer{flex-direction:column;text-align:center;padding:2rem 1.25rem}}
.flogo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.25rem;color:#fff;text-decoration:none}
.flogo em{color:var(--red);font-style:normal}
footer p{font-size:.75rem;color:rgba(255,255,255,.3)}
footer a{color:rgba(255,255,255,.3);text-decoration:none}
footer a:hover{color:var(--red)}
.flinks{display:flex;gap:1.5rem}

/* REVEAL */
.fu{opacity:0;transform:translateY(26px);transition:opacity .65s cubic-bezier(.4,0,.2,1),transform .65s cubic-bezier(.4,0,.2,1)}
.fu.in{opacity:1;transform:none}
.fl{opacity:0;transform:translateX(-22px);transition:opacity .65s cubic-bezier(.4,0,.2,1),transform .65s cubic-bezier(.4,0,.2,1)}
.fl.in{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}




/* Mapa */

.wrap--map{
  max-width:1660px;
  width:100%;
  margin:0 auto;
}

.map__layout{
  display:flex;
  align-items:flex-start;
  justify-content:center;
  gap:100px;
}

.map__canvas-wrap{
  position:relative;
  flex:0 0 68%;
  max-width:68%;
}

.map__stage{
  position:relative;
  width:100%;
  max-width:980px; /* más protagonista */
  margin:0;
}

.map__svg-base,
.map__stage img{
  display:block;
  width:100%;
  height:auto;
}

#spainCanvas{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:block;
  z-index:2;
}

.map__sidebar{
  flex:0 0 32%;
  max-width:32%;
}

.map-tooltip{
  position:absolute;
  z-index:5;
}

@media (max-width: 1200px){
  .wrap--map{
    max-width:100%;
  }

  .map__layout{
    gap:40px;
  }

  .map__canvas-wrap{
    flex:0 0 62%;
    max-width:62%;
  }

  .map__sidebar{
    flex:0 0 38%;
    max-width:38%;
  }

  .map__stage{
    max-width:100%;
  }
}

@media (max-width: 1024px){
  .map__layout{
    flex-direction:column;
    gap:32px;
  }

  .map__canvas-wrap,
  .map__sidebar{
    flex:0 0 100%;
    max-width:100%;
  }
}

.wrap--map{
  max-width:1660px;
  width:100%;
  margin:0 auto;
}

.map__head{
  max-width:1060px;
  margin:0 auto 48px;
}

/* =====================================================
   INCIDENCIAS — cinematic full-bleed (bg video + columns)
   ===================================================== */
.inc{
  position:relative;
  overflow:hidden;
  background:#0b0b0d;
  color:#fff;
  min-height:clamp(620px, 88vh, 860px);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:5rem 3rem 0;
  isolation:isolate;
  border-top:1px solid var(--border);
}

.inc__bg{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  object-position:center;
  z-index:-2;
  filter:brightness(.55) contrast(1.1) saturate(1.05);
  transform:scale(1.04);
  transition: transform 8s var(--e-out);
}
.inc:hover .inc__bg{ transform:scale(1.06); }

/* Scrim principal: refuerza lecturabilidad arriba (título) y abajo (columnas) */
.inc__scrim{
  position:absolute; inset:0; z-index:-1;
  background:
    /* Banda superior (título) */
    linear-gradient(180deg, rgba(11,11,13,.85) 0%, rgba(11,11,13,.45) 28%, rgba(11,11,13,0) 50%),
    /* Banda inferior (columnas) */
    linear-gradient(0deg, rgba(11,11,13,.92) 0%, rgba(11,11,13,.75) 18%, rgba(11,11,13,.3) 38%, rgba(11,11,13,0) 55%),
    /* Empuje lateral izquierdo para texto */
    linear-gradient(90deg, rgba(11,11,13,.55) 0%, rgba(11,11,13,0) 40%);
  pointer-events:none;
}

.inc__top{
  position:relative;
  max-width:720px;
  margin:0 0 2rem;
}
.inc__eyebrow{
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:'Manrope',sans-serif;
  font-size:.72rem; font-weight:700;
  letter-spacing:.18em; text-transform:uppercase;
  color:#fff;
  margin-bottom:1.25rem;
  text-shadow:0 1px 12px rgba(0,0,0,.6);
}
.inc__eye-dot{
  width:22px; height:1px;
  background:var(--red);
}

.inc__title{
  font-family:'Syne',sans-serif;
  font-weight:800;
  font-size:clamp(2.2rem, 5vw, 4rem);
  line-height:1.02;
  letter-spacing:-.03em;
  color:#fff;
  margin-bottom:1.25rem;
  text-shadow:
    0 2px 14px rgba(0,0,0,.55),
    0 1px 40px rgba(0,0,0,.35);
}
.inc__title-i{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-weight:400;
  color:var(--red);
}
.inc__sub{
  font-size:1rem;
  line-height:1.75;
  color:rgba(255,255,255,.92);
  max-width:560px;
  font-weight:400;
  text-shadow:0 1px 16px rgba(0,0,0,.7);
}

/* COLUMNAS AL PIE (estilo referencia cinematográfica) */
.inc__cols{
  position:relative;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:0;
  padding:3rem 0 3.5rem;
}
.inc-col{
  position:relative;
  padding:2rem 1.5rem 0;
  opacity:0;
  transform:translateY(30px);
  transition: opacity .85s var(--e-out), transform .85s var(--e-out);
}
.inc__cols.in .inc-col{ opacity:1; transform:none; }
.inc__cols.in .inc-col:nth-child(1){ transition-delay:.05s; }
.inc__cols.in .inc-col:nth-child(2){ transition-delay:.18s; }
.inc__cols.in .inc-col:nth-child(3){ transition-delay:.31s; }
.inc__cols.in .inc-col:nth-child(4){ transition-delay:.44s; }

.inc-col + .inc-col::before{
  content:'';
  position:absolute;
  left:0;
  top:-200px;
  bottom:-10px;
  width:1px;
  background: linear-gradient(
    to bottom,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,.18) 20%,
    rgba(255,255,255,.22) 80%,
    rgba(255,255,255,0) 100%
  );
  pointer-events:none;
}

.inc-col__n{
  display:inline-block;
  font-family:'Syne',sans-serif;
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.22em;
  color:var(--red);
  margin-bottom:1rem;
  position:relative;
  padding-left:28px;
}
.inc-col__n::before{
  content:'';
  position:absolute;
  left:0; top:50%;
  width:20px; height:1px;
  background:var(--red);
  transform:translateY(-50%);
}
.inc-col__h{
  font-family:'Syne',sans-serif;
  font-weight:700;
  font-size:1.05rem;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:#fff;
  margin-bottom:.9rem;
  line-height:1.2;
  text-shadow:0 1px 14px rgba(0,0,0,.55);
  transition: color .35s var(--e-out), transform .5s var(--e-out);
}
.inc-col:hover .inc-col__h{ color:var(--red); transform:translateX(3px); }
.inc-col__p{
  font-size:.85rem;
  line-height:1.7;
  color:rgba(255,255,255,.88);
  font-weight:400;
  max-width:280px;
  text-shadow:0 1px 12px rgba(0,0,0,.65);
}

/* ===== RESPONSIVE de la sección ===== */
@media (max-width:1100px){
  .inc{ padding:4.5rem 2rem 0; min-height:clamp(560px, 80vh, 780px); }
  .inc__cols{ padding:2.5rem 0 3rem; }
}
@media (max-width:960px){
  .inc{ padding:4rem 2rem 0; min-height:clamp(520px, 78vh, 720px); }
  .inc__cols{ grid-template-columns:repeat(2, 1fr); padding:2.25rem 0 2.75rem; column-gap:.25rem; row-gap:1.75rem; }
  .inc-col:nth-child(3)::before{ display:none; }
  .inc-col{ padding:1.5rem 1.1rem 0; }
  .inc-col__p{ max-width:100%; }
  /* divisor vertical acortado para evitar saltar a zona clara */
  .inc-col + .inc-col::before{ top:-40px; bottom:-20px; }
}
@media (max-width:680px){
  .inc{
    padding:3.5rem 1.25rem 0;
    min-height:auto;
    justify-content:flex-start;
  }
  .inc__bg{ object-position:60% center; filter:brightness(.45) contrast(1.1); }
  .inc__scrim{
    background:
      linear-gradient(180deg, rgba(11,11,13,.9) 0%, rgba(11,11,13,.55) 30%, rgba(11,11,13,.5) 60%, rgba(11,11,13,.95) 100%);
  }
  .inc__top{ margin-bottom:3rem; padding-top:.5rem; }
  .inc__cols{
    grid-template-columns:1fr;
    padding:1rem 0 2.5rem;
    gap:0;
  }
  .inc-col{
    padding:1.35rem 0;
    border-top:1px solid rgba(255,255,255,.16);
    transform:translateY(18px);
  }
  .inc-col + .inc-col::before{ display:none; }
  .inc-col:first-child{ border-top:none; padding-top:.5rem; }
  .inc-col__n{ margin-bottom:.65rem; }
  .inc-col__h{ font-size:1rem; }
  .inc-col__p{ font-size:.88rem; }
}

/* --- DEPRECATED deck/card/widget (se mantiene vacío para no romper nada) --- */
/* =====================================================
   PROFESSIONAL MOTION LAYER — global transitions & reveals
   ===================================================== */

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
}

/* Smooth scrolling refined */
html{ scroll-behavior:smooth; }
@supports (scroll-behavior:smooth){ html{ scroll-padding-top:80px; } }

/* Unified easing variables */
:root{
  --e-out: cubic-bezier(.22, 1, .36, 1);
  --e-in-out: cubic-bezier(.65, 0, .35, 1);
  --e-spring: cubic-bezier(.34, 1.56, .64, 1);
}

/* Nav polish — compress + soft background on scroll */
nav{
  transition: background .5s var(--e-out), border-color .5s var(--e-out), height .4s var(--e-out), padding .4s var(--e-out), box-shadow .5s var(--e-out) !important;
}
nav.scrolled{
  height:60px !important;
  box-shadow: 0 10px 30px -18px rgba(0,0,0,.08) !important;
}
.nav-links a{
  position:relative;
  transition: color .35s var(--e-out);
}
.nav-links a::after{
  content:'';
  position:absolute; left:0; right:0; bottom:-6px;
  height:1px; background:var(--red);
  transform: scaleX(0); transform-origin:right;
  transition: transform .45s var(--e-out);
}
.nav-links a:hover::after{ transform: scaleX(1); transform-origin:left; }

/* Buttons — refined micro-interactions */
.btn-r, .btn-g, .nav-cta, .sbtn, .inc-widget__btn{
  position:relative;
  overflow:hidden;
  transition: background .35s var(--e-out), color .35s var(--e-out), border-color .35s var(--e-out), transform .45s var(--e-out), box-shadow .45s var(--e-out) !important;
  will-change: transform;
}
.btn-r::before, .sbtn::before, .nav-cta::before{
  content:'';
  position:absolute;
  top:50%; left:50%;
  width:0; height:0;
  background: rgba(255,255,255,.18);
  border-radius:50%;
  transform: translate(-50%,-50%);
  transition: width .6s var(--e-out), height .6s var(--e-out);
  pointer-events:none;
}
.btn-r:hover::before, .sbtn:hover::before, .nav-cta:hover::before{
  width:320px; height:320px;
}
.btn-r:hover, .sbtn:hover, .inc-widget__btn:hover{
  transform: translateY(-3px);
  box-shadow:0 16px 34px -14px rgba(212,43,43,.5);
}
.btn-g:hover{ transform: translateY(-3px); }

/* Reveal system — fu/fl/fr with smoother curve + distance */
.fu{ opacity:0; transform: translateY(36px); transition: opacity .85s var(--e-out), transform .85s var(--e-out); }
.fu.in{ opacity:1; transform: none; }
.fl{ opacity:0; transform: translateX(-32px); transition: opacity .85s var(--e-out), transform .85s var(--e-out); }
.fl.in{ opacity:1; transform: none; }
.fr{ opacity:0; transform: translateX(32px); transition: opacity .85s var(--e-out), transform .85s var(--e-out); }
.fr.in{ opacity:1; transform: none; }

/* Auto-stagger direct children of .stagger containers */
.stagger > *{
  opacity:0;
  transform: translateY(28px);
  transition: opacity .75s var(--e-out), transform .75s var(--e-out);
  transition-delay: calc(var(--i, 0) * 90ms);
}
.stagger.in > *{ opacity:1; transform:none; }

/* How-steps nicer entry */
.how__track .step{
  opacity:0; transform: translateY(28px);
  transition: opacity .75s var(--e-out), transform .75s var(--e-out);
}
.how__track.in .step{ opacity:1; transform:none; }
.how__track.in .step:nth-child(1){ transition-delay:.05s; }
.how__track.in .step:nth-child(2){ transition-delay:.18s; }
.how__track.in .step:nth-child(3){ transition-delay:.31s; }
.how__track.in .step:nth-child(4){ transition-delay:.44s; }

.step__circle{ transition: border-color .45s var(--e-out), transform .55s var(--e-spring), box-shadow .5s var(--e-out); }
.step:hover .step__circle{ transform: translateY(-5px) scale(1.05); }

/* Service cards — refined */
.svc-card, .card{
  transition: background .4s var(--e-out), transform .55s var(--e-out), box-shadow .5s var(--e-out);
  will-change: transform;
}
.svc-card:hover, .card:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 40px -20px rgba(0,0,0,.12);
}
.svc-card::after, .card::after{ transition: transform .5s var(--e-out) !important; }

/* Why rows — slide-in on parent reveal */
.why__list .why__row{
  opacity:0; transform: translateX(-18px);
  transition: opacity .7s var(--e-out), transform .7s var(--e-out);
}
.why__list.in .why__row{ opacity:1; transform:none; }
.why__list.in .why__row:nth-child(1){ transition-delay:.05s; }
.why__list.in .why__row:nth-child(2){ transition-delay:.17s; }
.why__list.in .why__row:nth-child(3){ transition-delay:.29s; }
.why__list.in .why__row:nth-child(4){ transition-delay:.41s; }
.why__row{ transition: transform .45s var(--e-out); }
.why__row:hover{ transform: translateX(4px); }
.why__dot{ transition: border-color .4s var(--e-out), background .4s var(--e-out), transform .5s var(--e-spring); }
.why__row:hover .why__dot{ transform: rotate(-6deg) scale(1.08); }

/* Stats numbers subtle rise */
.stat{ transition: background .4s var(--e-out), transform .5s var(--e-out); }
.stat:hover{ transform: translateY(-3px); }

/* FAQ smoother open */
.fa{ transition: max-height .55s var(--e-in-out), padding .4s var(--e-out); }
.fq{ transition: color .3s var(--e-out), padding-left .4s var(--e-out); }
.fq:hover{ padding-left:.25rem; }
.ficon{ transition: background .35s var(--e-out), border-color .35s var(--e-out), transform .5s var(--e-spring); }

/* Contact fields — refined focus */
.ff input, .ff select, .ff textarea{
  transition: border-color .35s var(--e-out), background .35s var(--e-out), box-shadow .4s var(--e-out), transform .35s var(--e-out) !important;
}
.ff input:focus, .ff select:focus, .ff textarea:focus{
  border-color: var(--black);
  background:#fff;
  box-shadow: 0 8px 24px -12px rgba(0,0,0,.12);
}
.ci{ transition: transform .45s var(--e-out), border-color .35s var(--e-out); }
.ci:hover{ transform: translateX(3px); }
.cico{ transition: border-color .35s var(--e-out), background .35s var(--e-out), transform .5s var(--e-spring); }
.ci:hover .cico{ border-color:var(--red); background:var(--red-pale); transform:rotate(-4deg) scale(1.05); }

/* City rows map */
.city-row{ transition: background .35s var(--e-out), border-color .35s var(--e-out), transform .35s var(--e-out), padding-left .35s var(--e-out) !important; }
.city-row:hover{ transform: translateX(4px); }
.city-row__dot{ transition: transform .5s var(--e-spring), box-shadow .4s var(--e-out); }
.city-row:hover .city-row__dot{ transform: scale(1.6); box-shadow: 0 0 0 4px var(--red-soft); }

/* Custom cursor smoother */
#cur, #curl{
  transition: width .35s var(--e-out), height .35s var(--e-out), opacity .35s var(--e-out), background .35s var(--e-out), border-color .35s var(--e-out) !important;
  will-change: transform, left, top;
}

/* Hero video subtle parallax-ready */
.hero__video-box{ transition: transform .8s var(--e-out); }
.hero__video-box video{ transition: transform 1.2s var(--e-out); }
.hero__video-col:hover .hero__video-box video{ transform: scale(1.03); }

/* Logo hover */
.logo{ transition: color .35s var(--e-out), letter-spacing .5s var(--e-out); }
.logo:hover{ letter-spacing:-.015em; }
.logo em{ transition: color .3s var(--e-out); }

/* Footer link shimmer */
footer a{ transition: color .35s var(--e-out), transform .4s var(--e-out); display:inline-block; }
footer a:hover{ transform: translateY(-2px); }

/* Section titles — subtle underline grow */
.stitle{ position:relative; }

/* Counters pulse on enter */
.hero__counter-n{ transition: transform .6s var(--e-spring); }
.hero__counter-n.bump{ transform: scale(1.06); }

/* Scroll progress bar (optional decorative top bar) */
.scroll-progress{
  position:fixed; top:0; left:0; height:2px;
  width:var(--p, 0%);
  background:linear-gradient(90deg, var(--red), #ff5a47);
  z-index:1000; pointer-events:none;
  transition: width .08s linear;
}