/* ---------- Tokens ---------- */
:root{
  --red: #E21C21;
  --red-dark: #B7161A;
  --white: #FFFFFF;
  --black: #111111;
  --gray-900: #1A1A1A;
  --gray-800: #2B2B2B;
  --gray-700: #3A3A3A;
  --gray-500: #5A5A5A;
  --gray-300: #C8C8C8;
  --gray-200: #E5E5E5;
  --gray-100: #F4F4F4;
  --gray-50: #FAFAFA;

  --display: "Oswald", "Barlow Condensed", "Arial Narrow", sans-serif;
  --body: "Montserrat", system-ui, -apple-system, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;

  --container: 1240px;
  --r-sm: 4px;
  --r-md: 8px;
  --r-lg: 14px;

  --header-h: 76px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family: var(--body);
  color: var(--gray-800);
  background: var(--white);
  line-height: 1.6;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* ---------- Typography ---------- */
h1,h2,h3{
  font-family: var(--display);
  color: var(--black);
  line-height: 1.2;
  letter-spacing: 0.01em;
  text-wrap: balance;
  font-weight: 600;
  text-transform: uppercase;
}
h1{font-size: clamp(44px, 6.4vw, 84px); font-weight:700; letter-spacing:.005em}
h2{font-size: clamp(30px, 3.6vw, 48px); font-weight:600}
h3{font-size: clamp(18px, 1.5vw, 22px); font-weight:500; letter-spacing:.04em}
p{text-wrap:pretty}
.eyebrow{
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--red);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.eyebrow::before{
  content:"";
  width: 28px; height:1px; background: var(--red);
}

/* ---------- Container ---------- */
.container{
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: 24px;
}

section{padding: clamp(64px, 8vw, 120px) 0; position: relative; overflow: hidden;}
section > .container{ position: relative; z-index: 2 }

/* Subtle institutional grid for light sections */
.trust-strip::before,
.s-intro::before,
.sector-section::before,
.s-includes::before,
.s-why::before,
.coverage::before,
.clients-section::before,
.faq-section::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(17,17,17,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(17,17,17,.04) 1px, transparent 1px);
  background-size: 88px 88px;
  pointer-events:none;
  mask-image: radial-gradient(ellipse 85% 75% at 85% 25%, #000 0%, transparent 75%);
  z-index: 1;
}

/* Section heads */
.section-head{ position: relative }
.section-head .eyebrow{ position: relative; padding-left: 0 }

/* ---------- Buttons ---------- */
.btn{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--display);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: 14px;
  padding: 16px 28px;
  border-radius: var(--r-sm);
  transition: all .25s ease;
  border: 1px solid transparent;
  cursor: pointer;
  white-space: nowrap;
}
.btn-primary{
  background: var(--red);
  color: #fff;
  box-shadow: 0 4px 14px rgba(226,28,33,.25);
}
.btn-primary:hover{ background: var(--red-dark); transform: translateY(-1px); box-shadow: 0 8px 22px rgba(226,28,33,.35) }
.btn-ghost{
  background: transparent;
  color: var(--white);
  border-color: rgba(255,255,255,.3);
}
.btn-ghost:hover{ border-color: var(--white); background: rgba(255,255,255,.08) }
.btn-dark{
  background: var(--black);
  color: #fff;
}
.btn-dark:hover{ background: var(--gray-800) }
.btn-outline{
  background: transparent;
  color: var(--black);
  border: 1px solid var(--black);
}
.btn-outline:hover{ background: var(--black); color: #fff }
.btn .arrow{
  display: inline-block;
  width: 18px; height: 10px;
  position: relative;
  transition: transform .25s ease;
}
.btn .arrow::after{
  content:"";
  position:absolute;
  inset: 0 0 auto 0;
  top: 4px;
  height: 1.5px;
  background: currentColor;
}
.btn .arrow::before{
  content:"";
  position:absolute;
  right: 0; top: 0;
  width: 8px; height: 8px;
  border-top: 1.5px solid currentColor;
  border-right: 1.5px solid currentColor;
  transform: rotate(45deg);
}
.btn:hover .arrow{ transform: translateX(4px) }

/* ---------- Header ---------- */
.site-header{
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--header-h);
  z-index: 100;
  background: rgba(17,17,17,.92);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,255,255,.08);
  transition: background .3s ease;
}
.site-header.scrolled{
  background: rgba(255,255,255,.96);
  border-bottom-color: var(--gray-200);
}
.header-inner{
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
}
.brand{
  display: flex;
  align-items: center;
  gap: 12px;
}
.brand-logo{
  height: 52px;
  width: auto;
  display: block;
  image-rendering: -webkit-optimize-contrast;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,.25));
  transition: filter .25s ease;
}
.site-header:not(.scrolled) .brand-logo{
  filter: drop-shadow(0 2px 8px rgba(0,0,0,.45));
}
.brand-logo--footer{
  height: 72px;
  filter: drop-shadow(0 2px 10px rgba(226,28,33,.25));
}

