/* ============================================================
   GearPower — styles.css v3.0 DARK CORPORATE PREMIUM
   Filosofía: SpaceX / Palantir — Negro · Ámbar quirúrgico · Blanco
   ============================================================ */

/* ─── RESET & ROOT ───────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  /* Colores */
  --bg:           #080808;
  --bg-1:         #0e0e0e;
  --bg-2:         #141414;
  --bg-3:         #1c1c1c;
  --border:       rgba(255,255,255,0.07);
  --border-amber: rgba(240,165,0,0.3);
  --amber:        #f0a500;
  --amber-l:      #f7c24e;
  --amber-d:      #c47d00;
  --amber-glow:   rgba(240,165,0,0.12);
  --white:        #ffffff;
  --off:          #f0eeea;
  --g1:           #cccccc;
  --g2:           #888888;
  --g3:           #444444;

  /* Tipografía */
  --f-disp:  'Bebas Neue', sans-serif;
  --f-head:  'Barlow Condensed', sans-serif;
  --f-body:  'Inter', sans-serif;

  /* Utilidades */
  --r:      0px;          /* sin border-radius — estilo industrial duro */
  --r-sm:   3px;
  --tr:     0.4s cubic-bezier(0.4,0,0.2,1);
  --tr-s:   0.7s cubic-bezier(0.4,0,0.2,1);
  --sh-amb: 0 0 60px rgba(240,165,0,0.18);
  --sh-drk: 0 20px 60px rgba(0,0,0,0.7);
}

html { scroll-behavior:smooth; font-size:16px; }

body {
  font-family: var(--f-body);
  background: var(--bg);
  color: var(--off);
  line-height: 1.65;
  overflow-x: hidden;
}

img { max-width:100%; display:block; }
a   { text-decoration:none; color:inherit; }
ul  { list-style:none; }

.container {
  width:100%; max-width:1240px;
  margin:0 auto; padding:0 40px;
}

.sec { padding:130px 0; position:relative; }

/* ─── SCROLL PROGRESS BAR ────────────────────────────────────── */
.spb {
  position:fixed; top:0; left:0;
  height:2px; width:0%;
  background: linear-gradient(90deg, var(--amber-d), var(--amber), var(--amber-l));
  z-index:9999;
  transition: width .08s linear;
}

/* ─── TIPOGRAFÍA GLOBAL ──────────────────────────────────────── */
h2 {
  font-family: var(--f-head);
  font-size: clamp(2.2rem, 4.5vw, 4rem);
  font-weight: 700;
  line-height: 1.08;
  color: var(--white);
}
h3 {
  font-family: var(--f-head);
  font-size: clamp(1.15rem, 2vw, 1.5rem);
  font-weight: 700;
  line-height: 1.2;
  color: var(--white);
}
h4 {
  font-family: var(--f-head);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--white);
}

.accent { color: var(--amber); }

.eyebrow {
  font-family: var(--f-head);
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--amber);
  margin-bottom: 16px;
  display: flex; align-items: center; gap: 12px;
}
.eyebrow::before {
  content:'';
  display:inline-block;
  width:32px; height:1px;
  background:var(--amber);
  flex-shrink:0;
}
.eyebrow--light { color:var(--amber); }

.body-t {
  font-size: 1rem;
  color: var(--g1);
  margin-bottom: 24px;
  max-width: 540px;
  line-height: 1.75;
}
.body-t strong { color:var(--white); font-weight:600; }
.body-t--light { color:rgba(255,255,255,0.72); }

.sec-header {
  text-align:center;
  margin-bottom:80px;
}
.sec-header .eyebrow { justify-content:center; }
.sec-header .eyebrow::before { display:none; }
.sec-desc {
  font-size:1rem;
  color:var(--g2);
  max-width:580px;
  margin:18px auto 0;
  line-height:1.75;
}

/* ─── BOTONES ────────────────────────────────────────────────── */
.btn-prim {
  display:inline-flex; align-items:center; gap:10px;
  padding:15px 36px;
  background:var(--amber);
  color:var(--bg);
  font-family:var(--f-head);
  font-size:.95rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  border:none; cursor:pointer;
  transition:var(--tr);
  position:relative; overflow:hidden;
}
.btn-prim::after {
  content:'';
  position:absolute; inset:0;
  background:rgba(0,0,0,0.12);
  opacity:0;
  transition:opacity var(--tr);
}
.btn-prim:hover {
  background:var(--amber-l);
  transform:translateY(-2px);
  box-shadow:var(--sh-amb);
}
.btn-prim:hover::after { opacity:1; }

.btn-ghost {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 32px;
  background:transparent;
  color:var(--white);
  font-family:var(--f-head);
  font-size:.95rem;
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  border:1px solid var(--border);
  cursor:pointer;
  transition:var(--tr);
}
.btn-ghost:hover {
  border-color:var(--amber);
  color:var(--amber);
  transform:translateY(-2px);
}

.btn-line {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--f-head);
  font-size:.85rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--amber);
  border-bottom:1px solid rgba(240,165,0,0.3);
  padding-bottom:4px;
  transition:var(--tr);
}
.btn-line:hover {
  border-color:var(--amber);
  gap:14px;
}

.btn-full { width:100%; justify-content:center; }

.req { color:var(--amber); }

/* ─── REVEAL ANIMATIONS ──────────────────────────────────────── */
.r-up, .r-left, .r-right {
  opacity:0;
  transition: opacity .9s cubic-bezier(.4,0,.2,1),
              transform .9s cubic-bezier(.4,0,.2,1);
}
.r-up    { transform:translateY(36px); }
.r-left  { transform:translateX(-44px); }
.r-right { transform:translateX(44px); }

.vis {
  opacity:1 !important;
  transform:none !important;
}

.d1 { transition-delay:.1s; }
.d2 { transition-delay:.2s; }
.d3 { transition-delay:.3s; }
.d4 { transition-delay:.4s; }

/* ═══════════════════════════════════════════════════════════════
   LOADER — Dark Corporate Premium
   ═══════════════════════════════════════════════════════════════ */
