/* ==========================================================================
   PINDI 3D — Hoja de estilos principal (v2 "super tech")
   --------------------------------------------------------------------------
   Todo el "tema" del sitio vive aquí. Si quieres cambiar colores o tipografía,
   edita las variables del bloque :root (más abajo). No necesitas tocar nada más.
   ========================================================================== */

/* 1. TOKENS DE MARCA (colores, tipografía, medidas) ----------------------- */
:root {
  /* Colores de marca (extraídos del logo PINDI 3D) */
  --color-primario:      #5B5FC4; /* violeta / periwinkle del logo */
  --color-primario-osc:  #3B3D8A; /* violeta profundo (contraste / hover)   */
  --color-primario-cl:   #C9CBF0; /* violeta claro (tints, fondos suaves)    */
  --color-plata:         #B9BBC6; /* plata metálica (bordes, detalles)       */
  --color-plata-cl:      #E2E3EA; /* plata clara (highlights)                */
  --color-negro:         #0B0B12; /* negro de marca (fondos oscuros)         */
  --color-negro-2:       #12121E; /* negro un punto más claro                */
  --color-claro:         #F5F6FB; /* fondos claros                           */
  --color-blanco:        #FFFFFF;
  --color-texto:         #1C2430; /* texto sobre fondos claros               */
  --color-texto-suave:   #5A6472; /* texto secundario sobre claro            */
  --color-texto-osc:     #E7E8F2; /* texto sobre fondos oscuros              */
  --color-texto-osc-2:   #A9ACC4; /* texto secundario sobre oscuro           */
  --color-laser:         #7DF9D8; /* acento "láser" (barrido LIDAR, datos)   */

  /* Degradados */
  --grad-primario: linear-gradient(135deg, #6C70D8 0%, #4A4EB0 55%, #3B3D8A 100%);
  --grad-texto:    linear-gradient(180deg, #FFFFFF 0%, #C9CBF0 55%, #8E92E0 100%);
  --grad-oscuro:   linear-gradient(180deg, #0B0B12 0%, #12121E 100%);

  /* Tipografía */
  --fuente-titulos: "Sora", system-ui, -apple-system, "Segoe UI", sans-serif;
  --fuente-texto:   "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --fuente-mono:    "JetBrains Mono", ui-monospace, "Cascadia Code", Consolas, monospace;

  /* Medidas */
  --ancho-max: 1180px;
  --radio:     16px;
  --radio-sm:  10px;
  --radio-lg:  24px;

  /* Sombras */
  --sombra-sm: 0 2px 8px rgba(11, 11, 18, 0.06);
  --sombra:    0 14px 40px rgba(28, 36, 48, 0.10);
  --sombra-violeta: 0 18px 50px rgba(91, 95, 196, 0.28);

  /* Transiciones */
  --t: 0.28s cubic-bezier(0.4, 0, 0.2, 1);

  --header-h: 76px;
}

/* 2. RESET Y BASE --------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; scroll-padding-top: calc(var(--header-h) + 14px); -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--fuente-texto);
  color: var(--color-texto);
  background: var(--color-claro);
  line-height: 1.65;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img, svg, video, canvas { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }

h1, h2, h3, h4 { font-family: var(--fuente-titulos); line-height: 1.12; font-weight: 700; letter-spacing: -0.02em; }

/* Enlace de salto (accesibilidad por teclado) */
.skip-link {
  position: absolute; left: -999px; top: 0; z-index: 200;
  background: var(--color-primario); color: #fff; padding: 12px 18px; border-radius: 0 0 10px 0;
}
.skip-link:focus { left: 0; }

:focus-visible { outline: 3px solid var(--color-primario-cl); outline-offset: 3px; border-radius: 4px; }

::selection { background: var(--color-primario); color: #fff; }

/* 3. UTILIDADES DE LAYOUT ------------------------------------------------- */
.contenedor { width: 100%; max-width: var(--ancho-max); margin-inline: auto; padding-inline: 22px; }

.seccion { padding-block: clamp(64px, 8vw, 120px); position: relative; }
.seccion--clara  { background: var(--color-claro); color: var(--color-texto); }
.seccion--blanca { background: var(--color-blanco); color: var(--color-texto); }
.seccion--oscura { background: var(--grad-oscuro); color: var(--color-texto-osc); }

/* Encabezado de sección */
.encabezado-seccion { max-width: 720px; margin-bottom: 54px; }
.encabezado-seccion.centro { margin-inline: auto; text-align: center; }
.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--fuente-titulos); font-size: 0.78rem; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--color-primario);
  padding: 7px 14px; border-radius: 999px;
  background: rgba(91, 95, 196, 0.10);
  border: 1px solid rgba(91, 95, 196, 0.22);
}
.seccion--oscura .eyebrow { color: var(--color-primario-cl); background: rgba(201, 203, 240, 0.10); border-color: rgba(201, 203, 240, 0.20); }
.eyebrow::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--color-primario); }
.seccion--oscura .eyebrow::before { background: var(--color-laser); }

.titulo-seccion { font-size: clamp(1.9rem, 4vw, 2.9rem); margin-top: 18px; }
.subtitulo-seccion { margin-top: 16px; font-size: 1.1rem; color: var(--color-texto-suave); }
.seccion--oscura .subtitulo-seccion { color: var(--color-texto-osc-2); }