.nav{
  display: flex;
  align-items: center;
  gap: 4px;
}
.nav a{
  font-family: var(--body);
  font-size: 13px;
  font-weight: 500;
  color: rgba(255,255,255,.78);
  padding: 8px 14px;
  border-radius: 3px;
  transition: color .2s;
  position: relative;
}
.site-header.scrolled .nav a{color: var(--gray-700)}
.nav a:hover{color: #fff}
.site-header.scrolled .nav a:hover{color: var(--red)}
.nav a.active{color: #fff}
.site-header.scrolled .nav a.active{color: var(--black)}

/* Mega menu */
.nav .has-mega{ position: static }
.nav .nav-link{
  font-family: var(--body);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: .04em;
  color: rgba(255,255,255,.85);
  padding: 8px 14px;
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  background: none;
  border: none;
  font-family: inherit;
  transition: color .25s;
}
.site-header.scrolled .nav .nav-link{ color: var(--gray-700) }
.nav .nav-link:hover,
.nav .has-mega:hover .nav-link,
.nav .has-mega.open .nav-link{ color: #fff }
.site-header.scrolled .nav .nav-link:hover,
.site-header.scrolled .nav .has-mega:hover .nav-link,
.site-header.scrolled .nav .has-mega.open .nav-link{ color: var(--red) }
.nav .nav-link.active{ color: #fff }
.site-header.scrolled .nav .nav-link.active{ color: var(--black) }
.nav .caret{
  width: 8px; height: 8px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg) translate(-2px,-2px);
  transition: transform .25s ease;
  display: inline-block;
}
.nav .has-mega:hover .caret,
.nav .has-mega.open .caret{ transform: rotate(-135deg) translate(-2px,-2px) }

.mega-menu{
  position: absolute;
  left: 0; right: 0;
  top: 100%;
  background: #fff;
  border-top: 1px solid var(--gray-200);
  box-shadow: 0 30px 60px -20px rgba(0,0,0,.25);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: opacity .28s ease, transform .28s ease, visibility .28s;
  z-index: 200;
}
.nav .has-mega:hover .mega-menu,
.nav .has-mega.open .mega-menu,
.mega-menu:hover{
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.mega-inner{
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 40px;
  padding: 38px 24px 44px;
  max-width: var(--container);
  margin: 0 auto;
}
.mega-side{
  border-right: 1px solid var(--gray-200);
  padding-right: 32px;
}
.mega-side .eyebrow{ color: var(--red); margin-bottom: 16px }
.mega-side h3{
  font-family: var(--display);
  font-size: 24px;
  text-transform: uppercase;
  letter-spacing: .02em;
  color: var(--black);
  line-height: 1.1;
  margin-bottom: 14px;
}
.mega-side p{
  font-size: 13px;
  line-height: 1.6;
  color: var(--gray-500);
  margin-bottom: 22px;
}
.mega-side .btn{ padding: 11px 18px; font-size: 11px }
.mega-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--gray-200);
  border: 1px solid var(--gray-200);
}
.mega-card{
  background: #fff;
  padding: 22px 22px 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  text-decoration: none;
  color: inherit;
  position: relative;
  transition: background .25s, color .25s;
  min-height: 124px;
}
.mega-card .ix{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  color: var(--gray-300);
}
.mega-card h4{
  font-family: var(--display);
  font-size: 15px;
  text-transform: uppercase;
  letter-spacing: .03em;
  color: var(--black);
  line-height: 1.15;
  margin: 0;
}
.mega-card p{
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--gray-500);
  margin: 0;
}
.mega-card::after{
  content:"→";
  position: absolute;
  top: 22px; right: 22px;
  font-family: var(--mono);
  font-size: 14px;
  color: var(--gray-300);
  transition: color .25s, transform .25s;
}
.mega-card:hover{
  background: var(--gray-100);
}
.mega-card:hover h4{ color: var(--red) }
.mega-card:hover::after{ color: var(--red); transform: translateX(4px) }
@media (max-width: 980px){
  .nav .has-mega:hover .mega-menu,
  .nav .has-mega.open .mega-menu{ display: none }
  .mega-menu{ display: none }
}

.header-cta{display:flex;align-items:center;gap:12px}
.header-cta .btn{padding: 11px 20px;font-size:12px}

.menu-toggle{
  display: none;
  width: 44px; height: 44px;
  align-items: center;
  justify-content: center;
  color: #fff;
  border-radius: var(--r-sm);
  transition: background .2s, color .2s;
  flex-shrink: 0;
}
.site-header.scrolled .menu-toggle{color: var(--black)}
.menu-toggle:hover{ background: rgba(255,255,255,.1) }
.site-header.scrolled .menu-toggle:hover{ background: var(--gray-100) }
.menu-toggle svg{width:22px;height:22px}

/* Mobile nav overlay */
.mobile-nav{
  position: fixed;
  top: var(--header-h);
  left: 0; right: 0;
  bottom: 0;
  background: #111111;
  z-index: 99;
  transform: translateX(100%);
  transition: transform .38s cubic-bezier(.4,0,.2,1);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.mobile-nav.open{ transform: translateX(0) }

/* Mobile nav inner padding */
.mobile-nav-inner{
  padding: 24px 0 48px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

/* Top CTA area */
.mobile-nav-cta{
  padding: 20px 24px 24px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.mobile-nav-cta .btn{
  width: 100%;
  justify-content: center;
  font-size: 13px;
  padding: 14px 20px;
}

/* Section label */
.mob-section-label{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--red);
  padding: 20px 24px 8px;
  display: block;
}

/* Nav links */
.mobile-nav a{
  color: rgba(255,255,255,.88);
  padding: 15px 24px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  font-family: var(--display);
  text-transform: uppercase;
  letter-spacing: .06em;
  font-size: 17px;
  display: flex;
  align-items: center;
  gap: 12px;
  transition: color .2s, background .2s;
  position: relative;
}
.mobile-nav a::after{
  content: "→";
  margin-left: auto;
  font-size: 14px;
  color: rgba(255,255,255,.3);
  transition: transform .2s, color .2s;
}
.mobile-nav a:hover,
.mobile-nav a.mob-active{
  color: #fff;
  background: rgba(255,255,255,.04);
}
.mobile-nav a:hover::after{ transform: translateX(4px); color: var(--red) }
.mobile-nav a.mob-active{ color: var(--red) }
.mobile-nav a.mob-active::before{
  content:"";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--red);
}

/* Service sub-links inside mobile nav */
.mobile-nav .mob-svc-label{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--red);
  padding: 20px 24px 8px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.mobile-nav a.mob-svc{
  font-size: 14px;
  padding: 12px 24px 12px 40px;
  color: rgba(255,255,255,.65);
  background: rgba(0,0,0,.25);
}
.mobile-nav a.mob-svc:hover{ color: #fff }

/* ---------- Hero ---------- */
.hero{
  position: relative;
  min-height: 92vh;
  padding-top: calc(var(--header-h) + 60px);
  padding-bottom: 80px;
  background: var(--black);
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.hero::before{
  /* tech grid */
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse at 70% 40%, #000 30%, transparent 75%);
  z-index: -1;
}
.hero::after{
  content:"";
  position:absolute;
  width: 700px; height: 700px;
  right: -200px; top: -200px;
  background: radial-gradient(circle, rgba(226,28,33,.18), transparent 60%);
  z-index: -1;
  pointer-events:none;
}
.hero-grid{
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 64px;
  align-items: center;
}
.hero-tag{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--red);
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 24px;
}
.hero-tag::before{
  content:"";
  width: 6px; height: 6px;
  background: var(--red);
  border-radius: 50%;
  box-shadow: 0 0 0 4px rgba(226,28,33,.25);
  animation: pulse 2s infinite;
}
@keyframes pulse{
  0%,100%{box-shadow: 0 0 0 4px rgba(226,28,33,.25)}
  50%{box-shadow: 0 0 0 8px rgba(226,28,33,0)}
}
.hero h1{
  color: #fff;
  margin-bottom: 28px;
  font-size: clamp(54px, 7.8vw, 108px);
  line-height: 1.0;
}
.hero h1 .accent{
  display: inline-block;
  position: relative;
  color: #fff;
  letter-spacing: 0;
}
.hero h1 .accent::after{ content: none; }
.hero-lead{
  font-size: clamp(16px, 1.2vw, 19px);
  color: rgba(255,255,255,.82);
  max-width: 560px;
  margin-bottom: 36px;
  line-height: 1.65;
}
.hero-ctas{
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 40px;
}
.hero-support{
  font-family: var(--mono);
  font-size: 12px;
  color: var(--gray-300);
  letter-spacing: .04em;
  border-left: 2px solid var(--red);
  padding-left: 14px;
  max-width: 460px;
  line-height: 1.7;
}
.hero-badges{
  margin-top: 24px;
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}
.hero-badges-label{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: rgba(255,255,255,.45);
  position: relative;
  padding-right: 14px;
}
.hero-badges-label::after{
  content: "";
  position: absolute;
  right: 0; top: 50%;
  width: 6px; height: 1px;
  background: rgba(255,255,255,.3);
  transform: translateY(-50%);
}
.hero-badges-row{
  display: flex;
  align-items: center;
  gap: 18px;
  background: rgba(255,255,255,.96);
  padding: 12px 20px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 8px 24px -12px rgba(0,0,0,.6);
}
.hero-badge{
  display: block;
  height: 30px;
  width: auto;
  object-fit: contain;
  filter: saturate(1);
  transition: transform .25s ease, opacity .25s ease;
}
.hero-badge:hover{ transform: scale(1.04); }
.hero-badge.amesp{ height: 28px; }
.hero-badge.repse{ height: 32px; }
.hero-badges-sep{
  width: 1px;
  height: 24px;
  background: rgba(0,0,0,.12);
}

/* Hero right column — Guard panel */
.guard-panel{
  position: relative;
  aspect-ratio: 4/5;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--r-md);
  background:
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.005)),
    repeating-linear-gradient(45deg, rgba(255,255,255,.012) 0 2px, transparent 2px 8px),
    var(--gray-900);
  padding: 28px;
  overflow: hidden;
}
.guard-panel .corner{
  position: absolute;
  width: 22px; height: 22px;
  border: 2px solid var(--red);
}
.guard-panel .corner.tl{ top:14px; left:14px; border-right:none; border-bottom:none }
.guard-panel .corner.tr{ top:14px; right:14px; border-left:none; border-bottom:none }
.guard-panel .corner.bl{ bottom:14px; left:14px; border-right:none; border-top:none }
.guard-panel .corner.br{ bottom:14px; right:14px; border-left:none; border-top:none }
.guard-panel .panel-head{
  display:flex;justify-content:space-between;align-items:center;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gray-300);
  margin-bottom: 24px;
  padding-bottom: 14px;
  border-bottom: 1px dashed rgba(255,255,255,.12);
}
.guard-panel .panel-head .live{ color: var(--red); display:flex;align-items:center;gap:6px }
.guard-panel .panel-head .live::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--red); animation: pulse 1.5s infinite }
.guard-figure{
  position: relative;
  height: 62%;
  background:
    radial-gradient(circle at 50% 35%, rgba(226,28,33,.08), transparent 60%),
    linear-gradient(180deg, var(--gray-800), var(--gray-900));
  border-radius: var(--r-sm);
  display: grid;
  place-items: center;
  overflow: hidden;
  margin-bottom: 16px;
}
.guard-photo{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 35%;
  filter: saturate(1.05) contrast(1.05);
}
.guard-overlay{
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(17,17,17,.15) 0%, transparent 35%, rgba(17,17,17,.55) 100%),
    linear-gradient(90deg, rgba(17,17,17,.25) 0%, transparent 30%);
  pointer-events: none;
}
.guard-figure::before{ /* scanner */
  content:"";
  position:absolute;
  left:0;right:0;height:2px;
  background: linear-gradient(90deg, transparent, var(--red), transparent);
  animation: scan 3s ease-in-out infinite;
  opacity:.7;
}
@keyframes scan{
  0%{top:5%}
  50%{top:95%}
  100%{top:5%}
}
.guard-figure .crosshair{
  position:absolute;
  width: 64px; height:64px;
  border: 1px solid rgba(255,255,255,.6);
  border-radius: 50%;
  top: 28%; left: 28%; transform: translate(-50%,-50%);
  z-index: 2;
  mix-blend-mode: screen;
}
.guard-figure .crosshair::before, .guard-figure .crosshair::after{
  content:""; position:absolute; background: rgba(255,255,255,.6);
  z-index: 2;
}
.guard-figure .crosshair::before{ left: 50%; top:-14px; bottom:-14px; width:1px }
.guard-figure .crosshair::after{ top: 50%; left:-14px; right:-14px; height:1px }