#loader {
  position:fixed; inset:0; z-index:99999;
  background:var(--bg);
  display:flex; align-items:center; justify-content:center;
  transition: opacity .9s ease, visibility .9s ease;
  overflow:hidden;
}
#loader.done { opacity:0; visibility:hidden; pointer-events:none; }

/* Grid sutil del loader */
.ldr-grid {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(240,165,0,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(240,165,0,.03) 1px, transparent 1px);
  background-size:64px 64px;
  opacity:0;
  animation: ldrGridIn .6s .2s ease forwards;
}
@keyframes ldrGridIn { to { opacity:1; } }

/* Esquinas del loader */
.ldr-corner {
  position:absolute;
  width:32px; height:32px;
}
.ldr-corner::before,
.ldr-corner::after { content:''; position:absolute; background:var(--amber); }
.ldr-corner::before { width:100%; height:1px; }
.ldr-corner::after  { width:1px; height:100%; }

.ldr-tl { top:28px; left:28px; }
.ldr-tl::before { top:0; left:0; }
.ldr-tl::after  { top:0; left:0; }
.ldr-tr { top:28px; right:28px; }
.ldr-tr::before { top:0; right:0; }
.ldr-tr::after  { top:0; right:0; }
.ldr-bl { bottom:28px; left:28px; }
.ldr-bl::before { bottom:0; left:0; }
.ldr-bl::after  { bottom:0; left:0; }
.ldr-br { bottom:28px; right:28px; }
.ldr-br::before { bottom:0; right:0; }
.ldr-br::after  { bottom:0; right:0; }

.ldr-body {
  text-align:center;
  position:relative; z-index:2;
  animation: ldrBodyIn .5s ease both;
}
@keyframes ldrBodyIn {
  from { opacity:0; transform:translateY(16px); }
  to   { opacity:1; transform:translateY(0); }
}

.ldr-logo-wrap {
  margin-bottom:40px;
}
.ldr-logo-img {
  max-height:80px;
  margin:0 auto;
  filter:brightness(0) invert(1);
  animation: ldrLogoPulse 2s ease infinite;
}
@keyframes ldrLogoPulse {
  0%,100% { opacity:1; }
  50%      { opacity:.5; filter:brightness(0) invert(1) drop-shadow(0 0 16px rgba(240,165,0,.7)); }
}
#ldr-fb {
  font-family:var(--f-disp);
  font-size:3rem;
  letter-spacing:8px;
  color:var(--white);
}
#ldr-fb em { color:var(--amber); font-style:normal; }

.ldr-line-wrap {
  width:260px; height:1px;
  background:var(--bg-3);
  margin:0 auto 20px;
  position:relative;
  overflow:hidden;
}
.ldr-line {
  height:100%;
  background:linear-gradient(90deg, var(--amber-d), var(--amber-l));
  width:0%;
  box-shadow:0 0 8px var(--amber);
  transition:width .08s linear;
}

.ldr-bottom {
  display:flex; align-items:center; justify-content:space-between;
  width:260px; margin:0 auto;
}
.ldr-label {
  font-family:var(--f-head);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--g2);
}
.ldr-pct {
  font-family:var(--f-disp);
  font-size:1.1rem;
  color:var(--amber);
  letter-spacing:.08em;
}

/* ═══════════════════════════════════════════════════════════════
   NAVBAR — Línea fina, fondo oscuro al hacer scroll
   ═══════════════════════════════════════════════════════════════ */
.nav {
  position:fixed; top:0; left:0; width:100%;
  z-index:1000;
  padding:22px 0;
  transition:var(--tr);
}
.nav.scrolled {
  background:rgba(8,8,8,.97);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  padding:14px 0;
}

.nav-wrap {
  max-width:1240px; margin:0 auto; padding:0 40px;
  display:flex; align-items:center; justify-content:space-between;
}

.nav-brand { display:flex; align-items:center; }
.nav-brand-img {
  height:40px;
  filter:brightness(0) invert(1);
  transition:var(--tr);
}
.nav-brand:hover .nav-brand-img {
  filter:brightness(0) invert(1) drop-shadow(0 0 6px rgba(240,165,0,.5));
}
.nav-brand-text {
  font-family:var(--f-disp);
  font-size:1.8rem; letter-spacing:3px;
  color:var(--white);
}
.nav-brand-text em { color:var(--amber); font-style:normal; }

.nav-list {
  display:flex; align-items:center; gap:36px;
}
.nav-a {
  font-family:var(--f-head);
  font-size:.82rem;
  font-weight:600;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(255,255,255,.6);
  transition:color var(--tr);
  position:relative; padding-bottom:4px;
}
.nav-a::after {
  content:'';
  position:absolute; bottom:0; left:0;
  width:0; height:1px;
  background:var(--amber);
  transition:width var(--tr);
}
.nav-a:hover, .nav-a.active { color:var(--white); }
.nav-a:hover::after, .nav-a.active::after { width:100%; }

.nav-a--cta {
  padding:8px 20px;
  border:1px solid var(--amber);
  color:var(--amber) !important;
}
.nav-a--cta::after { display:none; }
.nav-a--cta:hover { background:var(--amber); color:var(--bg) !important; }

.nav-a--muted { color:var(--g3) !important; }
.nav-a--muted:hover { color:var(--g2) !important; }

.nav-burger {
  display:none; flex-direction:column; gap:7px;
  cursor:pointer; border:none; background:none; padding:4px;
}
.nav-burger span {
  display:block; width:24px; height:1px;
  background:var(--white); transition:var(--tr);
}
.nav-burger.open span:nth-child(1) { transform:translateY(8px) rotate(45deg); }
.nav-burger.open span:nth-child(2) { opacity:0; }

/* ═══════════════════════════════════════════════════════════════
   HERO — Dark Corporate Premium
   ═══════════════════════════════════════════════════════════════ */
.hero {
  position:relative;
  height:100vh; min-height:700px;
  display:flex; align-items:center;
  overflow:hidden;
}

.hero-vid {
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover; z-index:0;
}
.hero-scrim {
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(
    135deg,
    rgba(8,8,8,.95) 0%,
    rgba(8,8,8,.72) 55%,
    rgba(8,8,8,.88) 100%
  );
}
.hero-canvas {
  position:absolute; inset:0; z-index:2;
  pointer-events:none;
}