.texto-grad {
  background: linear-gradient(120deg, var(--color-primario) 0%, #8488E6 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

/* Cuadrícula de ingeniería (fondo decorativo) */
.grid-deco {
  position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background-image:
    linear-gradient(rgba(185, 187, 198, 0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(185, 187, 198, 0.07) 1px, transparent 1px);
  background-size: 46px 46px;
  -webkit-mask-image: radial-gradient(ellipse 80% 70% at 50% 30%, #000 40%, transparent 100%);
          mask-image: radial-gradient(ellipse 80% 70% at 50% 30%, #000 40%, transparent 100%);
}
.seccion > .contenedor { position: relative; z-index: 1; }

/* Etiqueta tipo "dato técnico" (monoespaciada) */
.dato-tec {
  font-family: var(--fuente-mono); font-size: 0.72rem; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--color-laser);
}

/* 4. BOTONES -------------------------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-family: var(--fuente-titulos); font-weight: 600; font-size: 0.98rem;
  padding: 14px 26px; border-radius: 999px;
  transition: transform var(--t), box-shadow var(--t), background var(--t), color var(--t), border-color var(--t);
  white-space: nowrap; line-height: 1; position: relative;
}
.btn svg { width: 18px; height: 18px; }
.btn--primario {
  background: var(--grad-primario); color: #fff;
  box-shadow: var(--sombra-violeta);
}
.btn--primario:hover { box-shadow: 0 24px 60px rgba(91, 95, 196, 0.40); }
/* Pulso sutil de atención en CTAs principales */
.btn--pulso::after {
  content: ""; position: absolute; inset: -4px; border-radius: inherit;
  border: 2px solid rgba(124, 128, 230, 0.55); opacity: 0;
  animation: pulsoCta 2.6s ease-out infinite;
  pointer-events: none;
}
@keyframes pulsoCta {
  0%   { opacity: 0.9; transform: scale(0.96); }
  70%  { opacity: 0;   transform: scale(1.12); }
  100% { opacity: 0; }
}
.btn--fantasma {
  background: transparent; color: var(--color-texto-osc);
  border: 1.5px solid rgba(201, 203, 240, 0.35);
}
.btn--fantasma:hover { border-color: var(--color-primario-cl); background: rgba(201, 203, 240, 0.08); }
.btn--claro { background: #fff; color: var(--color-primario-osc); box-shadow: var(--sombra-sm); }
.btn--claro:hover { box-shadow: var(--sombra); }
.btn--wa { background: #25D366; color: #06231A; }
.btn--wa:hover { box-shadow: 0 16px 40px rgba(37, 211, 102, 0.35); }
.btn--bloque { width: 100%; }

/* 5. BARRA DE PROGRESO + HEADER ------------------------------------------- */
#barraProgreso {
  position: fixed; top: 0; left: 0; height: 3px; width: 0%;
  background: linear-gradient(90deg, var(--color-primario), var(--color-laser));
  z-index: 120; transition: width 0.08s linear;
}
.header {
  position: fixed; inset: 0 0 auto 0; z-index: 100; height: var(--header-h);
  display: flex; align-items: center;
  background: rgba(11, 11, 18, 0.55);
  -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(185, 187, 198, 0.12);
  transition: background var(--t), border-color var(--t);
}
.header.is-scrolled { background: rgba(11, 11, 18, 0.86); }
.header .contenedor { display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.logo-link { display: inline-flex; align-items: center; flex-shrink: 0; }
.logo-link img { height: 46px; width: auto; display: block; }

.nav { display: flex; align-items: center; gap: 4px; }
.nav a {
  font-family: var(--fuente-titulos); font-weight: 500; font-size: 0.92rem;
  color: var(--color-texto-osc-2); padding: 9px 12px; border-radius: 8px;
  transition: color var(--t), background var(--t);
  white-space: nowrap;
}
/* En tablet el CTA largo cede su lugar al "Cotiza" compacto del nav */
@media (max-width: 1120px) and (min-width: 761px) {
  .header-acciones .btn { display: none; }
  .nav > .btn { display: inline-flex; padding: 10px 18px; margin-left: 6px; }
  .nav a { padding: 9px 9px; font-size: 0.88rem; }
}
.nav a:hover { color: #fff; background: rgba(201, 203, 240, 0.08); }
.nav a.activo { color: #fff; background: rgba(91, 95, 196, 0.28); }
/* El botón "Cotiza" del nav solo se muestra dentro del menú móvil desplegado */
.nav > .btn { display: none; }
.header-acciones { display: flex; align-items: center; gap: 14px; }

.menu-toggle { display: none; width: 44px; height: 44px; border-radius: 10px; align-items: center; justify-content: center; color: #fff; }
.menu-toggle svg { width: 26px; height: 26px; }
.menu-toggle .icono-cerrar { display: none; }
body.menu-abierto .menu-toggle .icono-abrir { display: none; }
body.menu-abierto .menu-toggle .icono-cerrar { display: block; }

/* 6. HERO ----------------------------------------------------------------- */
.hero {
  position: relative; min-height: 100svh; display: flex; align-items: center;
  padding-top: calc(var(--header-h) + 40px); padding-bottom: 110px;
  background: var(--grad-oscuro); color: var(--color-texto-osc);
  overflow: hidden;
}
.hero__canvas { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; }
/* Resplandor que sigue al cursor (efecto "linterna láser") */
.hero__laser {
  position: absolute; z-index: 1; width: 520px; height: 520px; border-radius: 50%;
  background: radial-gradient(circle, rgba(91, 95, 196, 0.22) 0%, rgba(125, 249, 216, 0.05) 40%, transparent 70%);
  pointer-events: none; mix-blend-mode: screen;
  transform: translate(-50%, -50%); left: 70%; top: 40%;
  transition: opacity 0.4s; opacity: 0;
}
.hero.con-laser .hero__laser { opacity: 1; }
.hero__glow {
  position: absolute; z-index: 0; width: 720px; height: 720px; border-radius: 50%;
  background: radial-gradient(circle, rgba(91, 95, 196, 0.30) 0%, transparent 65%);
  top: -240px; right: -160px; filter: blur(20px); pointer-events: none;
}
.hero__glow--2 { width: 520px; height: 520px; top: auto; bottom: -220px; right: auto; left: -160px;
  background: radial-gradient(circle, rgba(201, 203, 240, 0.14) 0%, transparent 65%); }
.hero .contenedor { position: relative; z-index: 2; }
.hero__grid { position: absolute; inset: 0; z-index: 0;
  background-image:
    linear-gradient(rgba(185,187,198,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(185,187,198,0.05) 1px, transparent 1px);
  background-size: 52px 52px;
  -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, #000 30%, transparent 100%);
          mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, #000 30%, transparent 100%);
}
.hero__contenido { max-width: 760px; }
.hero__badge {
  display: inline-flex; align-items: center; gap: 10px; flex-wrap: wrap;
  font-family: var(--fuente-mono); font-size: 0.74rem; font-weight: 500;
  letter-spacing: 0.06em; color: var(--color-primario-cl);
  padding: 9px 16px; border-radius: 999px;
  background: rgba(201, 203, 240, 0.08); border: 1px solid rgba(201, 203, 240, 0.20);
  margin-bottom: 26px;
}
.hero__badge .punto { width: 8px; height: 8px; border-radius: 50%; background: var(--color-laser); box-shadow: 0 0 0 4px rgba(125, 249, 216, 0.16); animation: parpadeo 2s infinite; }
@keyframes parpadeo { 0%,100% { opacity: 1; } 50% { opacity: 0.35; } }
.hero h1 {
  font-size: clamp(2.3rem, 6vw, 4.2rem); line-height: 1.05;
  letter-spacing: -0.03em;
}
.hero h1 .texto-grad { background: var(--grad-texto); -webkit-background-clip: text; background-clip: text; color: transparent; }
/* Palabra rotativa con efecto "descifrado" */
.palabra-rotativa {
  display: inline-block; min-width: 7.2ch; text-align: left;
  color: var(--color-laser); position: relative;
}
.palabra-rotativa .cursor-scan {
  display: inline-block; width: 3px; height: 0.85em; margin-left: 3px;
  background: var(--color-laser); vertical-align: -0.08em;
  animation: parpadeo 1s steps(2) infinite;
}
.hero__sub {
  margin-top: 26px; font-size: clamp(1.05rem, 2vw, 1.3rem);
  color: var(--color-texto-osc-2); max-width: 660px;
}
.hero__cta { margin-top: 38px; display: flex; flex-wrap: wrap; gap: 16px; }
.hero__stats {
  margin-top: 56px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px;
  max-width: 760px; padding-top: 34px; border-top: 1px solid rgba(185, 187, 198, 0.14);
}
.hero__stat .num {
  font-family: var(--fuente-titulos); font-weight: 700; font-size: clamp(1.4rem, 3vw, 2rem);
  background: var(--grad-texto); -webkit-background-clip: text; background-clip: text; color: transparent;
}
.hero__stat .lbl { font-size: 0.82rem; color: var(--color-texto-osc-2); margin-top: 2px; }
/* Indicador de scroll */
.hero__scroll {
  position: absolute; bottom: 26px; left: 50%; transform: translateX(-50%); z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  color: var(--color-texto-osc-2); font-size: 0.72rem; letter-spacing: 0.2em; text-transform: uppercase;
  font-family: var(--fuente-mono);
}
.hero__scroll .rueda {
  width: 22px; height: 36px; border: 1.5px solid rgba(201,203,240,0.4); border-radius: 12px;
  display: flex; justify-content: center; padding-top: 6px;
}
.hero__scroll .rueda i {
  width: 3px; height: 7px; border-radius: 2px; background: var(--color-laser);
  animation: bajaScroll 1.8s ease-in-out infinite;
}
@keyframes bajaScroll { 0% { transform: translateY(0); opacity: 1; } 70% { transform: translateY(12px); opacity: 0; } 100% { opacity: 0; } }

/* 7. MARQUEE (cinta de capacidades) --------------------------------------- */
.marquee {
  background: var(--color-negro); border-block: 1px solid rgba(201,203,240,0.12);
  overflow: hidden; padding-block: 16px; position: relative;
}
.marquee::before, .marquee::after {
  content: ""; position: absolute; top: 0; bottom: 0; width: 90px; z-index: 2; pointer-events: none;
}
.marquee::before { left: 0; background: linear-gradient(90deg, var(--color-negro), transparent); }
.marquee::after { right: 0; background: linear-gradient(-90deg, var(--color-negro), transparent); }
.marquee__pista { display: flex; gap: 0; width: max-content; animation: marquesina 30s linear infinite; }
.marquee:hover .marquee__pista { animation-play-state: paused; }
@keyframes marquesina { to { transform: translateX(-50%); } }
.marquee__grupo { display: flex; align-items: center; gap: 38px; padding-right: 38px; }
.marquee__item {
  font-family: var(--fuente-mono); font-size: 0.82rem; letter-spacing: 0.16em;
  color: var(--color-texto-osc-2); white-space: nowrap; display: inline-flex; align-items: center; gap: 38px;
}
.marquee__item::after { content: "◆"; color: var(--color-primario); font-size: 0.6rem; }

/* 8. TRANSFORMACIÓN AL SCROLL (Realidad → Nube → 3D → Planos) ---------------- */
.ts { position: relative; height: 420vh; background: var(--grad-oscuro); color: var(--color-texto-osc); }
.ts__sticky {
  position: sticky; top: 0; height: 100svh;
  display: flex; align-items: center; overflow: hidden;
  padding-top: var(--header-h);
}
.ts__sticky > .contenedor { width: 100%; }
.ts__encabezado { text-align: center; margin-bottom: 22px; }
.ts__titulo {
  margin-top: 14px; font-size: clamp(1.7rem, 3.8vw, 2.7rem);
  color: #FFFFFF; letter-spacing: -0.02em;
}
.ts__visor {
  position: relative; max-width: 860px; margin-inline: auto;
  aspect-ratio: 3 / 2; max-height: 52vh;
  border-radius: var(--radio-lg); overflow: hidden;
  border: 1px solid rgba(201, 203, 240, 0.2);
  box-shadow: 0 36px 90px rgba(0, 0, 0, 0.55);
}
.ts__capa { position: absolute; inset: 0; }
.ts__capa svg { width: 100%; height: 100%; }
#tsCapa2, #tsCapa3, #tsCapa4 { clip-path: inset(0 100% 0 0); will-change: clip-path; }
.ts__tag {
  position: absolute; top: 14px; left: 14px; z-index: 2;
  font-family: var(--fuente-mono); font-size: 0.68rem; letter-spacing: 0.14em;
  padding: 6px 12px; border-radius: 999px;
  background: rgba(11, 11, 18, 0.72); -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
}
.ts__tag--foto { color: #C8CEE0; border: 1px solid rgba(200, 206, 224, 0.4); }
.ts__tag--nube { color: var(--color-laser); border: 1px solid rgba(125, 249, 216, 0.4); }
.ts__tag--cad  { color: #9FB4E8; border: 1px solid rgba(159, 180, 232, 0.4); }
.ts__tag--plano { color: #2A2F45; background: rgba(255, 255, 255, 0.85); border: 1px solid rgba(42, 47, 69, 0.35); }
.ts__laser {
  position: absolute; top: 0; bottom: 0; left: 0; width: 3px; z-index: 3; opacity: 0;
  background: linear-gradient(180deg, var(--color-laser), var(--color-primario));
  box-shadow: 0 0 24px rgba(125, 249, 216, 0.8), 0 0 60px rgba(125, 249, 216, 0.35);
  will-change: left, opacity;
}
.ts__etapas {
  display: flex; justify-content: center; gap: clamp(16px, 4vw, 46px);
  margin-top: 26px;
}
.ts__etapa {
  display: flex; align-items: center; gap: 11px; opacity: 0.36;
  transition: opacity var(--t);
}
.ts__etapa.activa { opacity: 1; }
.ts__etapa b {
  font-family: var(--fuente-mono); font-size: 0.95rem;
  width: 42px; height: 42px; border-radius: 50%;
  display: grid; place-items: center;
  border: 1.6px solid var(--color-plata); color: var(--color-plata);
  transition: all var(--t);
}
.ts__etapa.activa b {
  border-color: var(--color-laser); color: var(--color-laser);
  box-shadow: 0 0 18px rgba(125, 249, 216, 0.35);
}
.ts__etapa span { font-size: 0.8rem; line-height: 1.35; color: var(--color-texto-osc-2); }
.ts__etapa.activa span { color: #fff; }
.ts__pista { text-align: center; margin-top: 18px; opacity: 0.7; }
/* Fallback estático (sin animaciones): las 3 etapas apiladas */
.ts--estatico { height: auto; padding-block: 70px; }
.ts--estatico .ts__sticky { position: static; height: auto; display: block; padding-top: 0; }
.ts--estatico .ts__visor { aspect-ratio: auto; max-height: none; border: 0; box-shadow: none; overflow: visible; }
.ts--estatico .ts__capa { position: relative; margin-bottom: 26px; border-radius: var(--radio-lg); overflow: hidden; border: 1px solid rgba(201,203,240,0.2); }
.ts--estatico #tsCapa2, .ts--estatico #tsCapa3, .ts--estatico #tsCapa4 { clip-path: none; }
.ts--estatico .ts__laser, .ts--estatico .ts__pista { display: none; }

/* 9. SERVICIOS — BENTO GRID -------------------------------------------------- */
.bento {
  display: grid; gap: 18px;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: minmax(150px, auto);
  perspective: 1200px;
}
.bento__card {
  position: relative; background: #fff; border: 1px solid #E7E8EF; border-radius: var(--radio-lg);
  padding: 26px 24px; overflow: hidden;
  transition: box-shadow var(--t), border-color var(--t);
  will-change: transform;
  transform: rotateX(var(--rx, 0deg)) rotateY(var(--ry, 0deg));
}
.bento__card::after {
  content: ""; position: absolute; inset: 0; border-radius: inherit; padding: 1px;
  background: linear-gradient(135deg, rgba(91,95,196,0.5), transparent 45%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity: 0; transition: opacity var(--t);
}
.bento__card::before {
  content: ""; position: absolute; inset: 0; z-index: 0; opacity: 0; transition: opacity var(--t);
  background: radial-gradient(360px circle at var(--mx, 50%) var(--my, 50%), rgba(91,95,196,0.10), transparent 60%);
}
.bento__card:hover { box-shadow: var(--sombra); border-color: transparent; }
.bento__card:hover::after, .bento__card:hover::before { opacity: 1; }
.bento__card > * { position: relative; z-index: 1; }
.bento__icono {
  width: 50px; height: 50px; border-radius: 13px; display: grid; place-items: center;
  background: linear-gradient(135deg, rgba(91,95,196,0.14), rgba(201,203,240,0.20));
  color: var(--color-primario-osc); margin-bottom: 16px; flex-shrink: 0;
  transition: transform var(--t), box-shadow var(--t);
}
.bento__icono svg { width: 26px; height: 26px; }
.bento__card:hover .bento__icono {
  transform: translateY(-4px) rotate(-6deg);
  box-shadow: 0 14px 28px rgba(91, 95, 196, 0.30);
}
.bento__card h3 { font-size: 1.08rem; margin-bottom: 8px; }
.bento__card p { font-size: 0.92rem; color: var(--color-texto-suave); line-height: 1.55; }

/* Tarjeta estrella: 2x2, oscura, con puntos animados */
.bento__card--hero {
  grid-column: span 2; grid-row: span 2;
  background: var(--grad-oscuro); border-color: rgba(91, 95, 196, 0.4);
  color: var(--color-texto-osc); display: flex; flex-direction: column;
  padding: 32px 30px;
}
.bento__card--hero h3 { font-size: clamp(1.4rem, 2.4vw, 1.9rem); color: #fff; margin-top: 4px; }
.bento__card--hero p { color: var(--color-texto-osc-2); font-size: 0.98rem; max-width: 40ch; }
.bento__card--hero .bento__icono {
  background: rgba(125, 249, 216, 0.12); color: var(--color-laser);
  width: 56px; height: 56px;
}
.bento__etq { margin-bottom: 14px; }
.bento__puntos {
  position: absolute; inset: 0; z-index: 0; opacity: 0.55; pointer-events: none;
  background-image: radial-gradient(rgba(142, 146, 224, 0.55) 1.2px, transparent 1.3px);
  background-size: 22px 22px;
  -webkit-mask-image: radial-gradient(ellipse 90% 80% at 70% 30%, #000 20%, transparent 75%);
          mask-image: radial-gradient(ellipse 90% 80% at 70% 30%, #000 20%, transparent 75%);
  animation: derivaPuntos 14s linear infinite;
}
@keyframes derivaPuntos { to { background-position: 44px 22px; } }
.bento__card--hero::before { background: radial-gradient(420px circle at var(--mx, 50%) var(--my, 50%), rgba(125,249,216,0.10), transparent 60%); }
.bento__tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.bento__tags span {
  font-family: var(--fuente-mono); font-size: 0.68rem; letter-spacing: 0.08em;
  color: var(--color-laser); padding: 5px 11px; border-radius: 999px;
  border: 1px solid rgba(125, 249, 216, 0.32);
}
.bento__cta {
  margin-top: auto; padding-top: 22px;
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--fuente-titulos); font-weight: 600; font-size: 0.95rem;
  color: var(--color-laser);
}
.bento__cta:hover { text-decoration: underline; text-underline-offset: 4px; }

/* Tarjeta ancha 2x1 */
.bento__card--ancha {
  grid-column: span 2;
  display: flex; align-items: flex-start; gap: 18px;
  background: linear-gradient(135deg, #fff, #F2F3FB);
}
.bento__card--ancha .bento__icono { margin-bottom: 0; }
.bento__card--ancha h3 { font-size: 1.15rem; }
/* Tarjeta de capacitación (cierra la cuadrícula con acento violeta) */
.bento__card--capacita {
  background: linear-gradient(135deg, #F4F2FF, #E9EBFC);
  border-color: rgba(91, 95, 196, 0.28);
}
.bento__card--capacita .bento__icono { background: var(--grad-primario); color: #fff; }

/* Sección "Lo que obtienes": tipografía con más presencia */
.obtienes .porque-lista { gap: 26px; }
.obtienes .beneficio h3 { font-size: 1.32rem; margin-bottom: 6px; }
.obtienes .beneficio p { font-size: 1.04rem; }
.obtienes .beneficio__num { width: 52px; height: 52px; font-size: 1.02rem; border-radius: 14px; }

/* 10. PROCESO — LÍNEA DE FLUJO CON DIRECCIÓN ---------------------------------- */
.stepper {
  position: relative;
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 22px;
}
/* La línea recorre los 6 pasos con guiones en movimiento y flecha al final */
.stepper__linea {
  position: absolute; top: 28px; height: 3px; z-index: 0;
  left: calc(100% / 12); right: calc(100% / 12);
  background: repeating-linear-gradient(90deg, var(--color-primario) 0 11px, rgba(91, 95, 196, 0.15) 11px 22px);
  background-size: 22px 3px; border-radius: 2px;
  animation: correFlujo 0.9s linear infinite;
}
@keyframes correFlujo { to { background-position: 22px 0; } }
.stepper__linea::after {
  content: ""; position: absolute; right: -4px; top: 50%; transform: translateY(-50%);
  border-left: 13px solid var(--color-primario);
  border-top: 8px solid transparent; border-bottom: 8px solid transparent;
}
.paso { position: relative; z-index: 1; text-align: center; padding: 0 4px; }
/* Burbuja de etapa: el aro blanco "corta" la línea para que pase por detrás */
.paso__num {
  font-family: var(--fuente-mono); font-weight: 700; font-size: 0.92rem;
  width: 58px; height: 58px; border-radius: 50%; display: grid; place-items: center;
  margin: 0 auto 16px;
  color: var(--color-primario-osc); background: #fff;
  border: 2.2px solid var(--color-primario);
  box-shadow: 0 0 0 7px #fff, 0 0 0 9px rgba(91, 95, 196, 0.16);
  transition: all var(--t);
}
.paso:hover .paso__num {
  background: var(--grad-primario); color: #fff;
  box-shadow: 0 0 0 7px #fff, 0 0 0 9px rgba(91, 95, 196, 0.3), var(--sombra-violeta);
}
.paso h3 { font-size: 1.02rem; margin-bottom: 6px; }
.paso p { font-size: 0.86rem; color: var(--color-texto-suave); }

/* En pantallas angostas: línea de tiempo vertical (igual de clara) */
@media (max-width: 1079px) {
  .stepper { grid-template-columns: 1fr; gap: 32px; }
  .stepper__linea {
    top: 8px; bottom: 8px; left: 27px; right: auto; width: 3px; height: auto;
    background: repeating-linear-gradient(180deg, var(--color-primario) 0 11px, rgba(91, 95, 196, 0.15) 11px 22px);
    background-size: 3px 22px;
    animation: correFlujoV 0.9s linear infinite;
  }
  @keyframes correFlujoV { to { background-position: 0 22px; } }
  .stepper__linea::after {
    right: auto; left: 50%; top: auto; bottom: -4px; transform: translateX(-50%);
    border-top: 13px solid var(--color-primario);
    border-left: 8px solid transparent; border-right: 8px solid transparent; border-bottom: 0;
  }
  .paso { text-align: left; display: grid; grid-template-columns: 58px 1fr; column-gap: 18px; }
  .paso__num { margin: 0; grid-row: 1 / span 2; }
  .paso h3 { align-self: end; }
  .paso p { grid-column: 2; }
}

/* 11. ¿QUÉ ES UNA NUBE DE PUNTOS? + PANEL HUD -------------------------------- */
.tech-layout { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: 44px; align-items: center; }
.nube-beneficios { display: grid; gap: 16px; perspective: 1100px; }
.nube-ben {
  display: flex; gap: 16px; align-items: flex-start;
  padding: 20px 22px; border-radius: var(--radio);
  background: rgba(201, 203, 240, 0.05); border: 1px solid rgba(201, 203, 240, 0.14);
  transition: border-color var(--t), background var(--t);
  will-change: transform;
  transform: rotateX(var(--rx, 0deg)) rotateY(var(--ry, 0deg));
}
.nube-ben:hover { border-color: rgba(125, 249, 216, 0.4); background: rgba(201, 203, 240, 0.09); }
.nube-ben__icono {
  flex-shrink: 0; width: 46px; height: 46px; border-radius: 12px;
  display: grid; place-items: center;
  background: rgba(125, 249, 216, 0.10); color: var(--color-laser);
}
.nube-ben__icono svg { width: 23px; height: 23px; }
.nube-ben h3 { font-size: 1.05rem; color: #fff; margin-bottom: 4px; }
.nube-ben p { font-size: 0.92rem; color: var(--color-texto-osc-2); }
/* Título extra-grande para la sección estrella */
.titulo-xl { font-size: clamp(2.2rem, 5vw, 3.4rem); }

/* Franja "el problema que resuelve" (datos de la industria) */
.problema-strip {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px;
  margin-bottom: 54px;
}
.problema {
  padding: 26px 26px; border-radius: var(--radio-lg);
  background: linear-gradient(160deg, rgba(91, 95, 196, 0.14), rgba(201, 203, 240, 0.04));
  border: 1px solid rgba(201, 203, 240, 0.16);
}
.problema__num {
  font-family: var(--fuente-titulos); font-weight: 800;
  font-size: clamp(2.2rem, 4.4vw, 3.2rem); line-height: 1;
  background: var(--grad-texto);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.problema p { margin-top: 10px; font-size: 0.95rem; color: var(--color-texto-osc-2); }
.problema strong { color: #fff; }

/* Nube de puntos interactiva (canvas arrastrable) */
.nube-viva { display: flex; flex-direction: column; gap: 16px; }
.nube-viva__marco {
  position: relative; border-radius: var(--radio-lg); overflow: hidden;
  border: 1px solid rgba(125, 249, 216, 0.25);
  background: radial-gradient(ellipse at 50% 40%, #14142299, #0B0B12);
  box-shadow: 0 30px 70px rgba(0, 0, 0, 0.5);
  aspect-ratio: 5 / 4; cursor: grab; touch-action: none;
}
.nube-viva__marco:active { cursor: grabbing; }
.nube-viva__marco canvas { width: 100%; height: 100%; }
.nube-viva__hint {
  position: absolute; left: 50%; bottom: 16px; transform: translateX(-50%);
  display: inline-flex; align-items: center; gap: 8px; white-space: nowrap;
  font-family: var(--fuente-titulos); font-size: 0.8rem; font-weight: 500;
  color: var(--color-laser); padding: 9px 16px; border-radius: 999px;
  background: rgba(11, 11, 18, 0.78); border: 1px solid rgba(125, 249, 216, 0.35);
  pointer-events: none; transition: opacity 0.5s;
  animation: flotaHint 2.4s ease-in-out infinite;
}
@keyframes flotaHint { 0%, 100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(-5px); } }
.nube-viva__marco.usado .nube-viva__hint { opacity: 0; }
.nube-viva__stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; text-align: center;
}
.nube-viva__stats > div {
  padding: 14px 10px; border-radius: var(--radio);
  background: rgba(201, 203, 240, 0.05); border: 1px solid rgba(201, 203, 240, 0.14);
}
.nube-viva__stats b {
  display: block; font-family: var(--fuente-titulos); font-weight: 700; font-size: 1.25rem;
  background: var(--grad-texto); -webkit-background-clip: text; background-clip: text; color: transparent;
}
.nube-viva__stats span { font-size: 0.76rem; color: var(--color-texto-osc-2); }

/* 12. PORTAFOLIO — VIDEO CON MARCO DE ENERGÍA + GALERÍA EDITABLE -------------- */
.video-energia { position: relative; max-width: 920px; margin: 0 auto 50px; }
.video-energia__borde {
  position: absolute; inset: -3px; z-index: 0;
  border-radius: calc(var(--radio-lg) + 4px); overflow: hidden;
}
.video-energia__borde::before {
  content: ""; position: absolute; inset: -60%;
  background: conic-gradient(#5B5FC4, #7DF9D8, #3B3D8A, #8E92E0, #5B5FC4);
  animation: girar 5s linear infinite;
}
.video-energia .video-wrap {
  position: relative; z-index: 1; aspect-ratio: 16 / 9;
  border-radius: var(--radio-lg); overflow: hidden; background: #000;
  box-shadow: 0 34px 90px rgba(91, 95, 196, 0.30);
}
.video-wrap iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.video-chip {
  position: absolute; z-index: 2; padding: 8px 15px; border-radius: 999px;
  background: rgba(11, 11, 18, 0.88); color: var(--color-laser);
  border: 1px solid rgba(125, 249, 216, 0.4);
}
.video-chip--a { top: -15px; left: 26px; }
.video-chip--b { bottom: -15px; right: 26px; color: var(--color-primario-cl); border-color: rgba(201, 203, 240, 0.4); }

/* Filtros de galería */
.galeria-filtros { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-bottom: 26px; }
.filtro {
  font-family: var(--fuente-titulos); font-size: 0.88rem; font-weight: 500;
  padding: 10px 18px; border-radius: 999px;
  color: var(--color-texto-osc-2); border: 1.5px solid rgba(201, 203, 240, 0.22);
  transition: all var(--t);
}
.filtro:hover { color: #fff; border-color: var(--color-primario-cl); }
.filtro.activo { background: var(--grad-primario); border-color: transparent; color: #fff; box-shadow: var(--sombra-violeta); }
.galeria--grande { grid-template-columns: repeat(3, 1fr); }
.galeria__item.oculto { display: none; }
.galeria__item img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.galeria { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.galeria__item {
  position: relative; aspect-ratio: 4 / 3; border-radius: var(--radio); overflow: hidden;
  border: 1px solid rgba(201,203,240,0.16); display: flex; align-items: flex-end;
  padding: 16px; color: #fff; font-family: var(--fuente-titulos); font-weight: 500; font-size: 0.85rem;
  background-size: cover; background-position: center;
  transition: transform var(--t), border-color var(--t);
}
.galeria__item:hover { transform: translateY(-4px) scale(1.015); border-color: rgba(125,249,216,0.45); }
/* Placeholders generados con CSS (reemplazables por fotos reales WebP) */
.ph-1 { background: linear-gradient(135deg, #1b1d3a, #3B3D8A); }
.ph-2 { background: linear-gradient(135deg, #20223f, #5B5FC4); }
.ph-3 { background: linear-gradient(135deg, #15151f, #2c2f6b); }
.ph-4 { background: linear-gradient(135deg, #23254a, #6C70D8); }
.galeria__item::before {
  content: ""; position: absolute; inset: 0;
  background-image: linear-gradient(rgba(201,203,240,0.10) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(201,203,240,0.10) 1px, transparent 1px);
  background-size: 18px 18px; opacity: 0.5;
}
/* Línea de "escaneo" que recorre cada miniatura al pasar el cursor */
.galeria__item::after {
  content: ""; position: absolute; left: 0; right: 0; top: -20%; height: 3px;
  background: linear-gradient(90deg, transparent, var(--color-laser), transparent);
  opacity: 0; box-shadow: 0 0 18px rgba(125,249,216,0.8);
}
.galeria__item:hover::after { opacity: 1; animation: lineaScan 1.2s ease-in-out infinite; }
@keyframes lineaScan { 0% { top: -4%; } 100% { top: 104%; } }
.galeria__item span { position: relative; z-index: 1; text-shadow: 0 1px 6px rgba(0,0,0,0.5); }
.galeria__item .etq { position: absolute; top: 12px; left: 12px; z-index: 1; font-size: 0.64rem;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-primario-cl);
  background: rgba(11,11,18,0.5); padding: 4px 9px; border-radius: 999px; font-weight: 600;
  font-family: var(--fuente-mono); }

/* 13. CASOS DE ÉXITO — FICHAS DE PROYECTO ------------------------------------- */
.fichas { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; perspective: 1200px; }
.ficha {
  background: rgba(201, 203, 240, 0.05); border: 1px solid rgba(201, 203, 240, 0.14);
  border-radius: var(--radio-lg); padding: 32px 30px; position: relative; overflow: hidden;
  transform: rotateX(var(--rx, 0deg)) rotateY(var(--ry, 0deg)); will-change: transform;
  transition: border-color var(--t), background var(--t);
}
.ficha:hover { border-color: rgba(125, 249, 216, 0.4); background: rgba(201, 203, 240, 0.08); }
.ficha::before {
  content: ""; position: absolute; top: 0; left: 12%; right: 12%; height: 2px;
  background: linear-gradient(90deg, transparent, var(--color-laser), transparent);
  opacity: 0; transition: opacity var(--t);
}
.ficha:hover::before { opacity: 1; }
.ficha__cab { display: flex; align-items: center; gap: 14px; margin-bottom: 18px; }
.ficha__icono {
  flex-shrink: 0; width: 46px; height: 46px; border-radius: 12px;
  display: grid; place-items: center;
  background: rgba(125, 249, 216, 0.10); color: var(--color-laser);
}
.ficha__icono svg { width: 24px; height: 24px; }
.ficha__tag { color: var(--color-texto-osc-2); }
.ficha h3 { font-size: clamp(1.2rem, 2vw, 1.45rem); color: #fff; }
.ficha p { margin-top: 10px; font-size: 0.97rem; color: var(--color-texto-osc-2); line-height: 1.65; }
.ficha__metricas { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 20px; }
.ficha__metricas span {
  font-family: var(--fuente-mono); font-size: 0.7rem; letter-spacing: 0.05em;
  color: var(--color-laser); border: 1px solid rgba(125, 249, 216, 0.3);
  padding: 6px 12px; border-radius: 999px;
}
.casos-nota { margin-top: 30px; text-align: center; font-size: 0.9rem; color: var(--color-texto-osc-2); max-width: 760px; margin-inline: auto; }

/* 14. SECTORES -------------------------------------------------------------- */
.sectores-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 16px; }
.sector {
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: 14px;
  padding: 28px 18px; border-radius: var(--radio); background: #fff; border: 1px solid #E7E8EF;
  transition: transform var(--t), box-shadow var(--t);
}
.sector:hover { transform: translateY(-5px); box-shadow: var(--sombra); }
.sector__icono { width: 52px; height: 52px; border-radius: 14px; display: grid; place-items: center;
  background: linear-gradient(135deg, rgba(91,95,196,0.12), rgba(201,203,240,0.20)); color: var(--color-primario-osc); }
.sector__icono svg { width: 28px; height: 28px; }
.sector b { font-family: var(--fuente-titulos); font-weight: 600; font-size: 0.98rem; }

/* 15. POR QUÉ ---------------------------------------------------------------- */
.porque-layout { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 50px; align-items: center; }
.porque-lista { display: grid; gap: 18px; }
.beneficio { display: flex; gap: 16px; align-items: flex-start; }
.beneficio__num {
  flex-shrink: 0; width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center;
  background: var(--grad-primario); color: #fff;
  font-family: var(--fuente-mono); font-weight: 700; font-size: 0.92rem;
  box-shadow: var(--sombra-violeta);
}
.beneficio h3 { font-size: 1.08rem; margin-bottom: 4px; }
.beneficio p { font-size: 0.95rem; color: var(--color-texto-suave); }
.porque-visual {
  border-radius: var(--radio-lg); padding: 40px; color: #fff;
  background: var(--grad-primario); position: relative; overflow: hidden;
  box-shadow: var(--sombra-violeta);
}
.porque-visual::before { content: ""; position: absolute; inset: 0;
  background-image: linear-gradient(rgba(255,255,255,0.08) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(255,255,255,0.08) 1px, transparent 1px);
  background-size: 30px 30px; opacity: 0.6; }
.porque-visual > * { position: relative; z-index: 1; }
.porque-visual .grande { font-family: var(--fuente-titulos); font-weight: 700; font-size: clamp(2.6rem, 6vw, 3.6rem); line-height: 1; }
.porque-visual .grande small { font-size: 1.4rem; font-weight: 600; }
.porque-visual p { margin-top: 12px; color: rgba(255,255,255,0.86); }
.porque-visual hr { border: none; border-top: 1px solid rgba(255,255,255,0.22); margin: 26px 0; }
.porque-visual .mini { display: flex; gap: 26px; flex-wrap: wrap; }
.porque-visual .mini b { display: block; font-family: var(--fuente-titulos); font-size: 1.5rem; }
.porque-visual .mini span { font-size: 0.82rem; color: rgba(255,255,255,0.8); }

/* 16. FAQ -------------------------------------------------------------------- */
.faq-lista { max-width: 820px; margin-inline: auto; display: grid; gap: 14px; }
.faq-item {
  background: #fff; border: 1px solid #E7E8EF; border-radius: var(--radio);
  overflow: hidden; transition: border-color var(--t), box-shadow var(--t);
}
.faq-item.abierto { border-color: rgba(91,95,196,0.45); box-shadow: var(--sombra-sm); }
.faq-preg {
  width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px;
  text-align: left; padding: 20px 24px; font-family: var(--fuente-titulos);
  font-weight: 600; font-size: 1.02rem; color: var(--color-texto);
}
.faq-preg .chev {
  flex-shrink: 0; width: 34px; height: 34px; border-radius: 10px;
  display: grid; place-items: center; color: var(--color-primario);
  background: rgba(91,95,196,0.10); transition: transform var(--t), background var(--t), color var(--t);
}
.faq-item.abierto .chev { transform: rotate(180deg); background: var(--color-primario); color: #fff; }
.faq-resp {
  display: grid; grid-template-rows: 0fr; transition: grid-template-rows 0.35s cubic-bezier(0.4,0,0.2,1);
}
.faq-item.abierto .faq-resp { grid-template-rows: 1fr; }
.faq-resp > div { overflow: hidden; }
.faq-resp p { padding: 0 24px 22px; font-size: 0.96rem; color: var(--color-texto-suave); }

/* 17. CTA BANNER -------------------------------------------------------------- */
.cta-banner { padding-block: clamp(70px, 9vw, 120px); background: var(--color-negro); position: relative; overflow: hidden; }
.cta-banner__caja {
  position: relative; border-radius: 28px; padding: clamp(40px, 6vw, 72px);
  background: var(--grad-primario); color: #fff; text-align: center; overflow: hidden;
  box-shadow: 0 40px 100px rgba(91,95,196,0.35);
}
.cta-banner__caja::before {
  content: ""; position: absolute; inset: -50%;
  background: conic-gradient(from 0deg, transparent 0 70%, rgba(255,255,255,0.16) 78%, transparent 86%);
  animation: girar 9s linear infinite;
}
@keyframes girar { to { transform: rotate(360deg); } }
.cta-banner__caja::after {
  content: ""; position: absolute; inset: 0;
  background-image: linear-gradient(rgba(255,255,255,0.07) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(255,255,255,0.07) 1px, transparent 1px);
  background-size: 32px 32px;
}
.cta-banner__caja > * { position: relative; z-index: 1; }
.cta-banner h2 { font-size: clamp(1.8rem, 4.4vw, 3rem); max-width: 760px; margin-inline: auto; }
.cta-banner p { margin-top: 14px; color: rgba(255,255,255,0.88); font-size: 1.08rem; }
.cta-banner .acciones { margin-top: 32px; display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* 18. CONTACTO ----------------------------------------------------------------- */
.contacto-layout { display: grid; grid-template-columns: 1fr 1.1fr; gap: 50px; align-items: start; }
.contacto-info h2 { font-size: clamp(1.9rem, 4vw, 2.7rem); }
.contacto-metodos { margin-top: 32px; display: grid; gap: 14px; }
.metodo { display: flex; gap: 16px; align-items: center; padding: 16px 18px; border-radius: var(--radio);
  background: rgba(201,203,240,0.06); border: 1px solid rgba(201,203,240,0.14); transition: border-color var(--t), background var(--t); }
.metodo:hover { border-color: var(--color-primario-cl); background: rgba(201,203,240,0.10); }
.metodo__icono { width: 46px; height: 46px; border-radius: 12px; flex-shrink: 0; display: grid; place-items: center;
  background: rgba(91,95,196,0.18); color: var(--color-primario-cl); }
.metodo__icono svg { width: 22px; height: 22px; }
.metodo small { display: block; font-size: 0.78rem; color: var(--color-texto-osc-2); }
.metodo b { font-family: var(--fuente-titulos); font-weight: 500; font-size: 1rem; color: #fff; word-break: break-word; }
.respuesta-rapida {
  margin-top: 22px; display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--fuente-mono); font-size: 0.78rem; color: var(--color-laser);
  padding: 9px 16px; border: 1px dashed rgba(125,249,216,0.4); border-radius: 999px;
}

.form-card { background: #fff; border-radius: var(--radio-lg); padding: 34px; box-shadow: var(--sombra); color: var(--color-texto); }
.form-card h3 { font-size: 1.3rem; margin-bottom: 6px; }
.form-card .ayuda { font-size: 0.9rem; color: var(--color-texto-suave); margin-bottom: 20px; }
/* Chips de interés: 1 toque = el lead ya nos dijo qué quiere */
.chips-interes { display: flex; flex-wrap: wrap; gap: 9px; margin-bottom: 20px; }
.chip-int {
  font-family: var(--fuente-titulos); font-size: 0.82rem; font-weight: 500;
  padding: 9px 15px; border-radius: 999px; border: 1.5px solid #DDDFE8; color: var(--color-texto-suave);
  transition: all var(--t);
}
.chip-int:hover { border-color: var(--color-primario); color: var(--color-primario-osc); }
.chip-int.activo { background: var(--color-primario); border-color: var(--color-primario); color: #fff; }
.campo { margin-bottom: 16px; }
.campo label { display: block; font-size: 0.85rem; font-weight: 500; margin-bottom: 7px; font-family: var(--fuente-titulos); }
.campo input, .campo textarea {
  width: 100%; padding: 13px 15px; border-radius: var(--radio-sm); font: inherit; font-size: 0.96rem;
  border: 1.5px solid #DDDFE8; background: #FBFBFE; color: var(--color-texto); transition: border-color var(--t), box-shadow var(--t);
}
.campo input:focus, .campo textarea:focus { outline: none; border-color: var(--color-primario); box-shadow: 0 0 0 3px rgba(91,95,196,0.16); }
.campo textarea { resize: vertical; min-height: 110px; }
.fila-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-nota { font-size: 0.78rem; color: var(--color-texto-suave); margin-top: 14px; text-align: center; }
.form-nota a { color: var(--color-primario-osc); text-decoration: underline; }
.form-msg { display: none; padding: 14px 16px; border-radius: var(--radio-sm); margin-bottom: 18px; font-size: 0.92rem; }
.form-msg.ok  { display: block; background: #E7F7EE; color: #176B3C; border: 1px solid #B6E3C8; }
.form-msg.err { display: block; background: #FCEAEA; color: #9A2A2A; border: 1px solid #F0C2C2; }
.confianza-mini {
  margin-top: 18px; display: flex; justify-content: center; gap: 18px; flex-wrap: wrap;
  font-size: 0.76rem; color: var(--color-texto-suave);
}
.confianza-mini span { display: inline-flex; align-items: center; gap: 6px; }
.confianza-mini svg { width: 14px; height: 14px; color: var(--color-primario); }

/* 19. FOOTER -------------------------------------------------------------------- */
.footer { background: #07070C; color: var(--color-texto-osc-2); padding-block: 64px 30px; }
.footer-top { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 36px; }
.footer-brand img { height: 72px; width: auto; margin-bottom: 18px; }
.footer-brand p { font-size: 0.92rem; max-width: 320px; line-height: 1.7; }
.footer-redes { display: flex; gap: 12px; margin-top: 20px; }
.footer-redes a { width: 40px; height: 40px; border-radius: 11px; display: grid; place-items: center;
  background: rgba(201,203,240,0.08); border: 1px solid rgba(201,203,240,0.14); color: var(--color-texto-osc); transition: background var(--t), transform var(--t); }
.footer-redes a:hover { background: var(--color-primario); transform: translateY(-3px); color: #fff; }
.footer-redes svg { width: 19px; height: 19px; }
.footer-col h4 { font-size: 0.82rem; letter-spacing: 0.12em; text-transform: uppercase; color: #fff; margin-bottom: 16px; }
.footer-col a { display: block; font-size: 0.92rem; padding: 5px 0; transition: color var(--t); }
.footer-col a:hover { color: var(--color-primario-cl); }
.footer-bottom { margin-top: 48px; padding-top: 24px; border-top: 1px solid rgba(201,203,240,0.10);
  display: flex; flex-wrap: wrap; gap: 12px; justify-content: space-between; align-items: center; font-size: 0.84rem; }
.footer-bottom a:hover { color: var(--color-primario-cl); }

/* 20. FLOTANTES: WHATSAPP + BURBUJA + BARRA MÓVIL --------------------------------- */
.wa-float {
  position: fixed; right: 22px; bottom: 22px; z-index: 90;
  width: 60px; height: 60px; border-radius: 50%; display: grid; place-items: center;
  background: #25D366; color: #fff; box-shadow: 0 12px 32px rgba(37,211,102,0.45);
  transition: transform var(--t);
}
.wa-float:hover { transform: scale(1.08); }
.wa-float svg { width: 32px; height: 32px; }
/* Burbuja proactiva que invita a conversar */
.wa-nudge {
  position: fixed; right: 94px; bottom: 30px; z-index: 90; max-width: 250px;
  background: #fff; color: var(--color-texto); border-radius: 16px 16px 4px 16px;
  padding: 14px 16px; font-size: 0.88rem; box-shadow: var(--sombra);
  opacity: 0; transform: translateY(14px) scale(0.94); pointer-events: none;
  transition: opacity 0.4s, transform 0.4s;
}
.wa-nudge.visible { opacity: 1; transform: none; pointer-events: auto; }
.wa-nudge b { font-family: var(--fuente-titulos); display: block; margin-bottom: 2px; }
.wa-nudge .cerrar-nudge {
  position: absolute; top: -10px; left: -10px; width: 24px; height: 24px; border-radius: 50%;
  background: var(--color-negro); color: #fff; font-size: 12px; display: grid; place-items: center;
}
/* Barra CTA fija inferior (solo móvil, aparece tras el hero) */
.sticky-cta {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 95;
  display: none; gap: 10px; padding: 10px 14px calc(10px + env(safe-area-inset-bottom));
  background: rgba(11,11,18,0.92); -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  border-top: 1px solid rgba(201,203,240,0.16);
  transform: translateY(110%); transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
}
.sticky-cta.visible { transform: none; }
.sticky-cta .btn { flex: 1; padding: 13px 10px; font-size: 0.9rem; }

/* 21. ANIMACIONES DE APARICIÓN ----------------------------------------------------- */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity 0.7s ease, transform 0.7s ease; }
.reveal--izq { transform: translateX(-34px); }
.reveal--der { transform: translateX(34px); }
.reveal--zoom { transform: scale(0.94); }
.reveal.visible { opacity: 1; transform: none; }
.reveal[data-delay="1"] { transition-delay: 0.08s; }
.reveal[data-delay="2"] { transition-delay: 0.16s; }
.reveal[data-delay="3"] { transition-delay: 0.24s; }

/* 22. PÁGINA INTERNA (aviso de privacidad) ------------------------------------------ */
.pagina-legal { padding-top: calc(var(--header-h) + 60px); padding-bottom: 90px; }
.pagina-legal .contenedor { max-width: 820px; }
.pagina-legal h1 { font-size: clamp(2rem, 5vw, 2.8rem); margin-bottom: 10px; }
.pagina-legal .actualizado { color: var(--color-texto-suave); font-size: 0.9rem; margin-bottom: 36px; }
.pagina-legal h2 { font-size: 1.3rem; margin: 34px 0 12px; color: var(--color-primario-osc); }
.pagina-legal p, .pagina-legal li { color: var(--color-texto); margin-bottom: 12px; }
.pagina-legal ul { list-style: disc; padding-left: 22px; }
.pagina-legal .volver { display: inline-flex; align-items: center; gap: 8px; margin-top: 30px; color: var(--color-primario-osc); font-weight: 600; }
.aviso-amarillo { background: #FFF7E6; border: 1px solid #F2D98A; border-radius: var(--radio-sm); padding: 16px 18px; font-size: 0.9rem; color: #6B4E00; margin-bottom: 28px; }

/* 23. CLIENTES (franja activable) ----------------------------------------------------- */
.clientes { text-align: center; }
.clientes__nota { font-size: 0.92rem; color: var(--color-texto-suave); max-width: 640px; margin: 0 auto 30px; }
.logos-strip { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 18px; }
.logo-ph {
  height: 64px; min-width: 150px; border-radius: 12px; display: grid; place-items: center;
  background: #fff; border: 1px dashed #C9CBD6; color: var(--color-texto-suave);
  font-family: var(--fuente-titulos); font-weight: 600; font-size: 0.9rem; letter-spacing: 0.04em;
}

/* 24. RESPONSIVE ------------------------------------------------------------------------ */
@media (max-width: 1024px) {
  .porque-layout, .contacto-layout, .tech-layout { grid-template-columns: 1fr; }
  .fichas { grid-template-columns: 1fr; max-width: 640px; margin-inline: auto; }
  .galeria--grande { grid-template-columns: repeat(2, 1fr); }
  .bento { grid-template-columns: repeat(2, 1fr); }
  .nube-viva { max-width: 560px; margin-inline: auto; }
  .footer-top { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: 1 / -1; }
}

@media (max-width: 760px) {
  .nav, .header-acciones .btn { display: none; }
  .menu-toggle { display: flex; }
  .nav.is-open {
    display: flex; flex-direction: column; align-items: stretch; gap: 4px;
    position: fixed; top: var(--header-h); left: 0; right: 0;
    background: rgba(11,11,18,0.97); -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px);
    padding: 16px 22px 26px; border-bottom: 1px solid rgba(185,187,198,0.14);
  }
  .nav.is-open a { padding: 14px 12px; font-size: 1.02rem; border-radius: 10px; }
  .nav.is-open .btn { display: inline-flex; margin-top: 10px; }
  .hero { padding-bottom: 90px; }
  /* En móvil la nube de puntos queda detrás del texto: se atenúa para legibilidad */
  .hero__canvas { opacity: 0.5; }
  .hero__stats { grid-template-columns: repeat(2, 1fr); gap: 22px 18px; }
  .hero__scroll { display: none; }
  .galeria { grid-template-columns: 1fr 1fr; }
  .galeria--grande { grid-template-columns: 1fr 1fr; }
  .fila-2 { grid-template-columns: 1fr; }
  .form-card { padding: 26px 22px; }
  .seccion { padding-block: 60px; }
  .bento { grid-template-columns: 1fr; }
  .bento__card--hero, .bento__card--ancha { grid-column: span 1; grid-row: span 1; }
  .bento__card--ancha { flex-direction: column; }
  .ts { height: 380vh; }
  .ts__visor { aspect-ratio: 4 / 3; max-height: 44vh; }
  .ts__etapa span { display: none; }
  .ts__etapa { gap: 0; }
  .problema-strip { grid-template-columns: 1fr; gap: 12px; margin-bottom: 40px; }
  .problema { display: flex; align-items: center; gap: 18px; padding: 18px 20px; }
  .problema p { margin-top: 0; }
  .video-chip--a { left: 12px; top: -13px; }
  .video-chip--b { right: 12px; bottom: -13px; }
  .sticky-cta { display: flex; }
  .wa-float { bottom: 86px; }
  .wa-nudge { bottom: 94px; }
  .palabra-rotativa { min-width: 0; }
}

@media (max-width: 420px) {
  body { font-size: 16px; }
  .hero__stats { grid-template-columns: 1fr 1fr; }
  .galeria { grid-template-columns: 1fr; }
}

/* ==========================================================================
   26. POLISH GLOBAL "SUPER TECH" — detalles finos en toda la página
   ========================================================================== */

/* Scrollbar personalizada (detalle premium) */
::-webkit-scrollbar { width: 11px; }
::-webkit-scrollbar-track { background: #0B0B12; }
::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #6C70D8, #3B3D8A);
  border-radius: 8px; border: 2px solid #0B0B12;
}
::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, #8488E6, #5B5FC4); }
html { scrollbar-color: #5B5FC4 #0B0B12; scrollbar-width: thin; }

/* Anillo de cursor (lo crea main.js solo en escritorio) */
.cursor-anillo {
  position: fixed; top: 0; left: 0; z-index: 999; pointer-events: none;
  width: 30px; height: 30px; border-radius: 50%; opacity: 0;
  border: 1.5px solid rgba(125, 249, 216, 0.55);
  box-shadow: 0 0 14px rgba(125, 249, 216, 0.18) inset;
  transition: width 0.25s, height 0.25s, border-color 0.25s, opacity 0.3s;
  mix-blend-mode: screen;
}
.cursor-anillo.activo {
  width: 52px; height: 52px;
  border-color: rgba(125, 249, 216, 0.9);
}

/* Subrayado láser que se dibuja bajo cada título al aparecer */
.titulo-seccion::after {
  content: ""; display: block; width: 78px; height: 3px; margin-top: 18px;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--color-primario), var(--color-laser));
  transform: scaleX(0); transform-origin: left;
  transition: transform 0.9s cubic-bezier(0.4, 0, 0.2, 1) 0.35s;
}
.reveal.visible .titulo-seccion::after,
.titulo-seccion.reveal.visible::after { transform: scaleX(1); }
.encabezado-seccion.centro .titulo-seccion::after { margin-inline: auto; transform-origin: center; }

/* Marquee: segunda fila invertida, más tenue (profundidad) */
.marquee__pista--rev {
  animation-direction: reverse; animation-duration: 44s;
  opacity: 0.4; margin-top: 10px;
}
.marquee__pista--rev .marquee__item { font-size: 0.72rem; }

/* Proceso: número con pop al aparecer */
.paso.reveal.visible .paso__num { animation: popNum 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) backwards 0.15s; }
@keyframes popNum { from { transform: scale(0.4) rotate(-12deg); opacity: 0; } to { transform: none; opacity: 1; } }

/* Nube interactiva: cuadrícula de fondo sutil */
.nube-viva__marco::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(201, 203, 240, 0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(201, 203, 240, 0.06) 1px, transparent 1px);
  background-size: 34px 34px;
}

/* Sectores: el ícono "saluda" al pasar el cursor */
.sector__icono { transition: transform var(--t), background var(--t); }
.sector:hover .sector__icono { transform: rotate(-8deg) scale(1.12); }

/* Por qué: radar girando dentro de la tarjeta violeta */
.porque-visual::after {
  content: ""; position: absolute; inset: -45%;
  background:
    conic-gradient(from 0deg, transparent 0 78%, rgba(255, 255, 255, 0.20) 90%, transparent 100%),
    repeating-radial-gradient(circle at center, transparent 0 44px, rgba(255, 255, 255, 0.05) 45px 46px);
  animation: girar 7s linear infinite;
  pointer-events: none;
}

/* FAQ: numeración monoespaciada automática */
.faq-lista { counter-reset: faq; }
.faq-preg { justify-content: flex-start; }
.faq-preg::before {
  counter-increment: faq;
  content: counter(faq, decimal-leading-zero);
  font-family: var(--fuente-mono); font-size: 0.78rem; font-weight: 700;
  color: var(--color-primario); flex-shrink: 0;
}
.faq-preg .chev { margin-left: auto; }

/* Footer: borde superior láser */
.footer {
  border-top: 1px solid;
  border-image: linear-gradient(90deg, transparent, var(--color-primario), var(--color-laser), transparent) 1;
}

@media (max-width: 760px) {
  .cursor-anillo { display: none; }
  .marquee__pista--rev { display: none; }
}

/* 25. PREFERENCIA DE MOVIMIENTO REDUCIDO -------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
  .reveal { opacity: 1; transform: none; }
  .marquee__pista { transform: none; }
  .titulo-seccion::after { transform: scaleX(1); }
  .paso:not(:nth-child(3n))::after { transform: scaleX(1); }
  .cursor-anillo { display: none; }
}