.guard-stats{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.gstat{
  background: rgba(255,255,255,.025);
  border: 1px solid rgba(255,255,255,.08);
  padding: 12px 14px;
  border-radius: var(--r-sm);
}
.gstat .k{
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gray-300);
  margin-bottom: 4px;
}
.gstat .v{
  font-family: var(--display);
  font-size: 18px;
  color: #fff;
  letter-spacing: .04em;
}
.gstat .v .dot{
  display:inline-block;width:7px;height:7px;background:#3FCF8E;border-radius:50%;margin-right:6px;vertical-align:middle
}

/* Trust seals strip beneath hero */
.seals{
  margin-top: 64px;
  padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.seals .label{
  display: block;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--gray-300);
  margin-bottom: 18px;
}
.seals-row{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.seal{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 3px;
  background: rgba(255,255,255,.02);
}
.seal .ring{
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 2px solid var(--red);
  display:grid;place-items:center;
  font-family: var(--display);
  font-weight: 700;
  font-size: 10px;
  color: #fff;
  letter-spacing: .04em;
}
.seal .meta{display:flex;flex-direction:column;line-height:1.1}
.seal .meta strong{font-family:var(--display);font-size:14px;letter-spacing:.1em;color:#fff;text-transform:uppercase}
.seal .meta small{font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;color:var(--gray-300);margin-top:3px;text-transform:uppercase}

/* ---------- Trust strip (Franja de confianza) ---------- */
.trust-strip{
  background: var(--gray-100);
  padding: 80px 0;
  position: relative;
  overflow: hidden;
}
.trust-strip::after{
  content:"";
  position:absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 8% 30%, rgba(226,28,33,.04), transparent 35%),
    radial-gradient(circle at 92% 70%, rgba(226,28,33,.04), transparent 35%);
  pointer-events: none;
}
.trust-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  position: relative;
  z-index: 1;
}
.trust-item{
  padding: 32px 28px;
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--r-md);
  position: relative;
  transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s, border-color .35s;
  overflow: hidden;
  isolation: isolate;
}
.trust-item::before{
  content:"";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--red);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .5s cubic-bezier(.2,.7,.2,1);
}
.trust-item:hover{
  transform: translateY(-6px);
  border-color: var(--red);
  box-shadow: 0 24px 50px -22px rgba(226,28,33,.25);
}
.trust-item:hover::before{ transform: scaleX(1) }
.trust-num{
  font-family: var(--display);
  font-size: clamp(48px, 5.4vw, 68px);
  line-height: 1;
  font-weight: 700;
  color: var(--black);
  letter-spacing: -.01em;
  margin-bottom: 18px;
  display: inline-flex;
  align-items: baseline;
}
.trust-num .plus{
  color: var(--red);
  font-size: .55em;
  font-weight: 600;
  margin: 0 2px;
}
.trust-num .count{ display: inline-block; min-width: 1ch; }
.trust-item h4{
  font-family: var(--display);
  font-size: 18px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--black);
  margin-bottom: 10px;
}
.trust-item p{
  font-size: 14px;
  color: var(--gray-500);
  line-height: 1.6;
}

/* ---------- Section title block ---------- */
.section-head{ margin-bottom: 56px; max-width: 880px }
.section-head h2{ margin-top: 18px; margin-bottom: 24px }
.section-head p{ font-size: 16.5px; color: var(--gray-500); max-width: 780px; line-height: 1.75 }
.section-head p + p{ margin-top: 14px }

.split{display:grid;grid-template-columns: 1fr 1fr;gap: 80px;align-items: start}

/* ---------- Section 1 services intro ---------- */
.s-intro{ background: var(--white) }
.intro-photo{
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Capacidades operativas — horizontal bar */
.capacities-bar{
  margin-top: 72px;
  padding-top: 36px;
  border-top: 1px solid var(--gray-200);
}
.cap-bar-head{
  display: flex;
  align-items: center;
  gap: 18px;
  margin-bottom: 28px;
}
.cap-bar-head .num{
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--red);
  white-space: nowrap;
}
.cap-bar-head .cap-line{
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, var(--red), transparent);
}
.cap-bar-grid{
  list-style: none;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}