.hero-body {
  position:relative; z-index:10;
  padding-top:90px;
}

/* Meta badge */
.hero-meta {
  display:flex; align-items:center; gap:14px;
  margin-bottom:24px;
}
.hero-meta-line {
  display:block; width:40px; height:1px;
  background:var(--amber);
  flex-shrink:0;
}
.hero-meta-text {
  font-family:var(--f-head);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--amber);
}

/* H1 masivo — estilo SpaceX */
.hero-h1 {
  font-family:var(--f-disp);
  font-size:clamp(4rem, 10vw, 10rem);
  letter-spacing:.04em;
  line-height:.92;
  margin-bottom:32px;
  display:flex; flex-direction:column;
}
.h1-fill {
  color:var(--white);
}
.h1-stroke {
  color:transparent;
  -webkit-text-stroke:1.5px rgba(255,255,255,.35);
  text-stroke:1.5px rgba(255,255,255,.35);
}

.hero-copy {
  font-size:clamp(.95rem,1.6vw,1.1rem);
  color:rgba(255,255,255,.6);
  max-width:520px;
  margin-bottom:40px;
  line-height:1.8;
}
.hero-copy strong { color:var(--amber); font-weight:500; }

.hero-actions {
  display:flex; flex-wrap:wrap; gap:14px;
  margin-bottom:56px;
}

/* Stats en el hero */
.hero-stats {
  display:flex; align-items:center;
  margin-bottom:52px;
  padding:24px 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.hstat {
  display:flex; flex-direction:column;
  padding:0 36px;
}
.hstat:first-child { padding-left:0; }
.hstat-n {
  font-family:var(--f-disp);
  font-size:2.6rem;
  color:var(--amber);
  line-height:1;
}
.hstat-s { font-size:1.4rem; color:var(--amber); }
.hstat-l {
  font-size:.72rem;
  color:var(--g2);
  letter-spacing:.1em;
  text-transform:uppercase;
  margin-top:4px;
  font-family:var(--f-head);
}
.hstat-sep {
  width:1px; height:36px;
  background:var(--border);
  flex-shrink:0;
}

/* Logos de representaciones en el hero */
.hero-reps {
  display:flex; align-items:center; gap:20px;
  flex-wrap:wrap;
}
.hero-reps-label {
  font-family:var(--f-head);
  font-size:.72rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--g2);
}
.hero-reps-logos {
  display:flex; align-items:center; gap:20px;
}
.hero-rep-item {
  display:flex; flex-direction:column; align-items:center; gap:4px;
}
.hero-rep-item img {
  max-height:28px; max-width:90px;
  filter:brightness(0) invert(.55);
  transition:var(--tr);
}
.hero-rep-item:hover img { filter:brightness(0) invert(1); }
.hero-rep-item small {
  font-size:.6rem;
  color:var(--amber);
  letter-spacing:.1em;
  text-transform:uppercase;
  font-family:var(--f-head);
}
.hero-rep-item b {
  font-family:var(--f-disp);
  font-size:1.1rem;
  letter-spacing:.08em;
  color:rgba(255,255,255,.5);
}
.hero-rep-div {
  width:1px; height:36px;
  background:var(--border);
}

/* Scroll cue */
.hero-scroll-cue {
  position:absolute; bottom:44px; left:50%;
  transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px;
  z-index:10;
}
.hsc-line {
  width:1px; height:56px;
  background:linear-gradient(to bottom, var(--amber), transparent);
  animation:hscPulse 2s ease infinite;
}
@keyframes hscPulse {
  0%   { transform:scaleY(0); transform-origin:top; }
  50%  { transform:scaleY(1); }
  100% { transform:scaleY(0); transform-origin:bottom; }
}
.hsc-text {
  font-family:var(--f-head);
  font-size:.65rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--g2);
  writing-mode:vertical-rl;
}

/* ═══════════════════════════════════════════════════════════════
   TICKER
   ═══════════════════════════════════════════════════════════════ */
.ticker {
  overflow:hidden;
  border-top:1px solid var(--border-amber);
  border-bottom:1px solid var(--border-amber);
  padding:12px 0;
  background:rgba(240,165,0,.04);
}
.ticker-inner {
  display:inline-flex; align-items:center; gap:24px;
  white-space:nowrap;
  animation:tickScroll 24s linear infinite;
}
.ticker-inner span {
  font-family:var(--f-head);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(240,165,0,.7);
}
.ticker-inner em {
  color:rgba(240,165,0,.25);
  font-style:normal;
  font-size:.5rem;
}
@keyframes tickScroll {
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}

/* ═══════════════════════════════════════════════════════════════
   NOSOTROS
   ═══════════════════════════════════════════════════════════════ */
.nosotros {
  background:var(--bg-1);
  border-bottom:1px solid var(--border);
}

.nos-grid {
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:80px; align-items:center;
}

.nos-img-frame { position:relative; }
.nos-img {
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
  display:block;
  filter:grayscale(20%) contrast(1.05);
  transition:var(--tr-s);
}
.nos-img-frame:hover .nos-img { filter:grayscale(0%) contrast(1); }

.nos-img-border {
  position:absolute;
  top:16px; left:16px; right:-16px; bottom:-16px;
  border:1px solid var(--border-amber);
  pointer-events:none;
  z-index:-1;
  transition:var(--tr-s);
}
.nos-img-frame:hover .nos-img-border {
  border-color:var(--amber);
  box-shadow:var(--sh-amb);
}

.nos-img-tag {
  position:absolute; bottom:20px; left:-20px;
  background:var(--amber);
  color:var(--bg);
  font-family:var(--f-head);
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  padding:10px 18px;
  display:flex; align-items:center; gap:8px;
  box-shadow:var(--sh-drk);
}

.nos-badge-float {
  position:absolute; top:20px; right:-20px;
  background:var(--bg-2);
  border:1px solid var(--border-amber);
  padding:12px 16px;
  display:flex; align-items:center; gap:12px;
  box-shadow:var(--sh-drk);
  animation:floatBadge 3.5s ease infinite;
}
@keyframes floatBadge {
  0%,100% { transform:translateY(0); }
  50%      { transform:translateY(-5px); }
}
.nbf-icon {
  width:36px; height:36px;
  background:var(--amber-glow);
  border:1px solid var(--border-amber);
  display:flex; align-items:center; justify-content:center;
  color:var(--amber); font-size:1rem; flex-shrink:0;
}
.nbf-txt { display:flex; flex-direction:column; gap:2px; }
.nbf-txt strong {
  font-family:var(--f-head); font-size:.85rem;
  font-weight:700; color:var(--white); white-space:nowrap;
}
.nbf-txt span {
  font-size:.7rem; color:var(--amber);
  font-family:var(--f-head); letter-spacing:.06em;
}

.nos-txt-col h2 { margin-bottom:24px; }

/* Banderas */
.flags-block {
  display:flex; flex-direction:column; gap:10px;
  margin:28px 0 32px;
  padding:20px;
  background:var(--bg-2);
  border:1px solid var(--border);
  border-left:2px solid var(--amber);
}
.flag-row {
  display:flex; align-items:center; gap:14px;
}
.flag-img {
  width:34px; height:22px;
  object-fit:cover;
  border:1px solid var(--border);
  flex-shrink:0;
}
.flag-info { display:flex; flex-direction:column; gap:2px; }
.flag-info strong {
  font-family:var(--f-head); font-size:.9rem;
  font-weight:700; color:var(--white);
}
.flag-info span { font-size:.8rem; color:var(--g2); }

/* Pills */
.pills-row {
  display:flex; flex-wrap:wrap; gap:10px;
  margin-top:32px;
}
.pill {
  display:flex; align-items:center; gap:8px;
  padding:9px 16px;
  background:var(--bg-2);
  border:1px solid var(--border);
  font-family:var(--f-head);
  font-size:.82rem; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase;
  color:var(--g1);
  transition:var(--tr);
  cursor:default;
}
.pill i { color:var(--amber); font-size:.85rem; }
.pill:hover { border-color:var(--amber); color:var(--amber); background:rgba(240,165,0,.05); }

/* ═══════════════════════════════════════════════════════════════
   NÚMEROS — Parallax + contadores
   ═══════════════════════════════════════════════════════════════ */
.numeros {
  position:relative; overflow:hidden; padding:110px 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.numeros-bg-img {
  position:absolute; inset:-40px;
  background-size:cover; background-position:center;
  background-attachment:fixed;
  z-index:0;
}
.numeros-scrim {
  position:absolute; inset:0;
  background:rgba(8,8,8,.9);
  z-index:1;
}
.numeros-inner {
  position:relative; z-index:2;
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:0;
}

.num-card {
  padding:48px 36px;
  text-align:center;
  border-right:1px solid var(--border);
  position:relative; overflow:hidden;
  transition:var(--tr);
}
.num-card:last-child { border-right:none; }
.num-card::after {
  content:'';
  position:absolute; bottom:0; left:0;
  width:100%; height:2px;
  background:linear-gradient(90deg, var(--amber-d), var(--amber-l));
  transform:scaleX(0); transform-origin:left;
  transition:transform var(--tr);
}
.num-card:hover::after { transform:scaleX(1); }

.num-icon {
  width:56px; height:56px;
  border:1px solid var(--border-amber);
  background:var(--amber-glow);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 20px;
  font-size:1.4rem; color:var(--amber);
  transition:var(--tr);
}
.num-card:hover .num-icon {
  background:var(--amber);
  color:var(--bg);
  border-color:var(--amber);
  box-shadow:var(--sh-amb);
}

.num-val {
  font-family:var(--f-disp);
  font-size:clamp(3rem,5vw,4.5rem);
  color:var(--amber);
  line-height:1;
  margin-bottom:12px;
}
.num-lbl {
  font-family:var(--f-head);
  font-size:.82rem; color:var(--g2);
  letter-spacing:.06em;
  line-height:1.5;
  max-width:160px; margin:0 auto;
}

/* ═══════════════════════════════════════════════════════════════
   REPRESENTACIONES
   ═══════════════════════════════════════════════════════════════ */
.reps { background:var(--bg); border-bottom:1px solid var(--border); }

.reps-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background:var(--border);
}

.rep-card {
  background:var(--bg-1);
  display:flex; flex-direction:column;
  position:relative; overflow:hidden;
  transition:var(--tr);
}
.rep-card:hover { background:var(--bg-2); }

/* Línea de hover superior */
.rep-card::before {
  content:'';
  position:absolute; top:0; left:0;
  width:100%; height:2px;
  background:linear-gradient(90deg, var(--amber-d), var(--amber-l));
  transform:scaleX(0); transform-origin:left;
  transition:transform var(--tr);
  z-index:2;
}
.rep-card:hover::before { transform:scaleX(1); }

.rep-card--future {
  border:1px dashed var(--border);
  background:transparent;
}
.rep-card--future:hover { background:rgba(240,165,0,.02); }

/* Ribbon */
.rep-ribbon {
  position:absolute; top:18px; right:-32px;
  background:var(--amber);
  color:var(--bg);
  font-family:var(--f-head); font-size:.62rem;
  font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  padding:4px 44px;
  transform:rotate(35deg);
  white-space:nowrap; z-index:3;
}
.rep-ribbon--b { background:#1a6bb5; color:var(--white); }

.rep-card-top {
  padding:30px 28px 20px;
  display:flex; align-items:center; justify-content:space-between;
  border-bottom:1px solid var(--border);
}
.rep-logo-wrap {
  height:48px; display:flex; align-items:center;
}
.rep-logo-wrap img { max-height:44px; max-width:150px; object-fit:contain; }
.rep-name {
  font-family:var(--f-disp);
  font-size:1.7rem; letter-spacing:.1em; color:var(--amber);
}
.rep-logo-plus {
  width:44px; height:44px;
  border:1px dashed var(--border-amber);
  display:flex; align-items:center; justify-content:center;
  color:var(--amber); font-size:1.2rem;
}
.rep-origin {
  font-family:var(--f-head);
  font-size:.7rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--g2);
  padding:4px 12px;
  border:1px solid var(--border);
  display:flex; align-items:center; gap:6px;
}
.rep-flag { width:16px; height:11px; object-fit:cover; }