.cap-bar-grid li{
  position: relative;
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--r-md);
  padding: 28px 28px;
  display: flex;
  align-items: center;
  gap: 22px;
  transition: all .35s cubic-bezier(.2,.7,.2,1);
  overflow: hidden;
}
.cap-bar-grid li::before{
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--red);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform .45s cubic-bezier(.2,.7,.2,1);
}
.cap-bar-grid li:hover{
  border-color: var(--red);
  transform: translateY(-4px);
  box-shadow: 0 18px 36px -20px rgba(226,28,33,.25);
}
.cap-bar-grid li:hover::before{ transform: scaleY(1) }
.cap-bar-grid .cap-i{
  font-family: var(--display);
  font-size: 38px;
  font-weight: 700;
  color: var(--gray-200);
  line-height: 1;
  transition: color .25s;
  flex-shrink: 0;
}
.cap-bar-grid li:hover .cap-i{ color: var(--red) }
.cap-bar-grid .cap-t{
  font-size: 15.5px;
  color: var(--gray-700);
  line-height: 1.5;
  font-weight: 500;
}
.intro-photo-frame{
  position: relative;
  aspect-ratio: 4/5;
  border-radius: var(--r-md);
  overflow: hidden;
  isolation: isolate;
  background: var(--gray-900);
  box-shadow: 0 30px 60px -25px rgba(0,0,0,.35);
}
.intro-photo-frame img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 35% 40%;
  display: block;
  filter: contrast(1.04) saturate(1.05);
}
.intro-photo-frame::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.0) 0%, rgba(0,0,0,.0) 55%, rgba(0,0,0,.7) 100%);
  z-index: 2;
  pointer-events: none;
}
.ip-corner{
  position:absolute;
  width: 22px; height: 22px;
  border: 2px solid var(--red);
  z-index: 3;
}
.ip-corner.tl{ top:14px; left:14px; border-right:none; border-bottom:none }
.ip-corner.tr{ top:14px; right:14px; border-left:none; border-bottom:none }
.ip-corner.bl{ bottom:14px; left:14px; border-right:none; border-top:none }
.ip-corner.br{ bottom:14px; right:14px; border-left:none; border-top:none }
.intro-photo-tag{
  position: absolute;
  left: 22px;
  bottom: 22px;
  z-index: 4;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: rgba(0,0,0,.7);
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(8px);
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: #fff;
  border-radius: 4px;
}
.intro-photo-tag .dot{
  width: 7px; height: 7px;
  background: var(--red);
  border-radius: 50%;
  box-shadow: 0 0 0 3px rgba(226,28,33,.25);
  animation: pulse 2s infinite;
}
.intro-aside{
  border: 1px solid var(--gray-200);
  padding: 24px 26px;
  background: var(--gray-50);
  border-radius: var(--r-md);
}
.intro-aside .num{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .22em;
  color: var(--red);
  margin-bottom: 18px;
}
.intro-aside ul{ list-style: none; display: grid; gap: 14px; margin-top: 22px }
.intro-aside li{
  display:flex; align-items:flex-start; gap: 12px;
  font-size: 14px; color: var(--gray-700);
  padding-bottom: 14px;
  border-bottom: 1px solid var(--gray-200);
}
.intro-aside li:last-child{border-bottom:none;padding-bottom:0}
.intro-aside li .dot{
  width: 8px; height: 8px;
  background: var(--red);
  margin-top: 7px; flex-shrink:0;
  transform: rotate(45deg);
}

/* ---------- Service cards (sectors + includes) ---------- */
.sector-section{ background: var(--gray-100); position: relative }
.sector-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.s-card{
  position: relative;
  background: var(--white);
  border: 1px solid var(--gray-200);
  padding: 32px 28px 28px;
  aspect-ratio: 1 / 1;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: all .35s cubic-bezier(.2,.7,.2,1);
  overflow: hidden;
  isolation: isolate;
}
.s-card::before{ /* scanner line */
  content:"";
  position: absolute;
  inset: 0 0 auto 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--red), transparent);
  transform: translateY(-2px);
  transition: transform .6s ease;
  z-index: 1;
}
.s-card .crosshair-corners span{
  position: absolute;
  width: 16px; height: 16px;
  border: 1.5px solid var(--red);
  opacity: 0;
  transition: opacity .25s ease, transform .35s cubic-bezier(.2,.7,.2,1);
  z-index: 2;
}
.s-card .s-bg{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  opacity: 0;
  transform: scale(1.04);
  transition: opacity .45s ease, transform .8s cubic-bezier(.2,.7,.2,1);
  z-index: 0;
  pointer-events: none;
  filter: grayscale(15%) contrast(1.02);
}
.s-card::after{ /* white-to-transparent veil so text stays legible */
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,.78) 0%, rgba(255,255,255,.82) 45%, rgba(255,255,255,.92) 100%);
  opacity: 0;
  transition: opacity .45s ease;
  z-index: 1;
  pointer-events: none;
}
.s-card > *:not(.s-bg):not(.crosshair-corners){ position: relative; z-index: 2; }
.s-card .crosshair-corners{ position: absolute; inset: 0; z-index: 3; pointer-events: none; }
.s-card:hover .s-bg{ opacity: .55; transform: scale(1); }
.s-card:hover::after{ opacity: 1; }
.s-card .crosshair-corners .tl{top:12px;left:12px;border-right:none;border-bottom:none;transform: translate(6px,6px)}
.s-card .crosshair-corners .tr{top:12px;right:12px;border-left:none;border-bottom:none;transform: translate(-6px,6px)}
.s-card .crosshair-corners .bl{bottom:12px;left:12px;border-right:none;border-top:none;transform: translate(6px,-6px)}
.s-card .crosshair-corners .br{bottom:12px;right:12px;border-left:none;border-top:none;transform: translate(-6px,-6px)}
.s-card:hover{
  border-color: var(--red);
  transform: translateY(-4px);
  box-shadow: 0 22px 50px -20px rgba(226,28,33,.28), 0 0 0 1px var(--red);
}
.s-card:hover::before{ transform: translateY(0) }
.s-card:hover .crosshair-corners span{ opacity: 1; transform: translate(0,0) }
.s-card .s-num{
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .22em;
  color: var(--gray-300);
}
.s-card .s-icon{
  width: 40px; height: 40px;
  color: var(--black);
  transition: color .3s;
  flex-shrink: 0;
}
.s-card:hover .s-icon{ color: var(--red) }
.s-card h3{
  text-transform: uppercase;
  color: var(--black);
  font-size: 19px;
  letter-spacing: .03em;
  line-height: 1.1;
}
.s-card p{
  font-size: 14px;
  color: var(--gray-500);
  line-height: 1.55;
  flex: 0 1 auto;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
}
.s-card .ideal{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .04em;
  color: var(--gray-700);
  padding-top: 14px;
  border-top: 1px dashed var(--gray-200);
  line-height: 1.55;
  margin-top: auto;
}
.s-card .ideal strong{
  display:block;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 6px;
  font-size: 10.5px;
}