.rep-body { padding:24px 28px; flex:1; }
.rep-body h3 {
  font-family:var(--f-disp); font-size:1.9rem;
  letter-spacing:.06em; margin-bottom:12px;
}
.rep-body p { font-size:.92rem; color:var(--g2); line-height:1.7; margin-bottom:20px; }

.rep-list {
  display:flex; flex-direction:column; gap:8px;
  margin-bottom:20px;
}
.rep-list li {
  font-size:.86rem; color:var(--g1);
  padding-left:14px; position:relative;
}
.rep-list li::before {
  content:'—';
  position:absolute; left:0;
  color:var(--amber); font-weight:700;
}

.rep-tags {
  display:flex; gap:12px; flex-wrap:wrap;
  padding-top:16px;
  border-top:1px solid var(--border);
}
.rep-tags span {
  font-family:var(--f-head);
  font-size:.72rem; color:var(--g2);
  display:flex; align-items:center; gap:5px;
}
.rep-tags i { color:var(--amber); font-size:.65rem; }

.rep-foot { padding:20px 28px 28px; }

/* Pulso futuro */
.future-pulse {
  display:flex; gap:8px; margin-top:20px;
}
.future-pulse span {
  width:6px; height:6px;
  background:rgba(240,165,0,.25);
  animation:fpulse 1.5s ease infinite;
}
.future-pulse span:nth-child(2) { animation-delay:.2s; }
.future-pulse span:nth-child(3) { animation-delay:.4s; }
@keyframes fpulse {
  0%,100% { background:rgba(240,165,0,.15); }
  50%      { background:var(--amber); }
}

/* ═══════════════════════════════════════════════════════════════
   SECTORES
   ═══════════════════════════════════════════════════════════════ */
.sectores { background:var(--bg-1); border-bottom:1px solid var(--border); }

.sectors-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:1px; background:var(--border);
}

.sector-card {
  position:relative; overflow:hidden;
  aspect-ratio:3/4;
  cursor:pointer;
}
.sector-bg-img {
  position:absolute; inset:0;
  background-image:var(--sbg);
  background-size:cover; background-position:center;
  transition:transform .6s ease;
  z-index:0;
  filter:grayscale(40%) brightness(.7);
}
.sector-card:hover .sector-bg-img {
  transform:scale(1.06);
  filter:grayscale(0%) brightness(.8);
}
.sector-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top,
    rgba(8,8,8,.97) 0%,
    rgba(8,8,8,.5) 50%,
    rgba(8,8,8,.15) 100%);
  z-index:1;
  transition:var(--tr);
}
.sector-cnt {
  position:absolute; bottom:0; left:0; right:0;
  padding:28px 24px;
  z-index:2;
}
.sector-ico {
  width:44px; height:44px;
  background:var(--amber);
  color:var(--bg);
  display:flex; align-items:center; justify-content:center;
  font-size:1.1rem;
  margin-bottom:14px;
  transition:var(--tr);
}
.sector-card:hover .sector-ico {
  box-shadow:0 0 20px rgba(240,165,0,.5);
}
.sector-cnt h3 { font-size:1.3rem; margin-bottom:8px; }
.sector-cnt p {
  font-size:.85rem; color:rgba(255,255,255,.6); line-height:1.55;
  margin-bottom:14px;
  max-height:0; overflow:hidden;
  opacity:0; transition:max-height .4s ease, opacity .4s ease;
}
.sector-card:hover .sector-cnt p { max-height:80px; opacity:1; }
.sector-lnk {
  display:inline-flex; align-items:center; gap:7px;
  font-family:var(--f-head); font-size:.78rem;
  font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--amber); transition:gap var(--tr);
}
.sector-lnk:hover { gap:12px; }

/* ═══════════════════════════════════════════════════════════════
   DIFERENCIADORES
   ═══════════════════════════════════════════════════════════════ */
.soluciones { background:var(--bg); border-bottom:1px solid var(--border); }

.dif-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:1px; background:var(--border);
}
.dif-card {
  padding:44px 32px;
  background:var(--bg-1);
  position:relative; overflow:hidden;
  transition:var(--tr);
}
.dif-card:hover { background:var(--bg-2); }
.dif-card::before {
  content:'';
  position:absolute; top:0; left:0;
  width:2px; height:0;
  background:var(--amber);
  transition:height var(--tr);
}
.dif-card:hover::before { height:100%; }

.dif-num {
  font-family:var(--f-disp);
  font-size:5rem; color:rgba(240,165,0,.05);
  line-height:1; position:absolute;
  top:12px; right:16px; pointer-events:none;
}
.dif-ico {
  width:52px; height:52px;
  border:1px solid var(--border-amber);
  background:var(--amber-glow);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:22px; font-size:1.3rem; color:var(--amber);
  transition:var(--tr);
}
.dif-card:hover .dif-ico {
  background:var(--amber); color:var(--bg);
  border-color:var(--amber);
  box-shadow:var(--sh-amb);
}
.dif-card h3 { margin-bottom:14px; font-size:1.1rem; }
.dif-card p { font-size:.9rem; color:var(--g2); line-height:1.7; }

/* ═══════════════════════════════════════════════════════════════
   PROCESO
   ═══════════════════════════════════════════════════════════════ */
.proceso { background:var(--bg-1); border-bottom:1px solid var(--border); }

.proceso-wrap {
  position:relative;
  display:grid; grid-template-columns:repeat(5,1fr);
  gap:0;
}
.proceso-spine {
  position:absolute;
  top:46px; left:calc(10% + 20px); right:calc(10% + 20px);
  height:1px;
  background:linear-gradient(90deg, var(--amber), rgba(240,165,0,.1));
}

.proceso-step {
  display:flex; flex-direction:column; align-items:center;
  text-align:center; padding:0 12px;
  position:relative;
}
.ps-num {
  position:absolute; top:-10px; left:50%;
  transform:translateX(-50%);
  font-family:var(--f-disp); font-size:4rem;
  color:rgba(240,165,0,.04);
  line-height:1; pointer-events:none;
}
.ps-ico {
  width:54px; height:54px;
  border:1px solid var(--border-amber);
  background:var(--bg);
  display:flex; align-items:center; justify-content:center;
  font-size:1.3rem; color:var(--amber);
  margin-bottom:20px; position:relative; z-index:1;
  transition:var(--tr);
}
.proceso-step:hover .ps-ico {
  background:var(--amber); color:var(--bg);
  border-color:var(--amber);
  box-shadow:var(--sh-amb);
}
.ps-body h4 { margin-bottom:8px; font-size:.9rem; }
.ps-body p { font-size:.82rem; color:var(--g2); line-height:1.65; }

/* ═══════════════════════════════════════════════════════════════
   FOGMAKER
   ═══════════════════════════════════════════════════════════════ */
.fogmaker-sec {
  position:relative; overflow:hidden;
  border-bottom:1px solid var(--border);
}
.fog-bg-wrap { position:absolute; inset:0; z-index:0; }
.fog-bg-img { width:100%; height:100%; object-fit:cover; filter:grayscale(30%); }
.fog-bg-scrim {
  position:absolute; inset:0;
  background:linear-gradient(
    90deg,
    rgba(8,8,8,.98) 0%,
    rgba(8,8,8,.92) 55%,
    rgba(8,8,8,.7) 100%
  );
}
.fog-inner {
  position:relative; z-index:1;
  display:grid; grid-template-columns:1.1fr 1fr;
  gap:80px; align-items:center;
  padding-top:130px; padding-bottom:130px;
}
.fog-text h2 { margin-bottom:24px; }

.fog-stats-row {
  display:flex; gap:28px; flex-wrap:wrap;
  padding:28px 0;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
  margin:32px 0;
}
.fog-stat-n {
  display:block;
  font-family:var(--f-disp); font-size:2.2rem;
  color:var(--amber); line-height:1;
}
.fog-stat-n small { font-size:1rem; }
.fog-stat-d {
  display:block; font-size:.78rem; color:var(--g2); margin-top:4px;
}

.fog-checks {
  display:flex; flex-direction:column; gap:12px;
  margin-bottom:40px;
}
.fog-checks li {
  display:flex; align-items:center; gap:12px;
  font-size:.95rem; color:rgba(255,255,255,.8);
}
.fog-checks li i { color:var(--amber); font-size:.75rem; flex-shrink:0; }

/* Triángulo del fuego */
.tri-wrap {
  position:relative;
  width:320px; height:300px;
  margin:0 auto 28px;
}
.tri-svg { position:absolute; inset:0; width:100%; height:100%; }
.tri-poly {
  fill:rgba(240,165,0,.03);
  stroke:rgba(240,165,0,.2);
  stroke-width:1;
  stroke-dasharray:6 4;
  animation:triDash 18s linear infinite;
}
@keyframes triDash {
  to { stroke-dashoffset:-200; }
}
.tri-inner {
  stroke:rgba(240,165,0,.06); stroke-width:1; stroke-dasharray:3 3;
}

.tri-node {
  position:absolute;
  width:92px; height:92px;
  background:var(--bg-2);
  border:1px solid var(--border-amber);
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  gap:5px; transition:var(--tr);
}
.tri-node:hover {
  border-color:var(--amber);
  box-shadow:var(--sh-amb);
  z-index:5;
}
.tri-node i { font-size:1.5rem; color:var(--amber); }
.tri-node span {
  font-family:var(--f-head); font-size:.7rem;
  font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--g1);
}

#fn-o { top:0; left:50%; transform:translateX(-50%); }
#fn-h { bottom:0; left:4%; }
#fn-f { bottom:0; right:4%; }

.tri-center {
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-38%);
  width:84px; height:84px;
}
.tri-ring {
  position:absolute; border:1px solid rgba(240,165,0,.3);
  animation:triRing 3s ease infinite;
}
.tri-ring-1 { inset:-10px; }
.tri-ring-2 { inset:-20px; border-color:rgba(240,165,0,.12); animation-delay:.6s; }
@keyframes triRing {
  0%,100% { transform:scale(1); opacity:.7; }
  50%      { transform:scale(1.1); opacity:.2; }
}
.tri-core {
  width:84px; height:84px;
  background:linear-gradient(135deg, var(--amber), var(--amber-d));
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 40px rgba(240,165,0,.5);
  overflow:hidden;
}
.tri-core img { max-width:68%; filter:brightness(0); }
.tri-core span {
  font-family:var(--f-disp); font-size:.7rem;
  letter-spacing:.1em; color:var(--bg); font-weight:900;
}

.fog-badges-row {
  display:flex; flex-wrap:wrap; gap:8px; justify-content:center;
}
.fog-badge {
  padding:8px 16px;
  background:rgba(240,165,0,.06);
  border:1px solid var(--border-amber);
  font-family:var(--f-head); font-size:.76rem;
  font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:var(--amber);
  display:flex; align-items:center; gap:8px;
  transition:var(--tr);
}
.fog-badge:hover { background:var(--amber); color:var(--bg); }

/* ═══════════════════════════════════════════════════════════════
   COBERTURA
   ═══════════════════════════════════════════════════════════════ */
.cobertura { background:var(--bg); border-bottom:1px solid var(--border); }

.cob-layout {
  display:grid; grid-template-columns:1.2fr 1fr;
  gap:60px; align-items:start;
}
.cob-map-wrap {
  position:relative;
  border:1px solid var(--border);
}
.cob-map {
  width:100%; display:block;
  filter:grayscale(70%) contrast(1.1) brightness(.75);
  transition:var(--tr-s);
}
.cob-map-wrap:hover .cob-map { filter:grayscale(30%) brightness(.9); }