/* ---------- Section 3 — capacitados (dark band) ---------- */
.s-capacity{
  background: var(--black);
  color: #fff;
  position: relative;
  overflow: hidden;
}
.s-capacity::before{
  content:"";
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(circle at 80% 50%, #000 30%, transparent 75%);
}
.s-capacity .container{position: relative}
.s-capacity h2{color: #fff}
.s-capacity .section-head p{ color: rgba(255,255,255,.72) }
.cap-visual{
  position: relative;
  aspect-ratio: 4/5;
}
.cap-stage{
  position: absolute;
  inset: 0;
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01) 30%, rgba(0,0,0,.4)),
    var(--gray-900);
  border: 1px solid rgba(255,255,255,.08);
  overflow: hidden;
  isolation: isolate;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 30px 80px -30px rgba(0,0,0,.7);
}
.cap-glow{
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  pointer-events: none;
  z-index: 1;
  opacity: .85;
  animation: capGlow 8s ease-in-out infinite alternate;
}
.cap-glow.gl-1{
  width: 65%; height: 55%;
  left: -10%; top: 18%;
  background: radial-gradient(circle, rgba(226,28,33,.85), rgba(226,28,33,0) 65%);
}
.cap-glow.gl-2{
  width: 55%; height: 45%;
  right: -8%; bottom: 6%;
  background: radial-gradient(circle, rgba(226,28,33,.55), rgba(226,28,33,0) 65%);
  animation-delay: -3s;
}
@keyframes capGlow{
  0%{ transform: translate(0,0) scale(1) }
  100%{ transform: translate(8%,-4%) scale(1.08) }
}
.cap-grid{
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse at 50% 40%, #000 0%, transparent 75%);
  z-index: 2;
  pointer-events:none;
}
.cap-frame{
  position: absolute;
  left: 9%; right: 9%; top: 7%; bottom: 7%;
  border-radius: 12px;
  overflow: hidden;
  background: var(--gray-900);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow:
    0 30px 60px -20px rgba(0,0,0,.75),
    0 0 0 1px rgba(255,255,255,.03),
    0 0 80px -10px rgba(226,28,33,.35);
  z-index: 3;
  transform: translateZ(0);
}
.cap-frame::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(255,255,255,.08), transparent 30%, transparent 70%, rgba(0,0,0,.35));
  z-index: 2;
  pointer-events:none;
  border-radius: inherit;
}
.cap-frame::after{
  /* subtle scanline */
  content:"";
  position:absolute;
  left:0; right:0;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(226,28,33,.55), transparent);
  opacity: .55;
  z-index: 3;
  animation: capScan 5s ease-in-out infinite;
  pointer-events:none;
}
@keyframes capScan{
  0%{ top: 4% }
  50%{ top: 92% }
  100%{ top: 4% }
}
.cap-photo{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  filter: saturate(1.05) contrast(1.05);
}
.cap-badges{
  position: absolute;
  left: 50%;
  bottom: 18px;
  transform: translateX(-50%);
  z-index: 4;
  width: max-content;
  max-width: calc(100% - 24px);
  display: flex;
  align-items: center;
  gap: 22px;
  background: rgba(255,255,255,.96);
  padding: 12px 28px 12px 24px;
  border-radius: 8px;
  box-shadow: 0 14px 32px -14px rgba(0,0,0,.6), 0 0 0 1px rgba(0,0,0,.06);
  backdrop-filter: blur(8px);
  white-space: nowrap;
}
.cap-badge{
  display: block;
  width: auto;
  height: auto;
  object-fit: contain;
  flex-shrink: 0;
}
.cap-badge.amesp{ height: 28px; }
.cap-badge.repse{ height: 32px; margin-right: 4px; }
.cap-badges-sep{
  width: 1px;
  height: 24px;
  background: rgba(0,0,0,.12);
  flex-shrink: 0;
}

/* ---------- Includes grid (Sección 4) ---------- */
.includes-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--gray-200);
  border: 1px solid var(--gray-200);
}
.inc-cell{
  background: var(--white);
  padding: 36px 32px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
  transition: background .25s;
}
.inc-cell:hover{ background: var(--gray-50) }
.inc-cell .num{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .2em;
  color: var(--red);
}
.inc-cell .ico{
  width: 36px; height: 36px;
  color: var(--black);
}
.inc-cell h3{
  font-size: 18px;
  text-transform: uppercase;
  letter-spacing: .03em;
  margin-top: 4px;
}
.inc-cell p{
  font-size: 14.5px;
  color: var(--gray-500);
  line-height: 1.65;
}

/* ---------- Why TSG (Sección 5) ---------- */
.why-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.why-card{
  background: var(--white);
  border: 1px solid var(--gray-200);
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
  transition: all .3s;
}
.why-card::before{
  content:"";
  position:absolute;left:0;top:0;bottom:0;
  width: 3px; background: var(--red);
  transform: scaleY(0); transform-origin: top;
  transition: transform .35s ease;
}
.why-card:hover{ border-color: var(--gray-300); transform: translateY(-3px); box-shadow: 0 14px 30px -16px rgba(0,0,0,.15) }
.why-card:hover::before{ transform: scaleY(1) }
.why-card .why-num{
  font-family: var(--display);
  font-size: 44px;
  color: var(--gray-200);
  line-height: 1;
  font-weight: 700;
  transition: color .25s;
}
.why-card:hover .why-num{ color: var(--red) }
.why-card h3{
  font-size: 19px;
  text-transform: uppercase;
  letter-spacing: .03em;
}
.why-card p{ font-size: 14.5px; color: var(--gray-500); line-height: 1.65 }

/* ---------- Coverage map (Sección 6) ---------- */
.coverage{ background: var(--gray-100) }
.cov-layout{
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 64px;
  align-items: center;
}
.cov-cities{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 18px;
  margin: 28px 0 32px;
}
.cov-cities li{
  list-style: none;
  font-family: var(--mono);
  font-size: 13px;
  color: var(--gray-700);
  padding: 8px 0;
  border-bottom: 1px dashed var(--gray-200);
  display: flex; align-items: center; gap: 10px;
  cursor: pointer;
  transition: color .2s;
}
.cov-cities li::before{
  content:""; width:6px;height:6px;background:var(--red);transform:rotate(45deg);
  flex-shrink:0;
}
.cov-cities li:hover, .cov-cities li.active{ color: var(--red) }
.cov-cities li.more{ color: var(--gray-500); font-style: italic }
.cov-cities li.more::before{ background: var(--gray-300) }

.map-wrap{
  position: relative;
  background: var(--white);
  border: 1px solid var(--gray-200);
  padding: 32px;
  border-radius: var(--r-md);
  aspect-ratio: 5/4;
}
.map-wrap .map-head{
  display:flex;justify-content:space-between;align-items:center;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gray-500);
  margin-bottom: 16px;
}
.map-wrap .map-head .live{color:var(--red);display:flex;align-items:center;gap:6px}
.map-wrap .map-head .live::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--red);animation:pulse 1.5s infinite}
.map-stage{
  position: relative;
  width: 100%;
  height: calc(100% - 30px);
  display: flex;
  align-items: center;
  justify-content: center;
}
.map-photo{
  display: block;
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
}
.map-pulses{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  overflow: visible;
}
.map-pulses .hit{
  fill: transparent;
  pointer-events: auto;
  cursor: pointer;
}
.map-pulses .pulse-ring{
  fill: none;
  stroke: #e21c21;
  stroke-width: 1.4;
  transform-origin: center;
  transform-box: fill-box;
  opacity: 0;
  pointer-events: none;
}
.map-pulses .dot-group:hover .pulse-ring,
.map-pulses .dot-group:focus-within .pulse-ring{
  animation: mapPulse 1.6s cubic-bezier(.2,.6,.2,1) infinite;
}
.map-pulses .pulse-ring.r2{ animation-delay: .55s !important; }
@keyframes mapPulse{
  0%   { transform: scale(.4); opacity: 0; }
  15%  { opacity: .9; }
  70%  { opacity: 0; transform: scale(3.4); }
  100% { opacity: 0; transform: scale(3.4); }
}
@media (prefers-reduced-motion: reduce){
  .map-pulses .dot-group:hover .pulse-ring{ animation: none; opacity: 0; }
}