.map-pin {
  position:absolute;
  display:flex; flex-direction:column; align-items:center; gap:4px;
}
.pin-dot {
  width:10px; height:10px;
  background:var(--amber);
  border:2px solid var(--bg);
  box-shadow:0 0 12px var(--amber);
  animation:pinPulse 2s ease infinite;
}
@keyframes pinPulse {
  0%,100% { box-shadow:0 0 6px var(--amber); }
  50%      { box-shadow:0 0 20px var(--amber), 0 0 40px rgba(240,165,0,.2); }
}
.pin-lbl {
  background:var(--bg-2);
  border:1px solid var(--border-amber);
  padding:5px 10px;
  font-family:var(--f-head); font-size:.74rem;
  font-weight:600; color:var(--white);
  white-space:nowrap;
  display:flex; flex-direction:column; align-items:center;
}
.pin-lbl small { font-size:.62rem; color:var(--amber); font-weight:400; }

.cob-cards { display:flex; flex-direction:column; gap:1px; background:var(--border); }
.cob-card {
  display:flex; gap:18px; align-items:flex-start;
  padding:24px 22px;
  background:var(--bg-1);
  border-left:2px solid transparent;
  transition:var(--tr);
}
.cob-card:hover { border-left-color:var(--amber); background:var(--bg-2); }
.cob-ico {
  width:40px; height:40px;
  background:var(--amber-glow);
  border:1px solid var(--border-amber);
  display:flex; align-items:center; justify-content:center;
  color:var(--amber); font-size:.9rem; flex-shrink:0;
}
.cob-info h4 { font-size:.9rem; margin-bottom:6px; }
.cob-info p { font-size:.82rem; color:var(--g2); line-height:1.6; margin-bottom:10px; }
.cob-tags { display:flex; gap:6px; flex-wrap:wrap; }
.cob-tags span {
  font-family:var(--f-head); font-size:.66rem;
  font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:var(--amber); padding:3px 8px;
  border:1px solid var(--border-amber);
}

/* ═══════════════════════════════════════════════════════════════
   CONTACTO
   ═══════════════════════════════════════════════════════════════ */
.contacto { background:var(--bg-1); border-bottom:1px solid var(--border); }

.contact-grid {
  display:grid; grid-template-columns:1fr 1.2fr;
  gap:80px; align-items:start;
}
.contact-info h2 { margin-bottom:20px; }

.contact-person {
  display:flex; align-items:center; gap:16px;
  margin:32px 0; padding:18px;
  background:var(--bg-2);
  border:1px solid var(--border);
  border-left:2px solid var(--amber);
}
.cp-avatar {
  width:58px; height:58px; object-fit:cover;
  border:1px solid var(--border-amber); flex-shrink:0;
}
.cp-info { display:flex; flex-direction:column; gap:3px; }
.cp-info strong { color:var(--white); font-size:1rem; }
.cp-info span   { color:var(--g2); font-size:.84rem; }
.cp-badge {
  display:flex; align-items:center; gap:6px;
  font-family:var(--f-head); font-size:.7rem;
  font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:var(--amber); margin-top:4px;
}
.cp-badge i { font-size:.55rem; }

.contact-items { display:flex; flex-direction:column; gap:1px; margin-bottom:32px; background:var(--border); }
.ci-item {
  display:flex; align-items:center; gap:16px;
  padding:16px 18px; background:var(--bg-2);
  border-left:2px solid transparent;
  transition:var(--tr);
}
.ci-item:hover { border-left-color:var(--amber); background:var(--bg-3); }
.ci-ico {
  width:40px; height:40px;
  background:var(--amber-glow);
  border:1px solid var(--border-amber);
  display:flex; align-items:center; justify-content:center;
  color:var(--amber); font-size:.9rem; flex-shrink:0;
}
.ci-lbl {
  display:block; font-size:.7rem; color:var(--g2);
  font-family:var(--f-head); letter-spacing:.1em; text-transform:uppercase; margin-bottom:2px;
}
.ci-val { display:block; font-size:.95rem; color:var(--off); }
.ci-wa { position:relative; }
.ci-arr {
  margin-left:auto; color:var(--amber); font-size:.75rem;
  transition:transform var(--tr);
}
.ci-wa:hover .ci-arr { transform:translateX(4px); }

.social-row { display:flex; gap:8px; }
.soc-lnk {
  width:38px; height:38px;
  border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--g2); font-size:.85rem; transition:var(--tr);
}
.soc-lnk:hover { border-color:var(--amber); color:var(--amber); }

/* Formulario */
.contact-form-wrap {
  background:var(--bg-2);
  border:1px solid var(--border);
  padding:44px 40px;
}
.form-header { margin-bottom:32px; }
.form-header h3 { font-size:1.5rem; margin-bottom:6px; }
.form-header p { font-size:.88rem; color:var(--g2); }

.fg { margin-bottom:18px; }
.fg-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.fg label {
  display:block; font-family:var(--f-head);
  font-size:.72rem; font-weight:600;
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--g2); margin-bottom:8px;
}
.cform input,
.cform select,
.cform textarea {
  width:100%;
  background:var(--bg);
  border:1px solid var(--border);
  padding:13px 16px;
  color:var(--off);
  font-family:var(--f-body); font-size:.93rem;
  transition:border-color var(--tr);
  -webkit-appearance:none;
}
.cform input::placeholder,
.cform textarea::placeholder { color:var(--g3); }
.cform input:focus,
.cform select:focus,
.cform textarea:focus {
  outline:none;
  border-color:var(--amber);
  box-shadow:0 0 0 2px rgba(240,165,0,.1);
}
.cform select option { background:var(--bg); }
.cform textarea { resize:vertical; min-height:110px; }

.form-note {
  font-size:.76rem; color:var(--g3);
  text-align:center; margin-top:12px;
  display:flex; align-items:center; justify-content:center; gap:6px;
}
.form-note i { color:var(--amber); }

/* ═══════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════ */
.footer { background:var(--bg); border-top:1px solid var(--border); }

.footer-top { padding:72px 0 56px; border-bottom:1px solid var(--border); }
.ft-inner {
  display:grid; grid-template-columns:2fr 1fr 1fr 1.4fr;
  gap:48px;
}