/* ---------- Permits/Certs (Sección 7) ---------- */
.permits{ background: var(--gray-900); color: #fff; position: relative; overflow: hidden }
.permits::after{
  content:""; position:absolute; right:-150px; bottom:-150px; width:480px;height:480px;
  background: radial-gradient(circle, rgba(226,28,33,.14), transparent 60%);
}
.permits .container{ position: relative; z-index: 1 }
.permits h2{ color: #fff }
.permits .section-head p{ color: rgba(255,255,255,.72) }
.permit-list{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.permit-card{
  position: relative;
  padding: 26px 22px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--r-md);
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: all .35s cubic-bezier(.2,.7,.2,1);
  isolation: isolate;
  overflow: hidden;
  min-height: 130px;
}
.permit-card::before{
  content:"";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--red);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .5s cubic-bezier(.2,.7,.2,1);
}
.permit-card:hover{
  background: rgba(255,255,255,.06);
  border-color: var(--red);
  transform: translateY(-3px);
  box-shadow: 0 18px 40px -20px rgba(226,28,33,.4);
}
.permit-card:hover::before{ transform: scaleX(1) }
.permit-card .check{
  width: 34px; height: 34px; flex-shrink:0;
  border: 1.5px solid var(--red);
  display:grid;place-items:center;
  color: var(--red);
  transition: all .3s;
}
.permit-card:hover .check{
  background: var(--red);
  color: #fff;
  transform: scale(1.05);
}
.permit-card .check svg{width:16px;height:16px}
.permit-card .label{
  font-family: var(--display);
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: 15px;
  color: #fff;
  line-height: 1.25;
}
.permits .closing{
  margin-top: 36px;
  padding: 24px 28px;
  background: rgba(255,255,255,.04);
  border-left: 3px solid var(--red);
  font-size: 15.5px;
  color: rgba(255,255,255,.85);
  max-width: 880px;
  line-height: 1.7;
}

/* ---------- Logos carousel (Sección 8) ---------- */
.clients-section .section-head p{ font-size: 16px }
.logos-track-wrap{
  margin-top: 48px;
  overflow: hidden;
  border-top: 1px solid var(--gray-200);
  border-bottom: 1px solid var(--gray-200);
  padding: 32px 0;
  background: var(--white);
  position: relative;
}
.logos-track-wrap::before, .logos-track-wrap::after{
  content:""; position:absolute; top:0; bottom:0; width:120px; z-index:2; pointer-events:none;
}
.logos-track-wrap::before{ left:0; background: linear-gradient(90deg, var(--white), transparent) }
.logos-track-wrap::after{ right:0; background: linear-gradient(-90deg, var(--white), transparent) }
.logos-track{
  display: flex;
  gap: 56px;
  width: max-content;
  animation: marquee 32s linear infinite;
}
@keyframes marquee{
  0%{ transform: translateX(0) }
  100%{ transform: translateX(-50%) }
}
.logo-tile{
  flex-shrink: 0;
  height: 80px;
  min-width: 180px;
  padding: 0 28px;
  display: grid;
  place-items: center;
  border: 1px solid var(--gray-200);
  background: var(--white);
  transition: all .25s;
}
.logo-tile img{
  max-height: 56px;
  max-width: 160px;
  width: auto;
  height: auto;
  object-fit: contain;
  
  
  transition: filter .3s ease, opacity .3s ease, transform .3s ease;
}
.logo-tile:hover{ border-color: var(--gray-300) }
.logo-tile:hover img{ transform: scale(1.04); }

/* ---------- Final CTA (Sección 9) ---------- */
.final-cta{
  background: var(--black);
  color: #fff;
  position: relative;
  overflow: hidden;
}
.final-cta::before{
  content:"";
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 30%, rgba(226,28,33,.18), transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(226,28,33,.10), transparent 55%);
}
.final-cta::after{
  content:""; position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(ellipse at center, #000 30%, transparent 80%);
}
.final-cta .container{position: relative; z-index:1; text-align: center}
.final-cta h2{color: #fff; font-size: clamp(40px, 5.4vw, 72px); margin-bottom: 22px}
.final-cta p{ color: rgba(255,255,255,.78); max-width: 720px; margin: 0 auto 14px; font-size: 16.5px }
.final-cta .btn{ margin-top: 36px; padding: 20px 36px; font-size: 15px }
.final-cta .meta{
  margin-top: 32px;
  display: flex; justify-content: center; gap: 32px;
  font-family: var(--mono); font-size: 11px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--gray-300);
  flex-wrap: wrap;
}
.final-cta .meta span::before{ content:"●"; color: var(--red); margin-right: 8px; font-size: 8px; vertical-align: middle }

/* ---------- FAQ (Sección 10) ---------- */
.faq-layout{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 80px;
  align-items: start;
}
.faq-side{position: sticky; top: calc(var(--header-h) + 24px)}
.faq-side .helper{
  margin-top: 28px;
  padding: 24px;
  border: 1px solid var(--gray-200);
  background: var(--gray-50);
  border-radius: var(--r-md);
}
.faq-side .helper strong{
  font-family: var(--display);
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: 16px;
  color: var(--black);
  display:block;
  margin-bottom: 10px;
}
.faq-side .helper p{ font-size: 14px; color: var(--gray-500); margin-bottom: 16px }

.faq-list{ list-style: none; border-top: 1px solid var(--gray-200) }
.faq-item{ border-bottom: 1px solid var(--gray-200) }
.faq-q{
  width: 100%;
  text-align: left;
  padding: 22px 0;
  font-family: var(--display);
  font-size: 18px;
  text-transform: uppercase;
  letter-spacing: .03em;
  color: var(--black);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  transition: color .2s;
}
.faq-q:hover{ color: var(--red) }
.faq-q .toggle{
  width: 36px; height: 36px;
  flex-shrink:0;
  display: grid; place-items: center;
  border: 1px solid var(--gray-300);
  border-radius: 50%;
  transition: all .3s;
}
.faq-q .toggle::before, .faq-q .toggle::after{
  content:""; position:absolute;
  background: currentColor;
}
.faq-q .toggle{position: relative}
.faq-q .toggle::before{ width: 12px; height: 1.5px }
.faq-q .toggle::after{ width: 1.5px; height: 12px; transition: transform .3s }
.faq-item.open .faq-q{ color: var(--red) }
.faq-item.open .toggle{ border-color: var(--red); background: var(--red); color: #fff }
.faq-item.open .toggle::after{ transform: rotate(90deg) }
.faq-a{
  max-height: 0;
  overflow: hidden;
  transition: max-height .4s ease;
}
.faq-a-inner{
  padding: 0 0 26px 0;
  font-size: 15px;
  color: var(--gray-500);
  line-height: 1.75;
  max-width: 90%;
}
.faq-item.open .faq-a{ max-height: 400px }

/* ---------- Footer ---------- */
.site-footer{
  background: var(--black);
  color: rgba(255,255,255,.7);
  padding: 80px 0 30px;
}
.foot-grid{
  display: grid;
  grid-template-columns: 1.4fr .9fr .9fr 1fr;
  gap: 56px;
  margin-bottom: 56px;
}
.foot-brand{ max-width: 360px }
.foot-brand .brand{ margin-bottom: 22px }
.foot-brand .brand .brand-text{ color: #fff }
.foot-brand .brand .brand-text small{ color: var(--gray-300) }
.foot-brand p{ font-size: 14px; line-height: 1.7; color: rgba(255,255,255,.65) }
.foot-col h5{
  font-family: var(--display);
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: 13px;
  color: #fff;
  margin-bottom: 20px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255,255,255,.12);
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: default;
  user-select: none;
}
.foot-col h5 .foot-chevron{ display: none }
.foot-col ul{list-style:none;display:grid;gap:12px}
.foot-col a, .foot-col li{
  font-size: 14px;
  color: rgba(255,255,255,.65);
  transition: color .2s;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.foot-col a:hover{ color: var(--red) }
.foot-col .ico{ width:14px;height:14px;color:var(--red);flex-shrink:0 }
.foot-bottom{
  display:flex; justify-content: space-between; align-items: center;
  padding-top: 26px;
  border-top: 1px solid rgba(255,255,255,.1);
  font-family: var(--mono); font-size: 11px; letter-spacing: .14em;
  color: var(--gray-500);
  text-transform: uppercase;
  flex-wrap: wrap;
  gap: 12px;
}

/* ---------- WhatsApp floating ---------- */
.wa-float{
  position: fixed;
  bottom: 22px; right: 22px;
  width: 58px; height: 58px;
  background: #25D366;
  border-radius: 50%;
  display: grid; place-items: center;
  box-shadow: 0 10px 30px -8px rgba(37,211,102,.55), 0 6px 16px rgba(0,0,0,.18);
  color: #fff;
  z-index: 95;
  transition: transform .25s;
}
.wa-float:hover{ transform: scale(1.08) }
.wa-float::before{
  content:"";
  position:absolute;inset:-6px;
  border-radius:50%;
  border: 1.5px solid rgba(37,211,102,.45);
  animation: pulse-ring 2s infinite;
}
@keyframes pulse-ring{
  0%{ transform: scale(.9); opacity: .8 }
  100%{ transform: scale(1.3); opacity: 0 }
}
.wa-float svg{width:28px;height:28px}

/* ========== Animaciones sutiles ========== */
[data-reveal]{
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .9s cubic-bezier(.2,.7,.2,1) var(--rd, 0ms),
              transform .9s cubic-bezier(.2,.7,.2,1) var(--rd, 0ms);
  will-change: opacity, transform;
}
[data-reveal="left"]{ transform: translateX(-32px) }
[data-reveal="right"]{ transform: translateX(32px) }
[data-reveal="scale"]{ transform: scale(.94) }
[data-reveal].is-in{
  opacity: 1;
  transform: none;
}
.section-head{ transition: opacity .8s ease, transform .8s ease }
@media (prefers-reduced-motion: reduce){
  [data-reveal]{ opacity: 1; transform: none; transition: none }
}

/* Section-head subtle reveal */
section .section-head{
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1);
}
section .section-head.is-in{ opacity: 1; transform: none }

@media (max-width: 980px){
  .menu-toggle{ display: none }
  .nav a{ padding: 8px 10px; font-size: 12px }
  .header-cta .btn{ padding: 10px 14px; font-size: 11px }
  .hero-grid{ grid-template-columns: 1fr; gap: 48px }
  .guard-panel{ aspect-ratio: 4/3; max-height: 460px }
  .trust-grid{ grid-template-columns: repeat(2, 1fr); gap: 14px }
  .trust-item{ padding: 28px 24px }
  .split{ grid-template-columns: 1fr; gap: 40px }
  .intro-aside{ position: static }
  .cap-bar-grid{ grid-template-columns: 1fr }
  .sector-grid{ grid-template-columns: 1fr 1fr }
  .includes-grid{ grid-template-columns: 1fr 1fr }
  .why-grid{ grid-template-columns: 1fr 1fr }
  .cov-layout{ grid-template-columns: 1fr; gap: 40px }
  .permit-list{ grid-template-columns: 1fr 1fr; gap: 12px }
  .faq-layout{ grid-template-columns: 1fr; gap: 40px }
  .faq-side{ position: static }
  .foot-grid{ grid-template-columns: 1fr 1fr; gap: 40px }
  .foot-brand{ grid-column: 1 / -1 }
}
@media (max-width: 760px){
  /* Hide desktop nav and CTA, show hamburger */
  .nav{ display: none }
  .header-cta{ display: none }
  .menu-toggle{ display: flex }

  /* Center logo, pin hamburger to right */
  .header-inner{
    justify-content: center;
    position: relative;
  }
  .brand{
    position: relative;
    z-index: 1;
  }
  .menu-toggle{
    position: absolute;
    right: 18px;
    top: 50%;
    transform: translateY(-50%);
  }
}
@media (max-width: 620px){
  :root{ --header-h: 64px }
  section{ padding: 64px 0 }
  .container{ padding-inline: 18px }
  .hero{ padding-top: calc(var(--header-h) + 40px); min-height: 0 }
  .trust-grid{ grid-template-columns: 1fr; gap: 12px }
  .trust-item{ padding: 26px 22px }
  .sector-grid, .includes-grid, .why-grid{ grid-template-columns: 1fr }
  .cap-bar-grid{ grid-template-columns: 1fr; gap: 12px }
  .capacities-bar{ margin-top: 48px; padding-top: 28px }
  .cov-cities{ grid-template-columns: 1fr }
  .hero-ctas{ flex-direction: column; align-items: stretch }
  .hero-ctas .btn{ justify-content: center }
  .final-cta .meta{ gap: 16px; flex-direction: column }

  /* Footer: full-width grid, collapsible columns */
  .foot-grid{ grid-template-columns: 1fr; gap: 0; margin-bottom: 40px }
  .foot-brand{
    grid-column: auto;
    padding-bottom: 32px;
    border-bottom: 1px solid rgba(255,255,255,.1);
    margin-bottom: 0;
  }
  .foot-bottom{ flex-direction: column; align-items: flex-start }

  /* Collapsible footer columns */
  .foot-col{
    border-bottom: 1px solid rgba(255,255,255,.1);
  }
  .foot-col h5{
    cursor: pointer;
    margin-bottom: 0;
    padding: 18px 0;
    border-bottom: none;
  }
  .foot-col h5 .foot-chevron{
    display: block;
    width: 20px; height: 20px;
    position: relative;
    flex-shrink: 0;
    transition: transform .3s ease;
  }
  .foot-col h5 .foot-chevron::before,
  .foot-col h5 .foot-chevron::after{
    content:"";
    position:absolute;
    background: rgba(255,255,255,.5);
    border-radius: 2px;
  }
  .foot-col h5 .foot-chevron::before{
    width: 10px; height: 1.5px;
    top: 50%; right: 5px;
    transform: translateY(-50%) rotate(45deg);
  }
  .foot-col h5 .foot-chevron::after{
    width: 10px; height: 1.5px;
    top: 50%; left: 5px;
    transform: translateY(-50%) rotate(-45deg);
  }
  .foot-col.open h5 .foot-chevron::before{
    transform: translateY(-50%) rotate(-45deg);
  }
  .foot-col.open h5 .foot-chevron::after{
    transform: translateY(-50%) rotate(45deg);
  }
  .foot-col ul{
    max-height: 0;
    overflow: hidden;
    transition: max-height .35s ease, padding .35s ease;
    padding: 0;
    gap: 0;
  }
  .foot-col.open ul{
    max-height: 500px;
    padding-bottom: 20px;
    gap: 14px;
  }
}

/* ============================================================
   HOME HERO — ajuste full screen + seals responsive
   Objetivo: que el hero use el alto completo de la pantalla,
   que las cards de logos no queden pegadas al final y que
   en móvil se adapten sin romper texto ni layout.
   ============================================================ */
.hero{
  min-height: 100svh;
  padding-top: calc(var(--header-h) + clamp(30px, 4vw, 56px));
  padding-bottom: clamp(44px, 5vw, 66px);
  display: flex;
  align-items: center;
}
.hero > .container{
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.hero-grid{
  grid-template-columns: minmax(0, 1.08fr) minmax(420px, .92fr);
  gap: clamp(42px, 5vw, 72px);
}
.hero h1{
  font-size: clamp(56px, 7.2vw, 96px);
  margin-bottom: 24px;
}
.hero-lead{ margin-bottom: 30px; }
.hero-ctas{ margin-bottom: 30px; }
.guard-panel{
  width: 100%;
  max-height: min(580px, 62vh);
}
.hero .seals{
  margin-top: clamp(34px, 4vw, 48px);
  padding-top: 24px;
  padding-bottom: 0;
}
.hero .seals-row{
  display: grid;
  grid-template-columns: repeat(2, minmax(260px, 1fr));
  gap: 14px;
  max-width: 820px;
}
.hero .seal--logo{
  min-width: 0;
  width: 100%;
}
.hero .seal-meta-block strong{
  font-family: var(--display);
  text-transform: uppercase;
  line-height: 1.05;
}

@media (max-width: 980px){
  .hero{
    padding-top: calc(var(--header-h) + 34px);
    padding-bottom: 64px;
    align-items: flex-start;
  }
  .hero-grid{
    grid-template-columns: 1fr;
    gap: 34px;
  }
  .guard-panel{
    max-height: none;
    aspect-ratio: 16 / 10;
    padding: 24px;
  }
  .guard-figure{
    height: auto;
    aspect-ratio: 16 / 8.5;
  }
  .hero .seals{
    margin-top: 38px;
  }
  .hero .seals-row{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-width: 100%;
  }
}

@media (max-width: 620px){
  .hero{
    min-height: 100svh;
    padding-top: calc(var(--header-h) + 22px);
    padding-bottom: 92px; /* deja aire antes del final y del botón WhatsApp */
  }
  .hero-tag{
    font-size: 9px;
    letter-spacing: .18em;
    gap: 8px;
    margin-bottom: 14px;
  }
  .hero h1{
    font-size: clamp(42px, 13vw, 58px);
    margin-bottom: 18px;
  }
  .hero h1 [aria-hidden="true"]{
    width: 112px !important;
    height: 4px !important;
    margin-top: 14px !important;
  }
  .hero-lead{
    font-size: 15px;
    line-height: 1.58;
    margin-bottom: 24px;
  }
  .hero-ctas{
    gap: 12px;
    margin-bottom: 26px;
  }
  .hero-support{
    font-size: 11px;
    line-height: 1.6;
    max-width: 100%;
  }
  .guard-panel{
    aspect-ratio: auto;
    padding: 14px;
    border-radius: 8px;
  }
  .guard-panel .panel-head{
    font-size: 8.5px;
    letter-spacing: .14em;
    gap: 8px;
    margin-bottom: 12px;
    padding-bottom: 10px;
    white-space: nowrap;
  }
  .guard-figure{
    height: auto;
    aspect-ratio: 16 / 9;
    margin-bottom: 12px;
  }
  .guard-photo{
    object-position: center 42%;
  }
  .guard-stats{
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  .gstat{
    padding: 10px;
  }
  .gstat .k{
    font-size: 8.5px;
    letter-spacing: .14em;
  }
  .gstat .v{
    font-size: 15px;
  }
  .hero .seals{
    margin-top: 34px;
    padding-top: 24px;
    padding-bottom: 22px;
  }
  .hero .seals .label{
    margin-bottom: 14px;
  }
  .hero .seals-row{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }
  .hero .seal--logo{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    min-height: 86px;
    padding: 12px 10px;
    gap: 8px;
  }
  .hero .seal-logo-wrap{
    width: 70px;
    height: 36px;
  }
  .hero .seal-logo-img{
    max-width: 70px;
    max-height: 34px;
  }
  .hero .seal-meta-block{
    align-items: center;
  }
  .hero .seal-meta-block strong{
    font-size: 11px;
    letter-spacing: .08em;
  }
  .hero .seal-meta-block small{
    display: none;
  }
  .wa-float{
    width: 54px;
    height: 54px;
    right: 18px;
    bottom: 18px;
  }
}

@media (max-width: 380px){
  .hero .seals-row{
    grid-template-columns: 1fr;
  }
  .hero .seal--logo{
    min-height: 74px;
    flex-direction: row;
    justify-content: flex-start;
    text-align: left;
    padding: 12px 14px;
  }
  .hero .seal-meta-block{
    align-items: flex-start;
  }
  .hero .seal-meta-block small{
    display: block;
    font-size: 9px;
    line-height: 1.35;
  }
}

/* ========== Legal pages ========== */
.legal-page{
  padding: 80px 0 100px;
  min-height: 60vh;
}
.legal-page .legal-header{
  margin-bottom: 48px;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--gray-200);
}
.legal-page .legal-header .eyebrow{
  display: block;
  margin-bottom: 12px;
}
.legal-page h1{
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.15;
  margin-bottom: 16px;
}
.legal-page .legal-meta{
  font-size: 13px;
  color: var(--gray-500);
  font-family: var(--mono);
  letter-spacing: .05em;
  text-transform: uppercase;
}
.legal-body{
  max-width: 820px;
}
.legal-body h2{
  font-size: clamp(18px, 1.8vw, 24px);
  margin-top: 48px;
  margin-bottom: 16px;
  color: var(--black);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.legal-body h3{
  font-size: 16px;
  margin-top: 28px;
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--black);
}
.legal-body p{
  font-size: 15px;
  color: var(--gray-600, #444);
  line-height: 1.8;
  margin-bottom: 16px;
}
.legal-body ul{
  margin: 0 0 20px 20px;
  display: grid;
  gap: 8px;
}
.legal-body ul li{
  font-size: 15px;
  color: var(--gray-600, #444);
  line-height: 1.7;
}
.legal-body a{
  color: var(--red);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.legal-body a:hover{ opacity: .8 }
.legal-body .highlight-box{
  background: var(--gray-100, #f5f5f5);
  border-left: 3px solid var(--red);
  padding: 20px 24px;
  margin: 28px 0;
  border-radius: 0 4px 4px 0;
}
.legal-body .highlight-box p{ margin-bottom: 0; font-size: 14px; }

/* ── Footer legal links ── */
.foot-legal{
  display: flex;
  flex-wrap: wrap;
  gap: 4px 20px;
  align-items: center;
}
.foot-legal a{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: var(--gray-500);
  text-decoration: none;
  transition: color .2s;
}
.foot-legal a:hover{ color: var(--red) }
@media(max-width:640px){
  .foot-legal{ justify-content: center; }
}