.ft-logo { max-height:40px; margin-bottom:16px; filter:brightness(0) invert(1); }
.ft-logo-txt {
  font-family:var(--f-disp); font-size:1.6rem;
  letter-spacing:3px; color:var(--white);
  display:block; margin-bottom:16px;
}
.ft-logo-txt em { color:var(--amber); font-style:normal; }
.ft-brand p { font-size:.88rem; color:var(--g2); line-height:1.7; max-width:260px; margin-bottom:20px; }

.ft-certs { display:flex; flex-direction:column; gap:8px; }
.ft-cert {
  display:flex; align-items:center; gap:8px;
  font-family:var(--f-head); font-size:.72rem;
  font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:var(--amber);
}
.ft-cert i { font-size:.7rem; }

.ft-links h4, .ft-contact h4 {
  font-family:var(--f-head); font-size:.72rem;
  font-weight:700; letter-spacing:.2em; text-transform:uppercase;
  color:var(--amber); margin-bottom:20px;
}
.ft-links ul { display:flex; flex-direction:column; gap:10px; }
.ft-links a {
  font-size:.88rem; color:var(--g2); transition:color var(--tr);
}
.ft-links a:hover { color:var(--amber); }

.ft-contact p {
  font-size:.88rem; color:var(--g2);
  display:flex; align-items:center; gap:10px;
  margin-bottom:10px;
}
.ft-contact i { color:var(--amber); width:12px; }
.ft-contact a { transition:color var(--tr); }
.ft-contact a:hover { color:var(--amber); }

.ft-social { display:flex; gap:8px; margin-top:20px; }
.fts-lnk {
  width:36px; height:36px;
  border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--g2); font-size:.82rem; transition:var(--tr);
}
.fts-lnk:hover { border-color:var(--amber); color:var(--amber); }

.footer-bot { padding:18px 0; }
.fb-inner {
  display:flex; align-items:center; justify-content:space-between;
  font-size:.76rem; color:var(--g3);
}
.fb-mid { display:flex; align-items:center; gap:6px; }

/* ─── WhatsApp FAB ──────────────────────────────────────────── */
.wa-fab {
  position:fixed
  ; bottom:28px; right:28px; z-index:900;
  width:52px; height:52px;
  background:#25D366;
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; color:var(--white);
  box-shadow:0 6px 24px rgba(37,211,102,.4);
  transition:var(--tr);
  animation:waBounce 4s ease infinite 5s;
}
.wa-fab:hover { background:#1ebe5a; transform:scale(1.1); }
@keyframes waBounce {
  0%,100% { transform:scale(1); }
  50%      { transform:scale(1.08); }
}
.wa-tooltip {
  position:absolute; right:64px;
  background:var(--bg-2); border:1px solid var(--border);
  padding:6px 12px;
  font-family:var(--f-head); font-size:.72rem;
  font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:var(--white); white-space:nowrap;
  opacity:0; pointer-events:none;
  transform:translateX(6px);
  transition:var(--tr);
}
.wa-fab:hover .wa-tooltip { opacity:1; transform:translateX(0); }

/* ─── Back to top ───────────────────────────────────────────── */
.btt {
  position:fixed; bottom:28px; left:28px; z-index:900;
  width:44px; height:44px;
  background:var(--bg-2); border:1px solid var(--border);
  color:var(--g2); font-size:.85rem;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:var(--tr);
  opacity:0; pointer-events:none;
}
.btt.show { opacity:1; pointer-events:all; }
.btt:hover { border-color:var(--amber); color:var(--amber); }

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */
@media (max-width:1100px) {
  .dif-grid           { grid-template-columns:repeat(2,1fr); }
  .reps-grid          { grid-template-columns:1fr 1fr; }
  .sectors-grid       { grid-template-columns:repeat(2,1fr); }
  .numeros-inner      { grid-template-columns:repeat(2,1fr); }
  .ft-inner           { grid-template-columns:1fr 1fr; gap:36px; }
  .proceso-wrap       { grid-template-columns:1fr; gap:40px; }
  .proceso-spine      { display:none; }
}

@media (max-width:900px) {
  .nos-grid           { grid-template-columns:1fr; gap:48px; }
  .fog-inner          { grid-template-columns:1fr; gap:56px; padding-top:80px; padding-bottom:80px; }
  .contact-grid       { grid-template-columns:1fr; gap:52px; }
  .cob-layout         { grid-template-columns:1fr; gap:40px; }
  .nos-img-border     { display:none; }
  .nos-img-tag        { left:0; }
  .nos-badge-float    { right:0; }
}

@media (max-width:768px) {
  .sec                { padding:80px 0; }
  .container          { padding:0 20px; }

  .reps-grid          { grid-template-columns:1fr; }
  .sectors-grid       { grid-template-columns:1fr 1fr; }
  .dif-grid           { grid-template-columns:1fr; }
  .numeros-inner      { grid-template-columns:1fr 1fr; }
  .ft-inner           { grid-template-columns:1fr; }
  .fb-inner           { flex-direction:column; gap:8px; text-align:center; }
  .fg-row             { grid-template-columns:1fr; }
  .contact-form-wrap  { padding:28px 20px; }

  .hero-stats         { flex-direction:column; align-items:flex-start; gap:20px; }
  .hstat              { padding:0; }
  .hstat-sep          { display:none; }
  .hero-h1            { font-size:clamp(3rem,14vw,6rem); }

  .nav-burger         { display:flex; }
  .nav-list {
    position:fixed; inset:0; top:68px;
    flex-direction:column; justify-content:center; align-items:center;
    background:rgba(8,8,8,.99);
    backdrop-filter:blur(20px);
    gap:28px;
    transform:translateX(100%);
    transition:transform var(--tr);
    font-size:1.1rem;
  }
  .nav-list.open      { transform:translateX(0); }
  .tri-wrap           { width:260px; height:240px; }
}

@media (max-width:480px) {
  .sectors-grid       { grid-template-columns:1fr; }
  .hero-actions       { flex-direction:column; }
  .btn-prim,
  .btn-ghost          { width:100%; justify-content:center; }
  .numeros-inner      { grid-template-columns:1fr; }
  .hero-reps          { flex-direction:column; align-items:flex-start; }
}
