.newsletter-cta { margin: .6rem 0 .4rem; }
.footer-socials { display: flex; align-items: center; gap: 1rem; margin-bottom: .5rem; }
/* 3x mÃƒÆ’Ã‚Â¡s grandes, sin borde ni cuadro: solo el logo */
.footer-socials .social-link { 
  --size: 58px;
  display: inline-grid; place-items: center; 
  width: var(--size); height: var(--size);
  border-radius: 999px; 
  /* Sin fondo ni bordes: solo la imagen visible */
  border: 0; 
  background: transparent; 
  color: inherit; 
  box-shadow: none;
  transition: transform .18s ease, filter .18s ease;
}
/* Ocultar SVG por defecto; usamos imÃƒÆ’Ã‚Â¡genes off/on */
.footer-socials .social-link svg { display: none; }
/* Las imÃƒÆ’Ã‚Â¡genes ocupan el tamaÃƒÆ’Ã‚Â±o del cÃƒÆ’Ã‚Â­rculo anterior */
.footer-socials .social-link img { width: var(--size); height: var(--size); display: block; }
/* Swap de iconos off/on con hover */
.footer-socials .social-link .icon-on { display: none; }
.footer-socials .social-link:hover .icon-off { display: none; }
.footer-socials .social-link:hover .icon-on { display: block; }
.footer-socials .social-link:hover { 
  transform: translateY(-2px) scale(1.05);
  filter: brightness(1.06);
}

/* Variantes por red usando aria-label (sin tocar HTML adicional) */
/* Neutralizar variantes: sin fondos ni sombras por red */
.footer-socials .social-link[aria-label] { 
  background: transparent !important; 
  border-color: transparent !important; 
  box-shadow: none !important; 
}

/* Fila fuera de la card: botÃƒÆ’Ã‚Â³n + redes en la misma lÃƒÆ’Ã‚Â­nea, centrado */
.footer-socials-wrap { display: flex; align-items: center; justify-content: flex-end; gap: .5rem; margin: .9rem 0 0; width: 100%; transform: translateX(-1cm); }
.footer-socials-wrap .newsletter-cta { margin: 0; }

/* BotÃƒÆ’Ã‚Â³n SuscrÃƒÆ’Ã‚Â­bete destacado */
#newsletter-focus-btn {
  --h: 64px;
  height: var(--h);
  padding: 0 30px;
  font-size: 1.05rem;
  font-weight: 800;
  letter-spacing: .02em;
  border-radius: 999px;
  border: 1px solid rgba(1,84,249,.35);
  color: #fff;
  /* Mismo diseÃƒÆ’Ã‚Â±o de color que "Soy Cliente" */
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
  box-shadow: 0 16px 36px rgba(1,84,249,.28), inset 0 0 0 2px rgba(255,255,255,.08);
  position: relative;
  overflow: hidden;
}
#newsletter-focus-btn::before {
  /* halo suave */
  content: ""; position: absolute; inset: -10px; border-radius: 999px;
  background: radial-gradient(closest-side, rgba(42,115,255,.22), transparent 70%);
  filter: blur(8px); opacity: .6; pointer-events: none;
}
#newsletter-focus-btn::after {
  /* brillo diagonal animado al hover */
  content: ""; position: absolute; top: -40%; left: -30%; width: 40%; height: 180%;
  background: linear-gradient(115deg, rgba(255,255,255,.0) 0%, rgba(255,255,255,.28) 50%, rgba(255,255,255,.0) 100%);
  transform: translateX(-120%) rotate(12deg);
  transition: transform .6s ease;
}
#newsletter-focus-btn:hover::after { transform: translateX(260%) rotate(12deg); }
#newsletter-focus-btn:hover {
  /* Hover igual al CTA, conservando el efecto existente */
  background: linear-gradient(135deg, #2f4dd1, #2a73ff);
  transform: translateY(-2px);
  box-shadow: 0 20px 42px rgba(1,84,249,.36), inset 0 0 0 2px rgba(255,255,255,.1);
}
#newsletter-focus-btn:focus-visible { outline: 3px solid rgba(1,84,249,.6); outline-offset: 2px; }

@media (max-width: 900px) {
  #newsletter-focus-btn { --h: 54px; padding: 0 22px; font-size: 1rem; }
}
/* BotÃƒÆ’Ã‚Â³n SuscrÃƒÆ’Ã‚Â­bete 3x */
@media (max-width: 700px) { .footer-socials-wrap { justify-content: center; flex-wrap: wrap; transform: none; } }

/* Responsivo: reducir tamaÃƒÆ’Ã‚Â±o en pantallas pequeÃƒÆ’Ã‚Â±as */
@media (max-width: 900px) {
  .footer-socials { gap: .5rem; }
  .footer-socials .social-link { --size: 52px; }
  .footer-socials .social-link svg { width: 26px; height: 26px; }
  .footer-socials .social-link[aria-label="Instagram"] svg { width: 20px; height: 20px; }
  .footer-socials .social-link[aria-label="YouTube"] svg { width: 24px; height: 24px; }
  .footer-socials .social-link[aria-label="Facebook"] svg { width: 22px; height: 22px; }
  .footer-socials .social-link[aria-label="LinkedIn"] svg { width: 24px; height: 24px; }
  .footer-socials .social-link[aria-label="X"] svg { width: 24px; height: 24px; }
}

/* Contacto: telÃƒÆ’Ã‚Â©fono y correo en la misma lÃƒÆ’Ã‚Â­nea (telÃƒÆ’Ã‚Â©fono primero) */
.footer__info .contact-list { display: flex; flex-wrap: wrap; gap: .6rem 1rem; align-items: stretch; }
.footer__info .contact-list .contact-item { flex: 1 1 48%; min-width: 260px; }
/* DirecciÃƒÆ’Ã‚Â³n ocupa toda la fila */
.footer__info .contact-list .contact-item:nth-child(1) { flex-basis: 100%; }
/* Reordenar visualmente: TelÃƒÆ’Ã‚Â©fono (3) antes que Correo (2) */
.footer__info .contact-list .contact-item:nth-child(3) { order: 1; }
.footer__info .contact-list .contact-item:nth-child(2) { order: 2; }
@media (max-width: 520px) {
  /* En mÃƒÆ’Ã‚Â³viles muy estrechos, que vuelvan a apilarse */
  .footer__info .contact-list .contact-item { flex-basis: 100%; min-width: 0; }
  .footer__info .contact-list .contact-item:nth-child(3),
  .footer__info .contact-list .contact-item:nth-child(2) { order: unset; }
}

/*
  Soy AsesorÃƒÆ’Ã‚Â­as - Estilos principales
{{ ... }}
  Paleta:
  -- Azul Medio (Principal) #253a94
  -- Azul Oscuro (Fondos)   #0e1222
  -- Azul Brillante         #0154f9
  -- Gris oscuro            #4b4e56
  -- Gris claro             #b8bbc3
  -- Negro                  #181b21
  -- Blanco                 #ffffff
  -- Blanco Oscuro          #d9d9d9
*/

:root {
  --color-primary: #253a94;
  --color-bg: #0e1222;
  --color-accent: #0154f9;
  --color-gray-700: #4b4e56;
  --color-gray-400: #b8bbc3;
  --color-black: #181b21;
  --color-white: #ffffff;
  --color-offwhite: #d9d9d9;

  --container: 1200px;
  --radius: 16px;
  --radius-sm: 10px;
  --shadow-1: 0 10px 30px rgba(0, 0, 0, 0.35);
  --shadow-2: 0 6px 20px rgba(1, 84, 249, 0.25);
}

/* ------------------------------ WhatsApp FAB ------------------------------ */
.fab { position: fixed; right: 18px; bottom: 18px; width: 72px; height: 72px; border-radius: 999px; display: grid; place-items: center; text-decoration: none; color: var(--color-white); background: transparent; border: 0; box-shadow: none; z-index: 80; transition: transform .2s ease; overflow: hidden; }
.fab:hover { transform: translateY(-2px); }
.fab__icon { width: 64px; height: 64px; display: block; position: absolute; inset: 0; margin: auto; transition: opacity .2s ease, transform .2s ease; }
.fab__icon--on { opacity: 0; transform: scale(.9); }
.fab:hover .fab__icon--off { opacity: 0; transform: scale(.9); }
.fab:hover .fab__icon--on { opacity: 1; transform: scale(1); }
.fab--whatsapp::before { content: none; }
.fab__tooltip { position: absolute; right: 70px; bottom: 14px; background: rgba(24,27,33,.92); color: var(--color-offwhite); border: 1px solid rgba(184,187,195,.18); padding: .4rem .6rem; border-radius: 10px; font-size: .9rem; opacity: 0; transform: translateX(6px); transition: opacity .2s ease, transform .2s ease; pointer-events: none; white-space: nowrap; }
.fab:hover .fab__tooltip { opacity: 1; transform: translateX(0); }

@media (max-width: 480px) {
  .fab { right: 14px; bottom: calc(14px + 1cm); width: 60px; height: 60px; border-radius: 999px; }
  .fab__icon { width: 52px; height: 52px; }
  .fab__tooltip { display: none; }
}

/* Reset base */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--color-offwhite);
  background-color: var(--color-bg);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden; /* evita barra horizontal por secciones full-bleed (p.ej. cinta de logos) */
}

/* Fuente: Poppins aplicada globalmente (import al inicio del archivo) */

img, svg, video { display: block; max-width: 100%; }

.container {
  width: min(100% - 2rem, var(--container));
  margin-inline: auto;
}

h1, h2, h3 { color: var(--color-white); margin: 0 0 .5rem; line-height: 1.2; }
p { margin: 0; }

/* ------------------------------ TipografÃƒÆ’Ã‚Â­a y utilidades ------------------------------ */
.d-block { display: block !important; }
.text-nowrap { white-space: nowrap !important; }

.kicker { 
  display: inline-block; 
  font-weight: 600; 
  letter-spacing: .12em; 
  text-transform: uppercase; 
  font-size: .82rem; 
  color: var(--color-accent);
}
.display-1 { 
  font-weight: 700; 
  font-size: clamp(2.2rem, 5.8vw, 3.4rem); 
  line-height: 1.1; 
}
.lead { 
  font-size: clamp(1rem, 2.2vw, 1.2rem); 
  color: #4b4e56; 
}
.text-muted { color: var(--color-gray-400); }
.text-gradient {
  background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Alternancia de secciones claras y oscuras */
.section--light { 
  background: var(--color-white); 
  color: var(--color-black);
}
.section--light h1,
.section--light h2,
.section--light h3 { color: var(--color-black); }
.section--light .section__title { color: var(--color-black); }
.section--light .section__subtitle { color: var(--color-gray-700); }
.section--light .kicker { color: var(--color-primary); }

/* Layout dividido para hero de texto (Propuesta) */
.split {
  display: grid; 
  grid-template-columns: 1.15fr .85fr; 
  align-items: center; 
  gap: clamp(1rem, 4vw, 2.5rem);
}
.split__col { display: grid; gap: .8rem; }

/* Insignia circular con degradado (similar a sello) */
.badge-circle {
  --size: clamp(160px, 24vw, 240px);
  position: relative;
  width: var(--size); height: var(--size);
  border-radius: 50%;
  display: grid; place-items: center; text-align: center;
  background: radial-gradient(60% 60% at 40% 40%, rgba(1,84,249,.18), transparent 70%),
              conic-gradient(from 180deg at 50% 50%, #2a73ff, #253a94, #2a73ff);
  color: var(--color-white);
  border: 2px solid rgba(1,84,249,.35);
  box-shadow: 0 12px 34px rgba(1,84,249,.27);
}
.badge-circle::after {
  content: ""; position: absolute; inset: -8px; border-radius: 50%;
  background: radial-gradient(closest-side, rgba(1,84,249,.22), transparent 70%);
  filter: blur(8px); z-index: -1;
}
.badge-circle::before {
  content: ""; position: absolute; inset: -6px; border-radius: 50%;
  border: 2px solid rgba(1,84,249,.45);
  opacity: 0; transform: scale(1);
  animation: pulseRing 2.6s ease-out infinite;
}
.badge-circle__inner { 
  width: calc(var(--size) - 24px); height: calc(var(--size) - 24px); 
  border-radius: 50%; display: grid; place-items: center; 
  background: linear-gradient(135deg, rgba(37,58,148,.95), rgba(1,84,249,.85));
  border: 1px solid rgba(1,84,249,.45);
  padding: 1rem; text-align: center;
  animation: pulseInner 1.9s ease-in-out infinite;
  will-change: transform;
}
.badge-circle__kicker { font-size: clamp(2rem, 7vw, 3.6rem); text-transform: uppercase; letter-spacing: .16em; opacity: 1; font-weight: 800; color: var(--color-white); text-shadow: 0 4px 18px rgba(0,0,0,.35); }
.badge-circle strong { font-size: clamp(1.35rem, 4vw, 2rem); line-height: 1.05; font-weight: 800; }
.badge-circle__sub { font-size: 1.1rem; opacity: .98; }
.badge-circle span { font-size: .95rem; }

/* Imagen + insignia superpuesta en Propuesta */
#propuesta { position: relative; overflow: hidden; --proposal-notch: clamp(160px, 16vw, 310px); }
#propuesta .container { padding-left: 0; margin-left: 0; }
#propuesta .split { margin-left: clamp(1rem, 3vw, 2rem); }
.proposal-media { 
  position: static; 
  display: grid; 
  grid-template-columns: 1fr auto; /* cÃƒÆ’Ã‚Â­rculo izquierda, imagen derecha */
  align-items: center; 
  justify-items: stretch; 
  justify-self: stretch; 
  align-self: center; 
  margin: 0; 
  min-height: clamp(260px, 34vw, 420px);
  overflow: visible;
}
.proposal-media__img {
  position: absolute; right: 0; top: 0; bottom: 0; 
  height: 100%; width: auto; 
  display: block; object-fit: contain; /* se ve completa sin recortes */
  border-radius: 0; border: 0;
  box-shadow: none; z-index: 1; pointer-events: none;
  /* Corte diagonal en esquina superior izquierda */
  clip-path: polygon(var(--proposal-notch) 0, 100% 0, 100% 100%, 0 100%, 0 var(--proposal-notch));
}
.proposal-media .badge-circle { 
  grid-column: 1;
  position: static; 
  margin-left: 0; 
  justify-self: center; /* centrado en la mitad izquierda */
  align-self: center; 
  transform: none; z-index: 2;
  animation: floatY 8s ease-in-out infinite; 
}

@keyframes floatY {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

@keyframes pulseInner {
  0%, 100% { transform: scale(1); }
  40% { transform: scale(1.075); }
  60% { transform: scale(1.02); }
}

@keyframes pulseRing {
  0% { transform: scale(1); opacity: .65; }
  70% { transform: scale(1.28); opacity: 0; }
  100% { opacity: 0; }
}

/* Accesibilidad: respetar reducciÃƒÆ’Ã‚Â³n de motion */
@media (prefers-reduced-motion: reduce) {
  .badge-circle__inner { animation: none; }
  .badge-circle::before { animation: none; }
  .proposal-media .badge-circle { animation: none; }
  /* Respetar reducciÃƒÆ’Ã‚Â³n de motion tambiÃƒÆ’Ã‚Â©n para los iconos de servicios */
  .service-icon { animation: none; }
  .service-icon::before { animation: none; }
}

@media (max-width: 900px) {
  .proposal-media { 
    position: relative;
    grid-template-columns: 1fr; 
    justify-self: center; align-self: center; margin: 0; 
    justify-items: center; min-height: 240px; 
    overflow: visible; /* permitir que el cÃƒÆ’Ã‚Â­rculo salga a la mitad */
    margin-bottom: clamp(84px, 12vw, 120px); /* espacio para la mitad exterior */
  }
  .proposal-media::after { display: none; }
  .proposal-media__img { 
    position: relative; grid-column: 1; 
    margin-right: 0; 
    width: min(100%, 420px); 
    height: auto; 
    border-radius: var(--radius);
    pointer-events: auto; z-index: 1;
    clip-path: none; /* sin corte en mÃƒÆ’Ã‚Â³viles */
  }
  .proposal-media .badge-circle { 
    grid-column: 1; 
    position: absolute; 
    left: 35%; 
    bottom: calc(var(--size) * -0.5); /* mitad afuera de la imagen */
    transform: translateX(-50%);
    z-index: 2; /* por encima de la imagen */
  }
}

/* Evitar que el contenido de la izquierda colisione con la imagen en pantallas grandes */
@media (min-width: 1100px) {
  .split { gap: clamp(1.5rem, 3.5vw, 3rem); }
}

/* ------------------------------ Hero ------------------------------ */
.hero {
  position: relative;
  width: 100%;
  overflow: hidden;
  background: var(--color-bg);
  margin: 0;
  padding: 0;
  line-height: 0; /* evita cualquier gap por line-height */
}
.hero__video {
  position: relative;
  width: 100%;
  height: auto; /* sin recortes, altura natural del video */
  display: block;
  object-fit: contain; /* redundante aquÃƒÆ’Ã‚Â­, pero deja claro que no recortamos */
  object-position: top center; /* referencia de alineaciÃƒÆ’Ã‚Â³n */
  background: var(--color-bg);
}
.hero__content {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: center;
  min-height: inherit;
  padding: clamp(4rem, 6vw, 8rem) 0;
  gap: 1rem;
}
.hero__title {
  font-weight: 700;
  font-size: clamp(2rem, 6vw, 3.2rem);
  letter-spacing: 0.2px;
  background: linear-gradient(90deg, var(--color-white), #e9ecff 30%, var(--color-accent));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.hero__subtitle {
  color: var(--color-offwhite);
  font-size: clamp(1rem, 2.5vw, 1.125rem);
  max-width: 56ch;
}

.btn {
  --btn-bg: linear-gradient(135deg, var(--color-primary), var(--color-accent));
  --btn-bg-hover: linear-gradient(135deg, #2f4dd1, #2a73ff);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .85rem 1.15rem;
  border-radius: 999px;
  color: var(--color-white);
  text-decoration: none;
  font-weight: 600;
  box-shadow: var(--shadow-2);
}
.btn--primary { background: var(--btn-bg); border: 1px solid rgba(1,84,249,.35); }
.btn--primary:hover { background: var(--btn-bg-hover); transition: background .25s ease; }

/* VariaciÃƒÆ’Ã‚Â³n de botÃƒÆ’Ã‚Â³n contorneado para fondos claros */
.btn--ghost {
  background: transparent;
  color: var(--color-primary);
  border: 1px solid rgba(37,58,148,.35);
}
.btn--ghost:hover {
  background: rgba(1,84,249,.06);
}

.actions { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: .6rem; }

/* Lista de bullets resaltados */
.bullets { list-style: none; padding: 0; margin: .6rem 0 0; display: grid; gap: .35rem; }
.bullets li { color: #4b4e56; display: grid; grid-template-columns: 24px 1fr; align-items: start; gap: .5rem; }
.bullets li::before { content: ""; width: 14px; height: 14px; margin-top: .3rem; border-radius: 50%; background: radial-gradient(circle at 30% 30%, var(--color-accent), var(--color-primary)); box-shadow: 0 0 0 3px rgba(1,84,249,.15); }

/* ------------------------------ NavegaciÃƒÆ’Ã‚Â³n ------------------------------ */
.site-nav {
  position: absolute; /* no sigue al hacer scroll en la parte superior */
  top: 0;
  left: 0;
  right: 0;
  z-index: 70;
  background: transparent;
  border-bottom: 1px solid transparent;
  transition: background .25s ease, border-color .25s ease, box-shadow .25s ease, position .15s ease;
}
.site-nav.is-fixed { position: fixed; top: 0; left: 0; right: 0; }
.site-nav.has-shadow {
  box-shadow: 0 6px 20px rgba(0,0,0,.25);
}
.site-nav.is-solid {
  backdrop-filter: blur(10px);
  background: #ffffff; /* barra blanca en el segundo menÃƒÆ’Ã‚Âº */
  border-bottom: 1px solid rgba(24, 27, 33, 0.08);
  box-shadow: 0 6px 20px rgba(0,0,0,.12);
}
.site-nav.is-solid .nav__inner { padding: 1rem 0; }
.nav__inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: .75rem 0; }

.nav__brand {
  color: var(--color-white);
  font-weight: 700;
  text-decoration: none;
  letter-spacing: .3px;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}

/* Logo aparece al pasar el video (nav sÃƒÆ’Ã‚Â³lido) */
.nav__logo { height: 32px; width: auto; display: none; }
.site-nav.is-solid .nav__logo { display: inline-block; }

/* Hacer el segundo menÃƒÆ’Ã‚Âº y logo mÃƒÆ’Ã‚Â¡s grandes en desktop */
@media (min-width: 900px) {
  .site-nav.is-solid .nav__logo { height: 50px; }
  .site-nav.is-solid .nav__link { padding: .65rem 1rem; font-size: 1rem; }
  .site-nav.is-solid .nav__link.nav__cta { padding: .65rem 1rem; }
}

.nav__links { display: flex; align-items: center; gap: .5rem; list-style: none; padding: 0; margin: 0; }
.nav__link {
  --pad-x: .85rem;
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .6rem 1rem;
  color: var(--color-offwhite);
  text-decoration: none;
  border-radius: 999px;
}

/* Globos (burbujas) mÃƒÆ’Ã‚Â¡s notorios para el menÃƒÆ’Ã‚Âº superior y el menÃƒÆ’Ã‚Âº en pÃƒÆ’Ã‚Â¡gina */
.nav__links { gap: .7rem; }
.nav__link {
  font-weight: 600;
  isolation: isolate; /* asegura que el pseudo quede debajo del texto */
}
/* Burbuja de fondo (vidrio) para el nav sobre el hÃƒÆ’Ã‚Â©roe */
.site-nav .nav__link::before {
  content: "";
  position: absolute; inset: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
  border: 1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(8px);
  box-shadow: 0 8px 28px rgba(0,0,0,.18), inset 0 0 0 1px rgba(255,255,255,.06);
  opacity: .85;
  transform: scale(.98);
  transition: transform .18s ease, box-shadow .2s ease, background .2s ease, opacity .18s ease;
  z-index: -1;
}
.site-nav .nav__link:hover::before { 
  transform: scale(1);
  box-shadow: 0 12px 34px rgba(0,0,0,.22), inset 0 0 0 1px rgba(255,255,255,.1);
  opacity: 1;
}
/* Estado activo (scroll spy) mÃƒÆ’Ã‚Â¡s visible */
.site-nav .nav__link.is-active::before {
  background: linear-gradient(135deg, rgba(1,84,249,.24), rgba(37,58,148,.18));
  border-color: rgba(1,84,249,.35);
  box-shadow: 0 16px 40px rgba(1,84,249,.28), 0 0 0 4px rgba(1,84,249,.14);
}

/* Variante del segundo menÃƒÆ’Ã‚Âº (barra sÃƒÆ’Ã‚Â³lida blanca) */
.site-nav.is-solid .nav__link { color: var(--color-black); }
.site-nav.is-solid .nav__link::before {
  background: linear-gradient(135deg, rgba(255,255,255,.95), rgba(245,247,255,.95));
  border: 1px solid rgba(24,27,33,.10);
  box-shadow: 0 8px 24px rgba(24,27,33,.10), inset 0 0 0 1px rgba(255,255,255,.66);
}
.site-nav.is-solid .nav__link:hover::before {
  background: linear-gradient(135deg, #ffffff, #f0f4ff);
  box-shadow: 0 14px 34px rgba(24,27,33,.16), inset 0 0 0 1px rgba(255,255,255,.8);
}
.site-nav.is-solid .nav__link.is-active::before {
  background: linear-gradient(135deg, rgba(47,77,209,.16), rgba(42,115,255,.16));
  border-color: rgba(1,84,249,.30);
  box-shadow: 0 16px 38px rgba(1,84,249,.20), 0 0 0 4px rgba(1,84,249,.10);
}

/* CTA del menÃƒÆ’Ã‚Âº aÃƒÆ’Ã‚Âºn mÃƒÆ’Ã‚Â¡s protagonista */
.nav__link.nav__cta {
  padding: .65rem 1.1rem;
  font-weight: 800;
  letter-spacing: .02em;
  box-shadow: 0 16px 36px rgba(1,84,249,.28), inset 0 0 0 2px rgba(255,255,255,.08);
}
.nav__link.nav__cta::after { content: none !important; }
/* Sin brillo cruzado al hover */
.nav__link.nav__cta:hover::after { content: none !important; }
/* Evitar doble fondo en CTA: sin vidrio */
.nav__link.nav__cta::before { content: none !important; }

/* Accesibilidad foco */
.nav__link:focus-visible { outline: 3px solid rgba(1,84,249,.6); outline-offset: 3px; }

@media (max-width: 900px) {
  .nav__link { padding: .55rem .9rem; }
}

/* Normalizar fondos para que el pseudo maneje el "globo" */
.nav__link { background: transparent !important; }
.nav__link.is-active { background: transparent !important; }
.site-nav.is-solid .nav__link.is-active { background: transparent !important; }

/* Reaplicar fondo del CTA tras la normalizaciÃƒÆ’Ã‚Â³n */
.nav__link.nav__cta {
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent)) !important;
  color: var(--color-white) !important;
  border: 1px solid rgba(1,84,249,.35);
}

/* UnificaciÃƒÆ’Ã‚Â³n: estilos para todos los modales de formularios */
.modal.modal--auth { place-items: start center !important; padding-top: calc(var(--nav-h, 84px) + 8px); padding-bottom: 16px; }
.modal--auth .modal__header, .modal--auth .modal__close { display: none !important; }
.modal--auth .modal__content { padding: 0 1rem .4rem; max-height: 90svh; overflow: auto; }
.modal--auth .modal__overlay { background: rgba(0,0,0,.35); backdrop-filter: blur(6px); }
.modal--auth .auth-modal { gap: .35rem; display: grid; grid-template-columns: 1fr; grid-template-rows: auto 1fr; }
.modal.modal--confirm { place-items: center center; padding: 4vh 1rem; }
.modal--confirm .modal__overlay { background: rgba(15,23,42,.55); backdrop-filter: blur(8px); }
.modal--confirm .modal__dialog { max-width: min(520px, 92%); border-radius: 24px; overflow: hidden; box-shadow: 0 24px 60px rgba(15,23,42,.35); transform: translateY(16px) scale(.98); opacity: 0; animation: login-pop .35s cubic-bezier(.2,.8,.2,1) forwards; }
.modal--confirm .modal__content { padding: clamp(1.2rem, 4vw, 2.4rem); background: linear-gradient(145deg, #ffffff, #f8fbff); position: relative; }
.modal--confirm .modal__close { position: absolute; top: clamp(.6rem, 2vw, 1.2rem); right: clamp(.6rem, 2vw, 1.2rem); background: transparent; border: none; font-size: 1.6rem; color: rgba(15,23,42,.55); cursor: pointer; }
.confirm-modal { display: grid; gap: clamp(.8rem, 2vw, 1.4rem); text-align: center; color: #0f172a; }
.confirm-modal__icon { font-size: clamp(2.4rem, 6vw, 3.2rem); display: inline-flex; align-items: center; justify-content: center; }
.confirm-modal__title { font-size: clamp(1.4rem, 4vw, 2rem); margin: 0; font-weight: 800; color: #0f172a; }
.confirm-modal__message { margin: 0; font-size: clamp(1rem, 2.5vw, 1.15rem); color: #334155; line-height: 1.6; }
.confirm-modal__action { margin-inline: auto; min-width: min(220px, 100%); font-size: 1rem; padding-block: .85rem; border-radius: 999px; }
.modal--confirm [data-close="true"]:hover { filter: brightness(.92); }
.modal--auth .modal__dialog {
  width: min(96%, 420px);
  transform: translateY(8px) scale(.98);
  opacity: 0;
  animation: login-pop .35s cubic-bezier(.2,.8,.2,1) forwards;
  border-radius: 26px;
  overflow: hidden;
  background: #ffffff;
  box-shadow: 0 28px 48px rgba(15, 23, 42, 0.22);
  max-height: 92svh;
  display: flex;
  flex-direction: column;
}
.modal--auth .auth-modal__left {
  display: grid !important; place-items: center;
  background: linear-gradient(15deg, var(--color-primary), var(--color-accent)) !important;
  border: 0; border-radius: 22px 22px 0 0; padding: .6rem .8rem;
  min-height: 92px; position: relative; overflow: hidden;
  margin-left: -1rem; margin-right: -1rem; margin-top: -1px; margin-bottom: .2rem;
}
.modal--auth .auth-modal__left::before, .modal--auth .auth-modal__left::after { content: none !important; }
.modal--auth .auth-left__layer, .modal--auth .auth-left__decor { display: none !important; }
.modal--auth .auth-left__logo { width: min(460px, 76%); max-height: 60px; height: auto; object-fit: contain; filter: none; opacity: 1; animation: logo-breathe 4.5s ease-in-out infinite; transform-origin: center; }
.modal--auth .auth-modal__right {
  background: #ffffff !important;
  border: 0;
  box-shadow: none;
  padding: 1.2rem 1.6rem 1.8rem;
  border-radius: 0 0 26px 26px;
  overflow: visible;
}
@media (prefers-reduced-motion: reduce) {
  .modal--auth .auth-left__logo { animation: none; }
}

/* Modal AsesorÃƒÆ’Ã‚Â­a: sin scroll interno y mÃƒÆ’Ã‚Â¡s arriba en la pantalla */
#asesoria-modal.modal--auth { padding-top: calc(var(--nav-h, 84px) - 56px); padding-bottom: 12px; }
#asesoria-modal.modal--auth .modal__content {
  max-height: calc(92svh - 24px);
  overflow-y: auto;
  padding-bottom: 1.6rem;
  scrollbar-width: none;
}
#asesoria-modal.modal--auth .modal__content::-webkit-scrollbar { display: none; }
#asesoria-modal.modal--auth .modal__dialog { max-height: min(92svh, 720px); }

/* BotÃƒÆ’Ã‚Â³n del modal: ancho completo y sin desbordes */
.auth-btn--block { width: 100%; display: block; box-sizing: border-box; height: 40px; }
.nav__link:hover { color: var(--color-white); }
.nav__link.is-active { color: var(--color-white); background: rgba(1,84,249,.08); }

/* Estado sÃƒÆ’Ã‚Â³lido (segundo menÃƒÆ’Ã‚Âº): textos negros y active sobre fondo claro */
.site-nav.is-solid .nav__link { color: var(--color-black); }
.site-nav.is-solid .nav__link:hover { color: var(--color-black); }
.site-nav.is-solid .nav__link.is-active { color: var(--color-black); background: rgba(24,27,33,.06); }
/* Mantener CTA (Soy Cliente) igual que antes en el menÃƒÆ’Ã‚Âº sÃƒÆ’Ã‚Â³lido */
.site-nav.is-solid .nav__link.nav__cta { color: var(--color-white); }

.nav__link.nav__cta {
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
  border: 1px solid rgba(1,84,249,.35);
  color: var(--color-white);
  font-weight: 600;
  box-shadow: var(--shadow-2);
}
.nav__link.nav__cta:hover {
  background: linear-gradient(135deg, #2f4dd1, #2a73ff);
}
.nav__link.nav__cta.is-active {
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
  color: var(--color-white);
}

/* Toggle mÃƒÆ’Ã‚Â³vil */
.nav__toggle {
  display: none;
  width: 40px; height: 40px;
  align-items: center; justify-content: center;
  background: transparent; border: 1px solid rgba(184,187,195,.15);
  border-radius: 10px; cursor: pointer; color: var(--color-white);
}
.nav__toggle .nav__bar { display: block; width: 20px; height: 2px; background: var(--color-white); margin: 3px 0; border-radius: 2px; transition: transform .25s ease, opacity .25s ease; }
.nav__toggle.is-active .nav__bar:nth-child(1) { transform: translateY(5px) rotate(45deg); }
.nav__toggle.is-active .nav__bar:nth-child(2) { opacity: 0; }
.nav__toggle.is-active .nav__bar:nth-child(3) { transform: translateY(-5px) rotate(-45deg); }

/* Asegurar visibilidad del ÃƒÆ’Ã‚Â­cono del menÃƒÆ’Ã‚Âº cuando el nav es sÃƒÆ’Ã‚Â³lido (fondo blanco) */
.site-nav.is-solid .nav__toggle { border-color: rgba(24,27,33,.18); }
.site-nav.is-solid .nav__toggle .nav__bar { background: var(--color-black); }

/* ------------------------------ Secciones ------------------------------ */
#propuesta, #servicios, #clientes, #cta, #equipo, #faq, #contacto { scroll-margin-top: var(--nav-h, 84px); }
.section { padding: clamp(3rem, 6vw, 5rem) 0; }
.section__header { text-align: center; margin-bottom: clamp(1.5rem, 4vw, 2.5rem); }
.section__title { font-size: clamp(1.5rem, 4.5vw, 2.2rem); }
.section__subtitle { color: var(--color-gray-400); }

/* Link "personas" en Soy Equipo: sin subrayado, acento y en negrita */
.section--team .section__subtitle a.link[data-modal="team-modal"] {
  text-decoration: none;
  color: var(--color-accent);
  font-weight: 800;
}
.section--team .section__subtitle a.link[data-modal="team-modal"]:hover,
.section--team .section__subtitle a.link[data-modal="team-modal"]:focus {
  text-decoration: none;
  color: var(--color-accent);
}

/* Compensar contenido cuando el nav se vuelve sÃƒÆ’Ã‚Â³lido (evita que tape el contenido) */
body.nav-solid main { padding-top: var(--nav-h, 72px); }

.headline-belt__title {
  margin: 0;
  margin-left: 1.5cm;
  font-weight: 800;
  font-size: clamp(1.8rem, 5vw, 2.4rem); /* Aumentar tamaÃƒÆ’Ã‚Â±o de fuente */
  color: var(--color-white);
  letter-spacing: .2px;
  text-align: center;
  margin-top: auto !important;
  margin-bottom: clamp(8rem, 16vh, 12rem);
  padding-bottom: 0;
}
.headline-belt__dynamic { 
  color: var(--color-accent); 
  position: relative; 
  display: inline-block; 
  min-width: 12ch; 
  text-align: left; 
}
.headline-belt__static { 
  color: var(--color-gray-700);  /* Cambiar a gris mÃƒÆ’Ã‚Â¡s oscuro */
}
.headline-belt__dynamic::after {
  content: "";
  display: inline-block;
  width: 3px; height: 1.2em;
  background: var(--color-accent);
  margin-left: 6px;
  transform: translateY(2px);
  animation: caret-blink 1s steps(1) infinite;
}
@keyframes caret-blink { 50% { opacity: 0; } }
@media (prefers-reduced-motion: reduce) {
  .headline-belt__dynamic::after { animation: none; }
}

/* Servicios */
.section--services {
  background: #ffffff;
  position: relative;
  overflow: hidden;
  padding: 0;
  margin-top: 0;
}
.services__grid { display: grid; gap: 1.25rem; grid-template-columns: repeat(1, minmax(0,1fr)); }
.section--services .section__title { color: var(--color-gray-700); }
.section--services .section__subtitle { color: var(--color-primary); }
.section--services.arrive-highlight::after {
  /* Resaltado breve del borde inferior al llegar desde el menÃƒÆ’Ã‚Âº */
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 32px;
  pointer-events: none;
  background: linear-gradient(to top, rgba(1,84,249,.42), rgba(1,84,249,0));
  filter: blur(6px);
  opacity: 0;
  animation: servicesArrive 1.2s ease-out forwards;
}
@keyframes servicesArrive {
  0% { opacity: 0; transform: translateY(8px); }
  25% { opacity: .95; transform: translateY(0); }
  100% { opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
  .section--services.arrive-highlight::after { animation: none; opacity: .35; }
}
.section--services .section__header {
  width: 100%;
  margin: 0 0 clamp(10px, 1.6vw, 16px);
  padding: 0;
}
.section--services > .container { max-width: none; width: 100%; padding-left: 0; padding-right: 0; }
.section--services .services-overlay > .container { position: relative; }
.services-bg { position: relative; z-index: 0; }
.services-bg__video { width: 100%; height: auto; object-fit: cover; display: block; }
/* Overlay superior difuminado (borde horizontal) en #003aae */
.services-bg::before {
  content: "";
  position: absolute;
  left: 0; right: 0; top: 0; /* anclado exacto al inicio de la secciÃƒÆ’Ã‚Â³n */
  height: clamp(36px, 7vw, 110px);
  pointer-events: none;
  z-index: 1; /* por encima del video, por debajo del contenido (container z-index:1 en el flujo global) */
  background: linear-gradient(180deg,
    rgba(0, 58, 174, .20) 0%,
    rgba(0, 58, 174, .12) 44%,
    rgba(0, 58, 174, .05) 82%,
    rgba(0, 58, 174, 0) 100%
  );
  filter: none; /* sin blur para evitar resalto blanco en el borde */
}
.services-bg::after { content: none; }

/* Nuevo layout Servicios: izquierda video + iconos, derecha lista dinÃƒÆ’Ã‚Â¡mica */
.services-showcase { 
  position: static;
  display: grid; 
  grid-template-columns: 1fr 1fr; 
  gap: 0; 
  align-items: stretch; 
  margin: 0; 
  height: 100%;
}
.services-visual__media {
  position: relative;
  height: 100%;
}
.services-visual__video { width: 100%; height: 100%; object-fit: cover; display: block; }
.services-icons {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
/* ------------------------------ Servicios Â· Iconos flotantes ------------------------------ */
/* Consolidado: todos los estilos de iconos viven en este bloque para evitar duplicados. */
.service-icon {
  position: absolute;
  pointer-events: auto;
  width: clamp(62px, 5vw, 92px);
  aspect-ratio: 1 / 1;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(184,187,195,.35);
  border-radius: 999px;
  box-shadow: 0 8px 22px rgba(0,0,0,.25);
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
  overflow: visible;
  z-index: 1;
  will-change: transform;
  animation: pulseInner 2.2s ease-in-out infinite; /* palpitar suave como la insignia */
}
.service-icon__orbit {
  position: absolute;
  inset: -18px;
  border-radius: 50%;
  pointer-events: none;
  display: block;
  z-index: 2;
  animation: orbitSweep 4.8s linear infinite;
}
.service-icon__orbit::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1.5px solid rgba(1,84,249,.55);
  box-shadow: 0 0 18px rgba(1,84,249,.35);
  background: none;
}
.service-icon__orbit::after {
  content: "";
  position: absolute;
  top: -7px;
  left: 50%;
  width: 12px;
  height: 12px;
  margin-left: -6px;
  border-radius: 50%;
  background: #003aae;
  box-shadow: 0 0 16px rgba(0,58,174,.65);
}
.service-icon.is-active .service-icon__orbit { animation-duration: 3.8s; }
.service-icon.is-active .service-icon__orbit::before { border-color: rgba(1,84,249,.65); }
.service-icon.is-active .service-icon__orbit::after { box-shadow: 0 0 18px rgba(1,84,249,.85); }

@keyframes orbitSweep {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}
/* Contenido grÃ¡fico del botÃ³n */
.service-icon img {
  max-width: 90%;
  max-height: 90%;
  display: block;
  position: relative;
  z-index: 1;
}
/* Interacciones */
.service-icon.is-active {
  outline: 3px solid rgba(1,84,249,.35);
  background: #fff;
  transform: scale(1.06);
}
/* Anillo pulsante (halo animado) */
.service-icon::before {
  content: "";
  position: absolute;
  inset: -8px;
  border-radius: 50%;
  border: 2px solid rgba(1,84,249,.45);
  opacity: 0;
  transform: scale(1);
  animation: pulseRing 2.6s ease-out infinite;
}
/* Etiqueta emergente (usa el atributo title) */
.service-icon::after {
  content: attr(title);
  position: absolute;
  top: calc(100% + 10px);
  left: 50%;
  transform: translateX(-50%);
  padding: .35rem .6rem;
  border-radius: 999px;
  color: var(--color-white);
  background: rgba(14,18,34,.66);
  border: 1px solid rgba(1,84,249,.35);
  font-weight: 700;
  font-size: clamp(.78rem, 1.4vw, .95rem);
  line-height: 1;
  white-space: nowrap;
  box-shadow: 0 8px 22px rgba(0,0,0,.25);
  pointer-events: none;
}
.service-icon:hover::after { transform: translateX(-50%) translateY(-1px); }
.service-icon.is-active::after {
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
  border-color: rgba(1,84,249,.45);
  box-shadow: 0 12px 30px rgba(1,84,249,.28);
}
/* Ajuste puntual: evitar recorte en la posiciÃ³n 4 */
.service-icon.pos-4::after { top: calc(100% + 10px); }

.services-dynamic {
  position: absolute;
  right: var(--svcdyn-right);
  top: var(--svcdyn-top);
  height: auto;
  max-height: none;
  min-height: 0;
  transform: translateY(var(--svcdyn-translate));
  width: 50%;
  min-width: 420px;
  z-index: 2;
  display: flex; 
  flex-direction: column; 
  padding: clamp(14px, 2.2vw, 20px);
}

/* Desktop: mantener las cards mÃƒÆ’Ã‚Â¡s arriba (sin offset extra) */
@media (min-width: 1025px) {
  .services-dynamic {
    top: var(--svcdyn-top);
  }
}
.services-dynamic::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  mix-blend-mode: normal;
}
.services-dynamic__title { margin: .25rem 0 .6rem; font-size: clamp(1.05rem, 2vw, 1.35rem); color: var(--color-white); display: none; }
.services-dynamic__grid {
  display: grid;
  gap: .95rem;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  grid-auto-rows: auto;
  overflow: visible;
  padding: .25rem;
  align-content: start;
  align-items: stretch;
  justify-items: stretch;
  min-height: 300px; /* Altura mínima para mantener la posición del texto */
}

/* Cards dentro del panel */
.services-dynamic .service-item {
  background: linear-gradient(180deg, rgba(26,38,72,.96) 0%, rgba(10,18,40,.94) 100%);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  box-shadow: 0 16px 30px rgba(6,16,46,.25);
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease, background .25s ease;
  display: flex !important;        /* estructura vertical */
  flex-direction: column;
  align-self: stretch;
  height: 100%;                    /* fuerza a igualar la fila */
}
.services-dynamic .service-item:hover {
  transform: translateY(-6px);
  box-shadow: 0 32px 56px rgba(4,18,52,.42);
  border-color: rgba(255,255,255,.18);
}
.services-dynamic .service-item__media {
  aspect-ratio: 16 / 9;
  border-radius: 0;
  overflow: hidden;
  position: relative;
}
.services-dynamic .service-item__badge {
  position: absolute; left: 8px; top: 8px; 
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
  color: var(--color-white);
  border: 1px solid rgba(1,84,249,.35);
  border-radius: 999px;
  padding: 4px 10px;
  font-weight: 700; font-size: .78rem; line-height: 1; box-shadow: none;
}
.services-dynamic .service-item__body {
  padding: calc(.85rem + var(--svctext-margin)) 1rem calc(1rem + var(--svctext-margin));
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.services-dynamic .service-item__title {
  margin: 0;
  font-size: .98rem;
  font-weight: 800;
  color: var(--color-white);
  line-height: 1.25;                 /* interlineado mÃƒÆ’Ã‚Â¡s cÃƒÆ’Ã‚Â³modo */
  letter-spacing: -0.01em;           /* interletrado similar a referencia */
  display: -webkit-box;            /* clamp para alturas consistentes */
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.services-dynamic .service-item__desc {
  margin: 0;
  font-size: .95rem;
  line-height: 1.55;
  letter-spacing: .012em;
  color: rgba(255,255,255,.78);
  display: block;
  -webkit-line-clamp: unset !important;
  line-clamp: unset;
  -webkit-box-orient: unset;
  overflow: visible;
}
.services-dynamic .service-item .service-item__actions {
  margin-top: auto !important;
  padding: 0 .9rem .9rem;
}
.services-dynamic .service-item__actions { margin-bottom: 0; }
.services-dynamic .service-item__actions .btn--request {
  width: 100% !important;
  height: 32px !important;
  font-size: .88rem !important;
  padding: 0 .95rem !important;
  border-radius: 999px;
  background: linear-gradient(95deg, #0057ff 0%, #00a0ff 100%) !important;
  color: var(--color-white) !important;
  box-shadow: 0 16px 32px rgba(1,87,255,.32);
  border: 0;
  transition: transform .22s ease, box-shadow .22s ease;
}
.services-dynamic .service-item__actions .btn--request:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 40px rgba(1,87,255,.4);
}
.services-mobile-deck { display: none; }
.services-mobile-deck[hidden] { display: none !important; }
.services-mobile-deck__title { margin: 0 0 .75rem; font-size: 1.35rem; font-weight: 700; color: var(--color-primary); text-align: center; }
.services-mobile-deck__grid { display: grid; gap: 1rem; }

/* BotÃƒÆ’Ã‚Â³n "Solicitar" mÃƒÆ’Ã‚Â¡s protagonista pero con pÃƒÆ’Ã‚Â­ldora mÃƒÆ’Ã‚Â¡s compacta */
.service-item .service-item__actions { margin-top: .75rem; }
.service-item .btn--request {
  font-size: .95rem;
  font-weight: 700;
  height: 32px;
  width: 100%;
  padding: 0 .95rem;
  border-radius: 999px;
  line-height: 1;
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(95deg, #0057ff 0%, #00a0ff 100%);
  color: var(--color-white);
  box-shadow: 0 12px 24px rgba(1,87,255,.24);
  border: 0;
  transition: transform .2s ease, box-shadow .2s ease;
}
.service-item .btn--request:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 40px rgba(1,87,255,.4);
}

/* Ocultar el grid clÃƒÆ’Ã‚Â¡sico si existe el nuevo showcase */
.services-showcase ~ .services__grid { display: none; }

@media (max-width: 1024px) {
  .services-showcase { grid-template-columns: 1fr; min-height: unset; }
  .services-dynamic { display: none; }
  .services-dynamic::before { display: none; }
  .services-dynamic__title { color: var(--color-accent); }
  .services-dynamic__grid { grid-template-columns: 1fr; }
  .service-icon { width: 60px; height: 60px; }
  .service-icon::after { font-size: .8rem; padding: .3rem .5rem; }
   /* En mÃƒÆ’Ã‚Â³viles, subir menos para evitar recortes */
    .service-icon.pos-5 { top: 8%; left: 10%; bottom: auto; }


  /* Ocultar tÃƒÆ’Ã‚Â­tulo de categorÃƒÆ’Ã‚Â­a por defecto en mÃƒÆ’Ã‚Â³vil; se mostrarÃƒÆ’Ã‚Â¡ al seleccionar */
  .services-dynamic__title { display: none; }
  /* Mostrar el tÃƒÆ’Ã‚Â­tulo cuando hay una categorÃƒÆ’Ã‚Â­a activa */
  .services-dynamic.is-active .services-dynamic__title { display: block; }
  .services-mobile-deck { display: block; padding: 1.4rem 1.1rem 2.2rem; background: linear-gradient(180deg, rgba(12,18,33,.94), rgba(12,18,33,.88)); }
  .services-mobile-deck__grid { grid-template-columns: 1fr; }
  .services-mobile-deck__title { color: #003aae !important; }

  .section--services {
    margin-top: 0 !important;
    padding-top: 0;
  }
  .section--services .services-overlay > .container {
    padding-top: var(--svcoverlay-padding-top);
  }

  /* Responsive: mostrar solo la mitad izquierda del video de Servicios
     y un sutil brillo vertical en el corte (sorpresa visual) */
  /* TÃƒÆ’Ã‚Â­tulos de la secciÃƒÆ’Ã‚Â³n por encima del video en mÃƒÆ’Ã‚Â³vil */
  .section--services { position: relative; }
  .section--services .section__header {
    position: absolute;
    left: 0; right: 0;
    top: var(--svcheader-top);
    width: min(100% - 2rem, var(--container));
    margin-left: var(--svcheader-margin-left);
    margin-right: var(--svcheader-margin-right);
    z-index: 3; /* por encima de iconos */
    text-align: var(--svcheader-text-align);
    padding: .2rem .25rem; /* sin recuadro de fondo */
  }
  .section--services .section__title { color: var(--color-black) !important; text-shadow: none; font-weight: 700; }
  .section--services .section__subtitle { color: var(--color-accent) !important; text-shadow: none; display: none !important; }

  .services-bg { 
    position: relative; 
    overflow: hidden; 
    /* full-bleed: ocupar todo el ancho del viewport (borde a borde) */
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    width: 100vw; max-width: 100vw;
    height: clamp(350px, 28vh, 36vh); /* reducir significativamente la altura en mÃƒÆ’Ã‚Â³vil */
    z-index: 1; /* por debajo de iconos y tÃƒÆ’Ã‚Â­tulo */
  }
  .services-bg__video {
    width: 200%;                     /* mitad izquierda ocupa 100% del contenedor */
    max-width: none;                 /* anula max-width global en video */
    height: 100%;
    object-fit: cover;
    object-position: left center;    /* foco a la izquierda */
    clip-path: inset(0 50% 0 0);
    -webkit-clip-path: inset(0 50% 0 0);
  }
  .services-bg::before { content: none !important; display: none !important; }

  /* Overlay de iconos sobre el video (solo mÃƒÆ’Ã‚Â³vil) */
  .services-visual__media {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
    width: 100vw;
    height: clamp(350px, 28vh, 36vh); /* igual que el alto del video */
  }
  .services-icons {
    position: absolute; inset: 0;
    display: block; /* cancelar flex de la regla anterior */
    pointer-events: none; /* permitir clic solo en los botones */
  }
  .service-icon { position: absolute; pointer-events: auto; }

  /* Coordenadas especÃƒÆ’Ã‚Â­ficas por categorÃƒÆ’Ã‚Â­a (en % del viewport, afinadas a ojo) */
  /* Riesgos Laborales (debajo de la grÃƒÆ’Ã‚Âºa) */
   /* Seguros (sobre la casita pequeÃƒÆ’Ã‚Â±a) */
   /* Administrativas (punta del edificio central) */
   /* SST (debajo de Administrativas) */
   /* juridica (encima del edificio mÃƒÆ’Ã‚Â¡s alto a la derecha) */
  .service-icon.pos-2 { top: 39%; left: calc(56% - 1.8vw); right: auto; bottom: auto; }

  /* MÃƒÆ’Ã‚Â¡s pegado: reducir separaciÃƒÆ’Ã‚Â³n entre icono y etiqueta en responsive */
  .service-icon::after { top: calc(100% + 6px); }
}

@media (min-width: 1280px) {
  .services-dynamic__grid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }
  .service-icon { width: 88px; height: 88px; }
}

/* Desktop: restaurar layout original */
@media (min-width: 1025px) {
  /* Recuperar un espacio superior similar a los <br> eliminados */
  .section--services { padding-top: 0; }
  /* Controlar clearance del encabezado en desktop */
  .section--services .services-overlay > .container {
    position: relative;
    padding-top: var(--svcheader-desktop-clearance);
    min-height: var(--svcdyn-area-height);
  }
  .section--services .section__header {
    position: absolute;
    top: var(--svcheader-desktop-top);
    left: var(--svcheader-desktop-left);
    right: var(--svcheader-desktop-right);
    transform: var(--svcheader-desktop-transform);
    width: var(--svcheader-desktop-width);
    text-align: var(--svcheader-desktop-text-align);
    margin: 0;
  }
  .services-dynamic {
    position: absolute;
    top: var(--svcgrid-desktop-top);
    left: var(--svcgrid-desktop-left);
    right: var(--svcgrid-desktop-right);
    width: var(--svcgrid-desktop-width);
    transform: var(--svcgrid-desktop-transform);
    min-width: 0;
  }
  .services-dynamic__grid {
    position: static;
  }
  .services-dynamic .headline-belt__title {
    position: absolute;
    top: var(--svcbelt-desktop-top);
    left: var(--svcbelt-desktop-left);
    right: var(--svcbelt-desktop-right);
    transform: var(--svcbelt-desktop-transform);
    width: var(--svcbelt-desktop-width);
    text-align: var(--svcbelt-desktop-text-align);
    margin: 0;
  }
  .services-dynamic .headline-belt__title + .services-dynamic__grid,
  .services-dynamic__grid + .headline-belt__title { margin-top: 0; }
  /* Quitar espacio blanco entre Propuesta y Servicios */
  #propuesta { padding-bottom: clamp(14px, 2.4vw, 28px); }
  #servicios { margin-top: 0 !important; }
  #propuesta .proposal-media { margin-bottom: 0 !important; }
  /* Video base (sin full-bleed forzado en desktop) */
  .services-bg { margin-left: 0; margin-right: 0; width: 100%; max-width: 100%; height: auto; z-index: 0; }
  .services-bg__video { width: 100%; max-width: 100%; height: auto; clip-path: none; -webkit-clip-path: none; }
  /* Overlay/columna visual vuelve a flujo normal */
  .services-visual__media { position: relative; top: auto; left: auto; transform: none; width: auto; height: 100%; margin: 0; }
  .services-icons { position: absolute; inset: 0; transform: none; }
}

/* TÃƒÆ’Ã‚Â­tulos genÃƒÆ’Ã‚Â©ricos para tarjetas de servicio (aplica en panel y modal) */
.service-item__title { 
  margin: 0 0 .35rem; 
  font-size: 1.05rem; 
  font-weight: 800; 
  color: var(--color-white); 
  line-height: 1.25;           /* similar a referencia */
  letter-spacing: -0.01em;     /* interletrado compacto */
}

.service-card {
  background: rgba(24, 27, 33, 0.6);
  border: 1px solid rgba(184,187,195,0.12);
  border-radius: var(--radius);
  padding: 1.15rem;
  box-shadow: var(--shadow-1);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease, background .25s ease;
  cursor: pointer;
  user-select: none;
  outline: none;
  /* centrar contenido */
  justify-items: center;
  text-align: center;
}
.service-card:hover { 
  transform: translateY(-6px); 
  box-shadow: 0 12px 36px rgba(1,84,249,.22); 
  border-color: rgba(1,84,249,.45);
  background: #ffffff; /* modo claro al hover */
}

/* --- Overrides migrados desde JavaScript --- */

/* Estilos para FAQ */
.faq[data-collapsed="true"] details[data-extra="true"] { display: none !important; }
.faq__controls { display: flex; justify-content: center; gap: .5rem; margin-top: .75rem; }
.faq__controls[hidden] { display: none !important; }

/* Estilos para la secciÃƒÆ’Ã‚Â³n de Clientes */
.section--clients { background: #003aae !important; }
.clients-belt { margin-left: calc(50% - 50vw) !important; margin-right: calc(50% - 50vw) !important; width: 100vw !important; }
.clients-belt .belt__viewport { border-radius: 0 !important; border: 0 !important; box-shadow: none !important; }
.clients-belt .belt__viewport::before,
.clients-belt .belt__viewport::after { display: none !important; }

/* Estilos para la secciÃƒÆ’Ã‚Â³n de Propuesta */
@media (min-width: 901px) { 
  .proposal-media .badge-circle { margin-left: 11cm !important; } 
}

@media screen and (min-width: 1500px) and (max-width: 1680px) {
  .proposal-media .badge-circle {
    justify-self: start;
    margin-left: 3cm !important;
  }
}

@media screen and (min-width: 1280px) and (max-width: 1420px)
       and (orientation: landscape) {
  .proposal-media .badge-circle {
    justify-self: start;
    --size: clamp(130px, 18vw, 190px);
    margin-left: -2.5cm !important;
  }
  #login-modal.modal.modal--auth {
    place-items: center center !important;
    padding-top: 0;
    padding-bottom: 0;
  }
  #login-modal.modal.modal--auth .modal__dialog {
    transform: none;
  }
}

/* Estilos para el panel dinÃƒÆ’Ã‚Â¡mico de Servicios */
.services-dynamic__grid {
  gap: .9rem !important;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)) !important;
  overflow-y: visible !important;
  justify-items: stretch;
  align-items: stretch;
  width: 100%;
  max-width: 880px;
  margin: 0 auto;
  padding: .1rem;
}
.services-dynamic__grid.is-scrollable { overflow-y: auto !important; }
@media (min-width: 1025px) {
  .services-dynamic__grid {
    grid-auto-rows: auto !important;
  }
}
.services-dynamic .service-item__title { font-size: 1.08rem !important; }
.services-dynamic .service-item__desc { font-size: .88rem !important; }

.service-card:focus-visible { box-shadow: 0 0 0 4px rgba(1,84,249,.25), 0 12px 36px rgba(1,84,249,.22); border-color: rgba(1,84,249,.55); }
.service-card__icon { color: var(--color-accent); margin-bottom: .5rem; transition: color .25s ease; }
.service-card__icon svg { width: clamp(40px, 4.5vw, 56px); height: clamp(40px, 4.5vw, 56px); transition: transform .25s ease; }
.service-card:hover .service-card__icon svg { transform: scale(1.06); }
.service-card__title { font-size: 1.05rem; margin-bottom: .35rem; overflow-wrap: anywhere; word-break: normal; hyphens: none; color: var(--color-accent); }
.service-card__title, .service-card__desc { transition: color .25s ease; }
.service-card__desc { color: var(--color-primary); line-height: 1.6; overflow-wrap: anywhere; word-break: normal; hyphens: none; }
.service-card__actions { margin-top: .8rem; display: flex; }
.service-card__actions .btn--request { padding: .7rem 1rem; }

/* Colores de texto al hover claro */
.service-card:hover .service-card__title { color: var(--color-black); }
.service-card:hover .service-card__desc { color: var(--color-gray-700); }

/* Team */
.section--team { background: radial-gradient(1200px 600px at 10% -10%, rgba(37,58,148,.12), transparent 60%), var(--color-bg); }
.team__grid { display: grid; gap: 1.25rem; grid-template-columns: repeat(1, minmax(0,1fr)); }

/* Nuevo: combo de tarjetas sincronizadas (izquierda imagen/ÃƒÆ’Ã‚Â¡rea, derecha descripciÃƒÆ’Ã‚Â³n) */
.team-combo { 
  display: grid; 
  grid-template-columns: 1.35fr 1fr; 
  gap: clamp(1rem, 2.5vw, 1.5rem); 
  align-items: stretch; 
  margin-bottom: clamp(1rem, 3vw, 1.5rem);
}
.team-card { 
  background: linear-gradient(180deg, rgba(24,27,33,.66), rgba(24,27,33,.85)); 
  border: 1px solid rgba(184,187,195,.14); 
  border-radius: 14px; 
  box-shadow: 0 18px 40px rgba(0,0,0,.25);
  overflow: hidden; 
  position: relative;
}
.team-card .team-viewport { position: relative; overflow: hidden; height: 100%; min-height: clamp(320px, 40vw, 460px); }
.team-card .team-track { display: flex; height: 100%; will-change: transform; transition: transform .65s ease-out; }
.team-card .team-slide { flex: 0 0 100%; height: 100%; }
.team-visual .team-slide img { width: 100%; height: 100%; object-fit: cover; display: block; }
.team-caption { 
  position: absolute; left: 0; right: 0; bottom: 0; 
  padding: .85rem 1.1rem; 
  background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.55));
  color: var(--color-white); 
  font-weight: 700; font-size: clamp(1.1rem, 2.6vw, 1.35rem);
}
.team-progress { position: absolute; left: 0; right: 0; bottom: 0; height: 3px; background: rgba(255,255,255,.18); }
.team-progress .bar { display: block; width: 0%; height: 100%; background: linear-gradient(90deg, var(--color-primary), var(--color-accent)); }

.team-copy .team-slide { 
  display: grid; align-content: center; gap: .5rem; 
  padding: clamp(1rem, 3vw, 1.5rem); color: var(--color-offwhite);
}
.team-copy .team-slide h3 { margin: 0; font-size: clamp(1.2rem, 2.2vw, 1.6rem); color: var(--color-white); }
.team-copy .team-slide p { margin: 0; color: var(--color-gray-300); line-height: 1.6; }

/* Ocultar el grid anterior cuando existe el combo (estÃƒÆ’Ã‚Â¡ despuÃƒÆ’Ã‚Â©s en el DOM) */
.team-combo ~ .team__grid { display: none; }

.member-card { position: relative; perspective: 1000px; height: 320px; }
.member-card:focus { outline: none; }
.member-card:hover { transform: translateY(-6px); }
.member-card__inner {
  position: relative; width: 100%; height: 100%;
  transform-style: preserve-3d; transition: transform .7s cubic-bezier(.2,.8,.2,1);
  border-radius: var(--radius);
}
.member-card:hover .member-card__inner,
.member-card:focus-within .member-card__inner { transform: rotateY(180deg); }
.member-card__face {
  position: absolute; inset: 0; border-radius: var(--radius);
  backface-visibility: hidden; -webkit-backface-visibility: hidden;
  background: #0e1222; /* color de fondo solicitado */
  border: 1px solid rgba(184,187,195,0.12);
  box-shadow: var(--shadow-1);
  display: grid; align-content: center; justify-items: center;
  padding: 1.1rem 1rem 1.2rem;
}
.member-card__back {
  transform: rotateY(180deg);
  background: #0e1222; /* unificar color de fondo */
  border: 1px solid rgba(1,84,249,.35);
  color: var(--color-white);
  padding: 1.25rem 1.2rem;
}

.member-card__photo {
  width: 150px; height: 150px; margin: 0 auto .9rem;
  border-radius: 50%; padding: 3px;
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
  box-shadow: 0 8px 22px rgba(1,84,249,.25);
}
.member-card__img {
  width: 100%; height: 100%; display: block;
  border-radius: 50%; object-fit: cover; background: #0b101e;
}
.member-card__name { font-size: 1.05rem; color: var(--color-white); margin: 0 0 .2rem; font-weight: 700; }
.member-card__role { color: var(--color-gray-400); font-size: .95rem; }
.member-card__bio { color: var(--color-offwhite); opacity: .95; font-size: .95rem; line-height: 1.55; text-align: center; }

/* Clients - Fondo con imagen animada + video slider */
.section--clients {
  position: relative;
  background: linear-gradient(135deg, #0154f9 0%, #003aae 50%, #0e1222 100%);
  background-size: 200% 200%;
  animation: clients-gradient 18s ease-in-out infinite alternate, clients-pulse 7s ease-in-out infinite;
  overflow: hidden;
  padding-bottom: 0; /* la cinta queda pegada al fondo */
  padding-top: clamp(1.2rem, 3.2vw, 2.2rem); /* mÃƒÆ’Ã‚Â¡s compacta, similar a la secciÃƒÆ’Ã‚Â³n anterior */
}
.section--clients::before { content: none; }
.section--clients::after {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(1200px 600px at 90% -10%, rgba(37,58,148,.18), transparent 60%);
  pointer-events: none;
}
.section--clients > .container { position: relative; z-index: 1; }

/* Layout de Clientes: copy izquierda, video centro-derecha, quote derecha */
.clients-layout {
  display: grid;
  grid-template-columns: 1.35fr minmax(400px, 620px);
  gap: clamp(.8rem, 2.2vw, 1.6rem);
  align-items: start;
}
.clients-copy { grid-column: 1; grid-row: 1; }
.clients-copy .section__header { 
  text-align: left; 
  margin-bottom: clamp(0.4rem, 1.6vw, .8rem);
  padding-bottom: .6rem; 
  border-bottom: 1px solid rgba(255,255,255,.14);
}
.clients-copy .section__title { margin: 0 0 .25rem; }
.clients-copy .section__subtitle { margin: 0; }
.clients-copy { position: relative; }

.clients-media { display: grid; justify-items: center; align-items: start; grid-column: 2; grid-row: 1; margin-top: -.4rem; }
.clients-media .video-slider { width: 100%; max-width: 640px; }

.clients-quote { 
  grid-column: 2; /* a la derecha, debajo del tÃƒÆ’Ã‚Â­tulo */
  grid-row: 1;
  color: var(--color-white); 
  display: grid; gap: .5rem; align-content: start; 
  background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.03));
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 16px;
  padding: clamp(.8rem, 2.2vw, 1.1rem);
  box-shadow: 0 10px 26px rgba(0,0,0,.18);
  margin-top: 0; /* debajo del tÃƒÆ’Ã‚Â­tulo */
  backdrop-filter: blur(6px);
}
.clients-copy .section__title { 
  background: linear-gradient(90deg, var(--color-white), #e9ecff 35%, var(--color-accent));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.clients-quote__title { 
  font-size: clamp(1.6rem, 3.2vw, 2.2rem); 
  font-weight: 800; margin: 0; 
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.clients-quote__subtitle { color: #cfe0ff; font-weight: 700; margin: 0; letter-spacing: .2px; }
.clients-quote__desc { color: var(--color-offwhite); margin: 0; line-height: 1.72; font-size: .98rem; letter-spacing: .1px; }

/* Cinta de logos al final con margen superior */
.clients-belt { 
  margin-top: clamp(1rem, 3vw, 2rem); 
  width: 100%; 
  margin-left: calc(50% - 50vw); 
  margin-right: calc(50% - 50vw); 
  margin-bottom: 0; /* sin margen inferior */
}

/* Acento del marco de video en esta secciÃƒÆ’Ã‚Â³n */
.section--clients .video-frame { 
  border: 1px solid rgba(1,84,249,.35);
  box-shadow: var(--shadow-1), 0 0 0 6px rgba(1,84,249,.08);
}

@media (max-width: 1100px) {
  .clients-layout { grid-template-columns: 1fr minmax(360px, 1fr); }
  .clients-copy { grid-column: 1; grid-row: 1; }
  .clients-quote { grid-column: 2; grid-row: 1; }
  .clients-media { grid-column: 2; grid-row: 2; }
}
@media (max-width: 720px) {
  .clients-layout { grid-template-columns: 1fr; }
  .clients-media .video-slider { max-width: 100%; }
  .clients-copy { grid-column: 1; grid-row: auto; }
  .clients-quote { grid-column: 1; grid-row: auto; }
  .clients-media { grid-column: 1; grid-row: auto; }
}

@keyframes clients-gradient {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 50% 50%; }
  100% { background-position: 100% 50%; }
}
@keyframes clients-pulse {
  0%, 100% { background-size: 190% 190%; }
  50%      { background-size: 260% 260%; }
}
@media (prefers-reduced-motion: reduce) {
  .section--clients { animation: none; }
  .section--clients::before { animation: none; transform: none; }
}
.video-slider { position: relative; display: grid; grid-template-columns: 1fr; align-items: center; gap: .5rem; width: 100%; max-width: 620px; margin-inline: auto; }
.slider__viewport { overflow: hidden; border-radius: var(--radius); border: 1px solid rgba(184,187,195,.12); background: rgba(24,27,33,.55); }
.slider__track { display: flex; will-change: transform; transition: transform .55s cubic-bezier(.2,.8,.2,1); }
.slider__slide { min-width: 100%; padding: .75rem; }
.video-frame { aspect-ratio: 16 / 9; background: #0b101e; border-radius: 14px; overflow: hidden; box-shadow: var(--shadow-1); }
.video-frame iframe { width: 100%; height: 100%; display: block; border: 0; }

.slider__btn { position: absolute; top: 50%; transform: translateY(-50%); width: 44px; height: 44px; border-radius: 999px; border: 1px solid rgba(184,187,195,.2); background: rgba(24,27,33,.85); color: var(--color-white); display: grid; place-items: center; cursor: pointer; z-index: 2; box-shadow: 0 8px 22px rgba(1,84,249,.18); transition: background .2s ease, transform .2s ease, box-shadow .2s ease; }
.slider__btn:hover { background: rgba(24,27,33,.95); box-shadow: 0 10px 26px rgba(1,84,249,.26); }
.slider__btn--prev { left: .5rem; }
.slider__btn--next { right: .5rem; }

@media (max-width: 700px) {
  .slider__slide { padding: .5rem; }
  .slider__btn { width: 38px; height: 32px; }
}

/* Clients - Logos Belt */

/* ------------------------------ Services: Cards Carousel (desktop) ------------------------------ */
@media (min-width: 1025px) {
  .services-dynamic[data-mode="carousel"] {
    width: 100%;
    min-width: 0;
    overflow: visible;
  }
  .services-dynamic__grid[data-mode="carousel"] { 
    padding-right: 0; 
    overflow: visible;
    min-height: auto;
  }
  .services-carousel {
    position: relative;
    width: 100%;
    --svc-gap: 12px;
    --svc-card-width: calc((100% - 24px) / 3);
  }
  .services-carousel .slider__viewport {
    overflow: hidden;
    border-radius: 0;
    border: 0;
    background: transparent;
    width: 100%;
    position: relative;
  }
  .services-carousel .slider__track {
    display: flex;
    gap: var(--svc-gap);
    will-change: transform;
    transition: transform .65s cubic-bezier(.25,.8,.25,1);
    width: 100%;
    align-items: stretch;
  }
  .services-carousel .slider__slide {
    flex: 0 0 var(--svc-card-width);
    min-width: var(--svc-card-width);
    max-width: var(--svc-card-width);
    padding: 0;
    opacity: 1;
    transform: scale(1);
    transition: all .3s ease;
  }
  /* Efecto hover en slides */
  .services-carousel .slider__slide:hover {
    transform: scale(1.02) translateY(-4px);
    z-index: 2;
  }
  .services-carousel .service-item { 
    height: 100%; 
    box-shadow: 0 8px 24px rgba(1,84,249,.15);
    border: 1px solid rgba(1,84,249,.08);
    transition: all .3s ease;
  }
  .services-carousel .service-item:hover {
    box-shadow: 0 16px 40px rgba(1,84,249,.25);
    border-color: rgba(1,84,249,.2);
  }
  /* Botones con animaciÃ³n */
  .services-carousel .slider__btn--prev { 
    left: -24px; 
    background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
    border: 0;
    transform: translateY(-50%) scale(1);
    transition: all .3s ease;
  }
  .services-carousel .slider__btn--next { 
    right: -24px;
    background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
    border: 0;
    transform: translateY(-50%) scale(1);
    transition: all .3s ease;
  }
  .services-carousel .slider__btn:hover {
    transform: translateY(-50%) scale(1.1);
    box-shadow: 0 12px 32px rgba(1,84,249,.4);
  }
  .services-carousel .slider__btn:disabled {
    opacity: 0.4;
    transform: translateY(-50%) scale(0.9);
    pointer-events: none;
  }
  /* Indicadores de progreso */
  .services-carousel::after {
    content: "";
    position: absolute;
    bottom: -16px;
    left: 50%;
    transform: translateX(-50%);
    width: 60px;
    height: 3px;
    background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
    border-radius: 999px;
    opacity: 0.6;
  }
}

@media screen and (min-width: 1330px) and (max-width: 1380px) and (max-height: 800px) {
  /* Contenedor ajustado (ligeramente más pequeño que la versión anterior) */
  .services-dynamic__grid { max-width: 880px; }
  /* En modo carrusel, reducir un poco el ancho efectivo del contenedor */
  .services-dynamic[data-mode="carousel"] { width: 62% !important; min-width: 0 !important; }
  .services-carousel {
    /* Mantener gap en 12px para coincidir con la lógica JS (main.js) */
    --svc-gap: 12px;
    /* 3 por vista: ancho exacto por tarjeta considerando el gap */
    --svc-card-width: calc((100% - (var(--svc-gap) * 2)) / 3);
  }
  .services-carousel .slider__slide {
    padding: 0;
    flex: 0 0 var(--svc-card-width);
    max-width: var(--svc-card-width);
  }
  /* Evitar escalado por transform (no afecta layout y puede desalinear el carrusel) */
  .services-carousel .service-item {
    transform: none;
    transform-origin: center top;
  }
  .services-carousel .service-item:hover {
    transform: translateY(-2px);
  }
  .services-carousel .service-item__body {
    padding: calc(.75rem + var(--svctext-margin)) .75rem calc(.8rem + var(--svctext-margin));
  }
  .services-carousel .service-item__title {
    font-size: .9rem;
  }
  .services-carousel .service-item__desc {
    font-size: .82rem;
    line-height: 1.42;
  }
  .services-carousel .service-item__actions {
    padding: 0 .75rem .75rem;
  }
  .services-carousel .service-item__actions .btn--request {
    height: 31px !important;
    font-size: .86rem !important;
    padding: 0 .8rem !important;
  }
}

.clients-belt { margin-top: 1.25rem; width: 100%; margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); }
.belt__viewport {
  position: relative;
  overflow: hidden;
  background: var(--color-white);
  border-radius: var(--radius);
  border: 1px solid rgba(24,27,33,.08);
  box-shadow: 0 8px 26px rgba(0,0,0,.18);
  padding-block: 34px; /* mÃƒÆ’Ã‚Â¡s gruesa */
}
.belt__viewport::before,
.belt__viewport::after {
  content: "";
  position: absolute; top: 0; bottom: 0; width: 80px; pointer-events: none;
  z-index: 2;
  display: none; /* sin difuminado en los bordes */
}
.belt__viewport::before { left: 0; }
.belt__viewport::after { right: 0; }
.belt__track {
  display: flex;
  width: max-content;
  animation: belt-scroll 28s linear infinite;
}
.belt__list { display: flex; align-items: center; gap: clamp(36px, 6.5vw, 84px); padding: 0 32px; list-style: none; margin: 0; }
.belt__item img { height: clamp(56px, 9.5vw, 110px); width: auto; display: block; }

@keyframes belt-scroll {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

@media (prefers-reduced-motion: reduce) {
  .belt__track { animation: none; }
}

/* Clientes: logos mÃƒÆ’Ã‚Â¡s grandes en mÃƒÆ’Ã‚Â³viles */
@media (max-width: 640px) {
  .clients-belt .belt__item img { height: clamp(84px, 22vw, 140px); }
  .clients-belt .belt__list { gap: clamp(28px, 8vw, 48px); padding: 0 24px; }
  .clients-belt .belt__viewport { padding-block: clamp(26px, 6vw, 36px); }
}

/* Placeholder sections */
.section--placeholder { background: #0d1324; }

/* ------------------------------ Beneficios (features) ------------------------------ */
.features__grid { display: grid; gap: 1rem; grid-template-columns: repeat(1, minmax(0,1fr)); }
.feature-card {
  background: rgba(24,27,33,.06);
  border: 1px solid rgba(24,27,33,.12);
  border-radius: var(--radius);
  padding: 1rem;
}
.section--light .feature-card { background: #ffffff; border-color: rgba(24,27,33,.12); box-shadow: 0 6px 20px rgba(0,0,0,.08); }
.feature-card__icon { color: var(--color-accent); margin-bottom: .35rem; }
.feature-card__title { margin: 0 0 .2rem; color: inherit; font-size: 1.05rem; }
.feature-card__desc { margin: 0; color: var(--color-gray-700); }

/* ------------------------------ CTA ------------------------------ */
.cta { 
  position: relative; 
  border-radius: var(--radius); 
  overflow: hidden; 
  border: 1px solid rgba(1,84,249,.2);
  background: radial-gradient(1200px 600px at 0% 0%, rgba(1,84,249,.12), transparent 60%),
              radial-gradient(1200px 600px at 100% 100%, rgba(37,58,148,.12), transparent 60%),
              linear-gradient(180deg, #ffffff, #f6f8ff);
  box-shadow: 0 10px 30px rgba(1,84,249,.12);
}
.cta__inner { padding: clamp(1.2rem, 4vw, 2rem); text-align: center; }
.cta__title { color: var(--color-black); font-size: clamp(1.4rem, 4.5vw, 2rem); margin: 0 0 .3rem; }
.cta__subtitle { color: #334155; margin: 0 0 .6rem; }
.cta__actions { display: flex; justify-content: center; gap: .5rem; flex-wrap: wrap; }

/* ------------------------------ FAQ ------------------------------ */
.faq { display: grid; gap: .75rem; max-width: 920px; margin-inline: auto; }
.faq details { 
  background: #ffffff; border: 1px solid rgba(24,27,33,.12); border-radius: 14px; 
  box-shadow: 0 6px 20px rgba(0,0,0,.06);
}
.faq summary { 
  list-style: none; cursor: pointer; padding: 1rem 1rem 1rem 2.5rem; position: relative; 
  font-weight: 600; color: var(--color-black);
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::before { 
  content: ""; position: absolute; left: 1rem; top: 1.15rem; width: 14px; height: 14px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--color-accent), var(--color-primary));
  box-shadow: 0 0 0 3px rgba(1,84,249,.15);
}
.faq .faq__a { padding: 0 1rem 1rem 2.5rem; color: var(--color-gray-700); }

/* Footer */
.footer { background: #0b101e; border-top: 1px solid rgba(184,187,195,0.08); }
.footer__inner { padding: clamp(2rem, 6vw, 3.5rem) 0; color: var(--color-offwhite); }
.footer__grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 1.5rem; }
.footer__col { background: rgba(24,27,33,.6); border: 1px solid rgba(184,187,195,.12); border-radius: var(--radius); padding: 1.2rem; box-shadow: var(--shadow-1); }
/* Contacto: dejar sin tarjetas (plano, directo en la pÃƒÆ’Ã‚Â¡gina) */
.footer__col.footer__info { background: transparent; border: 0; box-shadow: none; padding: 0; }
.footer__title { margin: 0 0 .75rem; font-size: 1.2rem; }

/* Contact info */
.contact-list { list-style: none; padding: 0; margin: 0; display: grid; gap: .4rem; }
.contact-item { display: grid; grid-template-columns: 24px 1fr; gap: .65rem; align-items: start; background: transparent; border: 0; padding: .4rem 0; border-radius: 0; }
/* En el footer, eliminamos lÃƒÆ’Ã‚Â­neas por defecto y dejamos solo una bajo 'DirecciÃƒÆ’Ã‚Â³n' */
.footer__info .contact-list .contact-item { border-bottom: 0; }
.footer__info .contact-list .contact-item:nth-child(1) { border-bottom: 1px solid rgba(184,187,195,.12); }
.contact-item__icon { color: var(--color-accent); display: inline-grid; place-items: center; }
.contact-item__body strong { color: var(--color-white); display: block; font-size: .98rem; margin-bottom: .15rem; }
.contact-item__body p, .contact-item__body a { color: var(--color-offwhite); text-decoration: none; }
.contact-item__body a:hover { text-decoration: underline; }

/* Forms */
.newsletter { display: grid; gap: .5rem; margin-bottom: 1rem; }
.newsletter__label { color: var(--color-offwhite); }
.newsletter__bar { display: grid; grid-template-columns: 1fr auto; gap: .5rem; background: rgba(184,187,195,.06); border: 1px solid rgba(184,187,195,.12); padding: .5rem; border-radius: 999px; }
.newsletter__input { background: transparent; border: 0; color: var(--color-white); padding: .6rem .8rem; outline: none; font: inherit; }
.newsletter__input::placeholder { color: #aeb3bd; }

.contact-form { display: grid; gap: .75rem; }
.form__row { display: grid; gap: .35rem; }
.form__label { color: var(--color-offwhite); font-size: .95rem; }
.form__input { background: rgba(184,187,195,.06); border: 1px solid rgba(184,187,195,.12); color: var(--color-white); padding: .75rem .85rem; border-radius: 12px; outline: none; font: inherit; }
.form__input:focus { border-color: rgba(1,84,249,.45); box-shadow: 0 0 0 3px rgba(1,84,249,.25); }
.form__textarea { resize: vertical; min-height: 120px; }
.form__actions { margin-top: .2rem; }

.footer__copy { text-align: center; color: var(--color-gray-400); margin-top: 1.2rem; font-size: .95rem; }

@media (max-width: 900px) {
  .footer__grid { grid-template-columns: 1fr; }
}

/* ------------------------------ Modal Servicios ------------------------------ */
/* Subfooter juridica/creditos */
.subfooter { background: #061408; border-top: 1px solid rgba(184,187,195,0.12); }
.subfooter__inner { padding: .9rem 0; }
.subfooter__copy { text-align: center; color: var(--color-gray-400); font-size: .95rem; margin: 0; }
.subfooter__link { color: #0086FF; font-weight: 700; text-decoration: none; position: relative; }
.subfooter__link::after { content: ""; position: absolute; left: 0; bottom: -2px; height: 2px; width: 100%; background: #0086FF; transform: scaleX(0); transform-origin: left; transition: transform .25s ease; }
.subfooter__link:hover::after { transform: scaleX(1); }
.subfooter__link:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 2px; border-radius: 3px; }
.modal[hidden] { display: none !important; }
.modal {
  position: fixed; inset: 0; z-index: 1000; display: grid; place-items: center;
}
.modal__overlay { position: absolute; inset: 0; background: rgba(0,0,0,.6); backdrop-filter: blur(2px); }
.modal__dialog {
  position: relative; z-index: 1; width: min(96%, 1100px);
  background: #ffffff;
  border: 0;
  border-radius: 16px;
  box-shadow: 0 24px 60px rgba(0,0,0,.18);
}
.modal__header { display: flex; align-items: center; justify-content: space-between; padding: .9rem 1rem; border-bottom: 1px solid rgba(184,187,195,.12); }
.modal__header h3 { margin: 0; font-size: 1.2rem; }
.modal__close { background: transparent; border: 1px solid rgba(184,187,195,.18); color: var(--color-white); width: 36px; height: 36px; border-radius: 10px; cursor: pointer; }
.modal__close:hover { background: rgba(184,187,195,.08); }
.modal__content { padding: 1rem 1.25rem; max-height: min(80svh, 760px); overflow: auto; }
.modal__grid { display: grid; gap: 1rem; grid-template-columns: repeat(1, minmax(0,1fr)); }

/* Modal del Equipo: sin cabecera ni botÃƒÆ’Ã‚Â³n cerrar, animaciÃƒÆ’Ã‚Â³n sutil y esquinas redondeadas */
#team-modal .modal__header, 
#team-modal .modal__close { display: none !important; }
#team-modal .modal__dialog { 
  /* Esquinas derechas cuadradas para mejorar el slide */
  border-radius: 24px 0 0 24px; 
  overflow: hidden; 
  transform: translateY(6px) scale(.99); 
  opacity: 0; 
  animation: teamModalIn .24s ease-out forwards; 
}
#team-modal .modal__content { padding: 1rem; border-radius: inherit; }
#team-modal .modal__grid { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 1rem; }
#team-modal .member-card, 
#team-modal .member-card__face { border-radius: 20px; }

@keyframes teamModalIn { to { transform: none; opacity: 1; } }

.service-item { background: rgba(11,16,30,.6); border: 1px solid rgba(184,187,195,.12); border-radius: 14px; overflow: hidden; display: flex; flex-direction: column; }
.service-item__media { aspect-ratio: 16 / 9; background: #0b101e; display: grid; place-items: center; overflow: hidden; border-top-left-radius: 14px; border-top-right-radius: 14px; position: relative; }
.service-item__badge { position: absolute; left: 10px; top: 10px; background: linear-gradient(135deg, var(--color-primary), var(--color-accent)); color: var(--color-white); border: 1px solid rgba(1,84,249,.35); border-radius: 999px; padding: 5px 12px; font-weight: 700; font-size: .82rem; line-height: 1; box-shadow: 0 6px 14px rgba(1,84,249,.25); }
.service-item__media img { width: 100%; height: 100%; object-fit: cover; }
.service-item__body { padding: 1rem 1.6rem 1.2rem; display: flex; flex-direction: column; gap: .45rem; flex: 1 1 auto; }
.service-item__desc { 
  color: var(--color-gray-400); 
  font-size: .96rem; 
  line-height: 1.55;           /* interlineado mÃƒÆ’Ã‚Â¡s suelto */
  letter-spacing: .01em;       /* leve separaciÃƒÆ’Ã‚Â³n */
  overflow-wrap: anywhere; word-break: normal; hyphens: none; 
}
.service-item__actions { margin-top: auto; display: flex; }
.service-item__actions .btn--request { width: 100%; padding: .75rem 1rem; }

/* Bloqueo de scroll cuando modal estÃƒÆ’Ã‚Â¡ abierto */
body.modal-open { overflow: hidden; }

/* ------------------------------ Auth Modal (Login/Registro) ------------------------------ */
.auth-modal {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto 1fr;
  gap: .9rem;
  align-items: stretch;
}
.auth-modal__left {
  position: relative;
  overflow: hidden;
  border-radius: 14px;
  background: linear-gradient(140deg, #0f1533 0%, #0e1222 45%, #0b1022 100%);
  display: grid;
  place-items: center;
  min-height: clamp(200px, 34svh, 300px);
}
.auth-modal__left::after {
  content: "";
  position: absolute; left: 0; right: 0; bottom: 0; height: 2px;
  background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
  opacity: .6;
}
.auth-left__layer {
  position: absolute; inset: 0;
  background: radial-gradient(1200px 600px at -5% -15%, rgba(37,58,148,.25), transparent 60%),
              radial-gradient(1000px 500px at 110% 10%, rgba(1,84,249,.22), transparent 60%);
}
.auth-left__content { position: relative; z-index: 1; text-align: center; padding: clamp(1rem, 3vw, 1.5rem); }
.auth-left__logo { width: min(340px, 80%); margin-inline: auto; filter: drop-shadow(0 10px 24px rgba(1,84,249,.25)); }
.auth-left__title { color: var(--color-white); margin: .8rem 0 .2rem; font-size: clamp(1.3rem, 2.6vw, 1.7rem); font-weight: 700; }
.auth-left__subtitle { color: var(--color-gray-400); max-width: 48ch; margin: 0 auto; }
.auth-left__decor { position: absolute; border-radius: 50%; filter: blur(40px); opacity: .35; }
.auth-left__decor--1 { width: 240px; height: 240px; background: #253a94; top: 4%; left: -4%; }
.auth-left__decor--2 { width: 200px; height: 200px; background: #0154f9; bottom: 8%; right: -3%; }
.auth-left__decor--3 { width: 160px; height: 160px; background: #003aae; top: 22%; right: 8%; opacity: .25; }

.auth-modal__right {
  display: grid;
  grid-template-rows: auto 1fr;
  gap: .8rem;
  padding: clamp(.8rem, 3vw, 1rem);
  background: linear-gradient(180deg, rgba(24,27,33,.66), rgba(24,27,33,.85));
  border: 1px solid rgba(184,187,195,.14);
  border-radius: 14px;
  box-shadow: var(--shadow-1);
  backdrop-filter: blur(10px);
}
.auth-tabs {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: .5rem;
  background: rgba(14,18,34,.6);
  padding: .5rem; border-radius: calc(var(--radius) + 2px);
  border: 1px solid rgba(184,187,195,.1);
}
.auth-tab {
  appearance: none; background: transparent; border: 0; color: var(--color-gray-400);
  padding: .7rem 1rem; border-radius: var(--radius); cursor: pointer; font-weight: 600;
  display: inline-flex; align-items: center; gap: .5rem; justify-content: center;
}
.auth-tab:hover { color: var(--color-white); }
.auth-tab.is-active { color: var(--color-white); background: linear-gradient(135deg, rgba(37,58,148,.35), rgba(1,84,249,.35)); border: 1px solid rgba(1,84,249,.35); }

.auth-panes { background: transparent; border-radius: 12px; }
.auth-pane { display: none; }
.auth-pane.is-active { display: block; }

.auth-field { display: grid; gap: .35rem; margin-bottom: .85rem; }
.auth-field label { color: var(--color-offwhite); font-size: .95rem; }
.auth-input-group { position: relative; }
.auth-input-group input[type="text"],
.auth-input-group input[type="email"],
.auth-input-group input[type="password"],
.auth-pane input[type="text"],
.auth-pane input[type="email"],
.auth-pane input[type="tel"],
.auth-pane input[type="password"] {
  width: 100%; padding: .85rem 1rem; border-radius: 12px;
  border: 1px solid rgba(2,6,23,.06);
  background: #f8fafc;
  color: #0f172a;
  outline: none;
  height: 40px;
  box-sizing: border-box;
  font: inherit;
}
.auth-pane textarea { resize: vertical; min-height: 100px; border-radius: 12px; border: 1px solid rgba(2,6,23,.06); background: #f8fafc; color: #0f172a; outline: none; padding: .85rem 1rem; line-height: 1.4; font: inherit; }
.auth-pane input::placeholder, .auth-pane textarea::placeholder { color: #9fa3ad; }
.auth-input-group input:focus, .auth-pane textarea:focus { border-color: var(--color-accent); box-shadow: 0 0 0 3px rgba(1,84,249,.18); }
.auth-pane input:focus, .auth-pane textarea:focus { border-color: rgba(1,84,249,.5); box-shadow: 0 0 0 4px rgba(1,84,249,.12); }

.auth-field-row { display: flex; align-items: center; justify-content: space-between; gap: .75rem; margin-bottom: .9rem; }
.auth-check { display: inline-flex; align-items: center; gap: .5rem; color: var(--color-gray-400); }
.auth-check input[type="checkbox"] { width: 16px; height: 16px; border-radius: 4px; border: 1px solid rgba(148,163,184,.6); }
.auth-check input[type="checkbox"]:focus { outline: 2px solid rgba(1,84,249,.45); outline-offset: 2px; }
.auth-check.is-invalid { color: #b91c1c; }
.auth-check.is-invalid input[type="checkbox"] { border-color: rgba(220,38,38,.75); box-shadow: 0 0 0 3px rgba(248,113,113,.25); }
.auth-terms-link { color: #1d4ed8; font-weight: 600; text-decoration: underline; transition: color .15s ease; }
.auth-terms-link:hover { color: #2563eb; }
.auth-check.is-invalid .auth-terms-link { color: #b91c1c; }
.auth-alert {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  margin-bottom: .65rem;
  padding: .35rem .55rem;
  border-radius: 999px;
  border: 1px solid rgba(220,38,38,.35);
  background: rgba(254,226,226,.85);
  color: #b91c1c;
  font-weight: 600;
  font-size: .82rem;
  line-height: 1;
  white-space: nowrap;
}
.auth-alert::before {
  content: "\26A0";
  font-size: .85rem;
  font-weight: 800;
  color: #ef4444;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.auth-alert--error {
  border-color: rgba(220,38,38,.35);
  background: rgba(254,226,226,.9);
  color: #b91c1c;
}
.auth-alert--error::before {
  content: "\26A0";
  color: #ef4444;
}
.auth-alert--success {
  border-color: rgba(16,185,129,.35);
  background: rgba(209,250,229,.9);
  color: #047857;
}
.auth-alert--success::before {
  content: "\2714";
  color: #047857;
}
.auth-alert--info {
  border-color: rgba(37,99,235,.28);
  background: rgba(219,234,254,.92);
  color: #1d4ed8;
}
.auth-alert--info::before {
  content: "\2139";
  color: #2563eb;
}
.auth-alert[hidden] { display: none !important; }
.auth-link { color: var(--color-gray-400); text-decoration: none; }
.auth-link:hover { color: var(--color-white); }

/* Evitar salto de lÃƒÆ’Ã‚Â­nea en 'Ãƒâ€šÃ‚Â¿Olvidaste tu contraseÃƒÆ’Ã‚Â±a?' solo en el modal de login */
#login-modal .auth-link { white-space: nowrap; }

/* Reducir tamaÃƒÆ’Ã‚Â±o de texto en la fila de 'RecuÃƒÆ’Ã‚Â©rdame' y el enlace de recuperaciÃƒÆ’Ã‚Â³n */
#login-modal .auth-field-row { gap: .5rem; }
#login-modal .auth-field-row .auth-check span,
#login-modal .auth-field-row .auth-link { font-size: .82rem; }

.auth-toggle-pass {
  position: absolute; right: .35rem; top: 50%; transform: translateY(-50%);
  background: transparent; border: 0; color: var(--color-gray-400); font-size: 1.05rem; cursor: pointer; padding: .35rem .45rem; border-radius: 8px;
}
.auth-toggle-pass:hover { color: var(--color-white); background: rgba(206, 227, 14, 0.08); }

.auth-btn--block { width: 100%; }

/* AnimaciÃƒÆ’Ã‚Â³n de apariciÃƒÆ’Ã‚Â³n del modal (configurada en .modal--auth .modal__dialog) */
@keyframes login-pop { to { transform: none; opacity: 1; } }

/* Estilos del contenido del modal unificados vÃƒÆ’Ã‚Â­a .modal--auth */

/* Posicionamiento unificado en .modal--auth */

/* Overlay unificado en .modal--auth .modal__overlay */
/* Tabs solo en el login */
#login-modal .auth-tabs { gap: .2rem; padding: .1rem; }
#login-modal .auth-tab__icon { display: none; }
#login-modal .auth-tab { padding: .4rem .6rem; font-size: .88rem; }

/* Las alturas y max-height se controlan en .modal--auth */

/* Alturas muy cortas: hacer aÃƒÆ’Ã‚Âºn mÃƒÆ’Ã‚Â¡s compacto */
@media (max-height: 680px) {
  .modal--auth .modal__dialog { width: min(96%, 340px); }
  .modal--auth .auth-modal__left { min-height: 84px; }
  .modal--auth .auth-left__logo { width: min(120px, 50%); }
}

@media (max-width: 900px) {
  .auth-modal { grid-template-columns: 1fr; min-height: unset; }
  .auth-modal__left { min-height: 200px; }
}

/* Login modal: estilos del contenedor unificados vÃƒÆ’Ã‚Â­a .modal--auth */

@keyframes logo-breathe {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.12); opacity: .98; }
}

/* Respeto a reduce motion gestionado por selector unificado mÃƒÆ’Ã‚Â¡s arriba */
/* Panel derecho del login se rige por .modal--auth .auth-modal__right */

#login-modal .auth-tabs { 
  background: transparent; 
  padding: .1rem; 
  border-radius: 16px; 
  display: grid; grid-template-columns: repeat(2, 1fr); gap: .2rem; 
}
#login-modal .auth-tab { 
  background: transparent; 
  color: var(--color-primary); 
  border: 1px solid rgba(37,58,148,.35); 
  border-radius: 999px; 
  padding: .5rem .8rem; 
  text-align: center; 
  transition: background .2s ease, color .2s ease, border-color .2s ease, transform .15s ease; 
}
#login-modal .auth-tab:hover { background: rgba(1,84,249,.06); color: var(--color-primary); transform: translateY(-1px); }
#login-modal .auth-tab.is-active { 
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent)); 
  border-color: rgba(1,84,249,.35); 
  color: #ffffff; 
  box-shadow: var(--shadow-2);
}

#login-modal .auth-panes { background:transparent; }
#login-modal .auth-field label,
#login-modal .auth-pane label { color: #000000; }
#login-modal .auth-pane h3,
#login-modal .auth-pane h4,
#login-modal .auth-pane .auth-heading,
#login-modal .auth-pane .auth-title { color: #6e6e6e; }

/* Modal registro/asesorÃƒÆ’Ã‚Â­a: colores pedidos (tÃƒÆ’Ã‚Â­tulos = color subtÃƒÆ’Ã‚Â­tulo, labels = color tÃƒÆ’Ã‚Â­tulo) */
.modal--auth .auth-pane h3,
.modal--auth .auth-pane h4,
.modal--auth .auth-pane .auth-heading,
.modal--auth .auth-pane .auth-title { color: #6e6e6e; }
.modal--auth .auth-field label,
.modal--auth .auth-pane label { color: #000000; }

/* Inputs/textarea del login se rigen por reglas genÃƒÆ’Ã‚Â©ricas de .auth-pane */

#login-modal .auth-link { color:#475569; }
#login-modal .auth-link:hover { color:#0f172a; }

/* Texto de tÃƒÆ’Ã‚Â©rminos mÃƒÆ’Ã‚Â¡s pequeÃƒÆ’Ã‚Â±o y equilibrado */
#login-modal .auth-check span { font-size: .78rem; line-height: 1.3; color:#475569; }
#login-modal .auth-check input[type="checkbox"] { width: 16px; height: 16px; border-radius: 4px; }


.auth-btn--block {
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
  border:1px solid rgba(1,84,249,.35);
  color:#fff;
  border-radius: 999px;
}

/* Contenido del login regido por .modal--auth .modal__content */

/* Restaurar estilo oscuro para AsesorÃƒÆ’Ã‚Â­a */
/* AsesorÃƒÆ’Ã‚Â­a: usa la misma unificaciÃƒÆ’Ã‚Â³n .modal--auth y los estilos genÃƒÆ’Ã‚Â©ricos de .auth-pane */

/* ------------------------------ Responsivo ------------------------------ */
  @media (max-width: 900px) {
    /* Logo mÃƒÆ’Ã‚Â¡s grande en el menÃƒÆ’Ã‚Âº responsive */
    .site-nav.is-solid .nav__logo { height: 44px; }
    .nav__toggle { display: inline-flex; }
    .nav__inner { position: relative; }
    .split { grid-template-columns: 1fr; }
    .split__col:last-child { justify-items: center; }

    .nav__links {
      position: absolute;
      left: 0; right: 0; top: calc(100% + 8px);
      flex-direction: column;
      background: rgba(14,18,34,.92);
      border: 1px solid rgba(184, 187, 195, 0.12);
      border-radius: var(--radius);
      margin: 0 1rem;
      padding: .5rem;
      z-index: 1001; /* por encima de overlays de la secciÃƒÆ’Ã‚Â³n Servicios */
      max-height: 0; overflow: hidden;
      opacity: 0; transform: translateY(-6px);
      transition: max-height .3s ease, opacity .2s ease, transform .2s ease;
    }

  @media screen and (min-width: 1550px) and (max-width: 1650px)
         and (min-height: 850px) and (max-height: 950px)
         and (orientation: landscape) {
    :root {
      --svcbelt-desktop-left: clamp(-26rem, -1vw, -6rem);
    }
  }
    /* Asegurar que el botÃƒÆ’Ã‚Â³n toggle tambiÃƒÆ’Ã‚Â©n quede por encima */
    .site-nav { z-index: 1000; }
    .site-nav .nav__toggle { z-index: 1002; position: relative; }
    .nav__links.is-open { max-height: 85svh; opacity: 1; transform: translateY(0); overflow: auto; }
    /* PequeÃƒÆ’Ã‚Â±o espacio al final para que el ÃƒÆ’Ã‚Âºltimo botÃƒÆ’Ã‚Â³n no quede pegado al borde */
    .nav__links.is-open::after { content: ""; display: block; height: 10px; }
    .nav__link { width: 100%; }
    /* Forzar colores claros en el menÃƒÆ’Ã‚Âº mÃƒÆ’Ã‚Â³vil (fondo oscuro) */
    .nav__links .nav__link { color: var(--color-white); }
    /* MenÃƒÆ’Ã‚Âº sÃƒÆ’Ã‚Â³lido en responsive: tipografÃƒÆ’Ã‚Â­a negra */
    .site-nav.is-solid .nav__links .nav__link { color: var(--color-black); }
    .nav__links .nav__link:hover,
    .nav__links .nav__link.is-active { color: var(--color-white); background: rgba(1,84,249,.08); }
    .site-nav.is-solid .nav__links .nav__link:hover,
    .site-nav.is-solid .nav__links .nav__link.is-active {
      color: var(--color-black);
      background: rgba(24,27,33,.06);
    }

    /* Ajustes del bloque Servicios en mÃƒÆ’Ã‚Â³viles */
    #servicios .section__header { margin-top: -2.25rem; }
  }

  @media (min-width: 640px) {
    .services__grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
    .features__grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
    .modal__grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
    .team__grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  }
@media (min-width: 980px) {
  .services__grid { grid-template-columns: repeat(5, minmax(0,1fr)); }
  .features__grid { grid-template-columns: repeat(4, minmax(0,1fr)); }
  .modal__grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .team__grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
}
@media (max-width: 900px) {
  .team-combo { grid-template-columns: 1fr; }
  .team-card .team-viewport { min-height: clamp(260px, 60vw, 360px); }
    /* Ocultar el subtÃƒÆ’Ã‚Â­tulo de Servicios sÃƒÆ’Ã‚Â³lo en responsive (mÃƒÆ’Ã‚Â³viles/tablet) */
  @media (max-width: 900px) {
  #servicios .section__header .section__subtitle { display: none !important; }
  }
}

/* Ventana: video full-width with natural aspect ratio, section height equals video */
#ventana { position: relative; overflow: hidden; }
#ventana .services-bg { position: relative; margin-left: 0; margin-right: 0; width: 100%; max-width: 100%; height: auto; }
#ventana .services-bg__video { width: 100%; height: auto; display: block; object-fit: contain; max-width: 100%; clip-path: none; -webkit-clip-path: none; }
/* Showcase full-height over the video */
#ventana #services-showcase { height: 100%; }
#ventana .services-visual { height: 100%; }
#ventana .services-visual__media { height: 100%; }
#ventana .services-dynamic { height: 100%; display: flex; flex-direction: column; }
#ventana .services-dynamic__grid { flex: 1 1 auto; }

/* Override mobile tweaks so #ventana video is never cropped */
@media (max-width: 1024px) {
  #ventana .services-bg { margin-left: 0; margin-right: 0; width: 100%; max-width: 100%; height: auto; }
  #ventana .services-bg__video { width: 100%; height: auto; object-fit: contain; object-position: center center; clip-path: none; -webkit-clip-path: none; }
  #ventana #services-showcase { height: 100%; }
  #ventana .services-visual, #ventana .services-visual__media { height: 100%; }
  #ventana .services-dynamic { height: auto; }
}

/* Servicios: colores de tÃƒÆ’Ã‚Â­tulo y subtÃƒÆ’Ã‚Â­tulo (ya definidos en .section--services overrides) */

/* Servicios: grilla 3 columnas (desktop), 2 (tablet), 1 (mÃƒÆ’Ã‚Â³vil) */
@media (min-width: 1025px) {
  .services-dynamic__grid {
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)) !important;
    gap: 1.4rem !important;
  }
}
@media (min-width: 640px) and (max-width: 1024px) {
  .services-dynamic__grid { grid-template-columns: repeat(2, minmax(0,1fr)) !important; gap: .9rem !important; }
}

/* MÃƒÆ’Ã‚Â¡s grandes y con mÃƒÆ’Ã‚Â¡s texto visible */
@media (min-width: 640px) and (max-width: 1024px) {
  .services-dynamic__grid { grid-auto-rows: auto !important; }
  .services-dynamic .service-item__desc { font-size: .88rem; }
}
@media (min-width: 1025px) {
  .services-dynamic { width: 100% !important; max-width: 880px !important; min-width: 0 !important; margin: 0 auto !important; }
  .services-dynamic__grid { grid-auto-rows: auto !important; }
  .services-dynamic .service-item__title { font-size: 1.12rem; }
  .services-dynamic .service-item__desc { font-size: .92rem; }
  .services-dynamic .service-item__body {
    padding: calc(1rem + var(--svctext-margin)) 1.1rem calc(1.1rem + var(--svctext-margin));
  }
  .services-dynamic .service-item__actions .btn--request { height: 32px !important; font-size: .88rem !important; }
}

/* ApariciÃƒÆ’Ã‚Â³n sutil con escalado y desplazamiento (stagger por fila de 3) */
@keyframes servicesCardIn { from { transform: translateY(6px) scale(.98); opacity: 0; } to { transform: none; opacity: 1; } }
.services-dynamic__grid .service-item { animation: servicesCardIn .42s cubic-bezier(.2,.8,.2,1) both; }
.services-dynamic__grid .service-item:nth-child(3n+1) { animation-delay: .02s; }
.services-dynamic__grid .service-item:nth-child(3n+2) { animation-delay: .10s; }
.services-dynamic__grid .service-item:nth-child(3n+3) { animation-delay: .18s; }
.services-mobile-deck .service-item { animation: servicesCardIn .42s cubic-bezier(.2,.8,.2,1) both; }
@media (prefers-reduced-motion: reduce) {
  .services-dynamic__grid .service-item { animation: none; }
}

/* ------------------------------ Propuesta de Valor: tipografÃƒÆ’Ã‚Â­a mÃƒÆ’Ã‚Â³vil ------------------------------ */
@media (max-width: 540px) {
  /* Permitir cortes de lÃƒÆ’Ã‚Â­nea en spans con .text-nowrap dentro de #propuesta */
  #propuesta .text-nowrap { white-space: normal !important; }

  /* TÃƒÆ’Ã‚Â­tulo grande: mÃƒÆ’Ã‚Â¡s compacto y con buen ajuste de lÃƒÆ’Ã‚Â­neas */
  #propuesta .display-1 {
    font-size: clamp(1.55rem, 7.2vw, 2rem);
    line-height: 1.18;
    letter-spacing: -0.012em;
    word-break: break-word;
    overflow-wrap: anywhere;
    text-wrap: balance; /* suaviza el salto entre lÃƒÆ’Ã‚Â­neas en navegadores modernos */
  }

  /* SubtÃƒÆ’Ã‚Â­tulo (lead) mÃƒÆ’Ã‚Â¡s legible en pantallas pequeÃƒÆ’Ã‚Â±as */
  #propuesta .lead {
    font-size: clamp(.95rem, 3.6vw, 1.05rem);
    line-height: 1.55;
  }

  /* Lista mÃƒÆ’Ã‚Â¡s compacta y sin desbordes */
  #propuesta .bullets { gap: .45rem; }
  #propuesta .bullets li { grid-template-columns: 18px 1fr; }
  #propuesta .bullets li::before { width: 10px; height: 10px; box-shadow: 0 0 0 2px rgba(1,84,249,.15); margin-top: .4rem; }
}
@media (max-width: 360px) {
  #propuesta .display-1 { font-size: clamp(1.4rem, 7vw, 1.7rem); }
}

/* Forzar 3 lÃƒÆ’Ã‚Â­neas exactas en el tÃƒÆ’Ã‚Â­tulo de Propuesta (mÃƒÆ’Ã‚Â³vil) */
@media (max-width: 540px) {
  #propuesta h2.display-1 {
    font-size: clamp(1.25rem, 5.2vw, 1.6rem); /* mÃƒÆ’Ã‚Â¡s pequeÃƒÆ’Ã‚Â±o para que quepa en 1 lÃƒÆ’Ã‚Â­nea cada renglÃƒÆ’Ã‚Â³n */
    line-height: 1.15;
  }
  /* Asegurar 1 lÃƒÆ’Ã‚Â­nea por cada span y conservar formato en mÃƒÆ’Ã‚Â³vil */
  #propuesta h2.display-1 .d-block { display: block; }
  #propuesta h2.display-1 .text-nowrap { white-space: nowrap !important; }
  #propuesta h2.display-1 .d-block + .d-block { margin-top: .05rem; }
}
@media (max-width: 360px) {
  #propuesta h2.display-1 { font-size: clamp(1.15rem, 5.6vw, 1.35rem); }
}
/* Services Desktop: horizontal snap scroller when there are many cards */
@media (min-width: 1025px) {
  .services-dynamic__grid.hsnap {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: clamp(280px, 31vw, 360px);
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: .75rem; /* ensure spacing between cards */
    padding-bottom: .25rem; /* space for thin scrollbar */
  }
  .services-dynamic__grid.hsnap .service-item {
    scroll-snap-align: start;
  }
  /* Position arrow controls for services carousel */
  .services-dynamic .slider__btn.services { top: 50%; transform: translateY(-50%); }
}
/* Services Desktop: force override conflicting grid-template with !important */
@media (min-width: 1025px) {
  .services-dynamic__grid.hsnap {
    grid-template-columns: none !important;
    grid-auto-flow: column !important;
    grid-auto-columns: clamp(300px, 28vw, 360px) !important;
    overflow-x: auto !important;
  }
}
/* Services Desktop: wider cards, full description */
@media (min-width: 1025px) {
  .services-dynamic__grid.hsnap {
    grid-auto-columns: clamp(380px, 34vw, 460px) !important;
    gap: .9rem !important;
  }
  /* Show full descriptions on desktop */
  .services-dynamic__grid.hsnap .service-item__desc {
    display: block !important;
    -webkit-line-clamp: unset !important;
    line-clamp: unset !important;
    -webkit-box-orient: unset !important;
    overflow: visible !important;
  }
}


/* === Services Icon Positions: Single Source of Truth (vw/vh) === */
/* Ajusta un ÃƒÂºnico bloque: cada viewport redefine solo sus variables dedicadas */

:root {
  /* Desktop 1600Ãƒâ€”900 (base) */
  --svc1-1600-top: 33vh;
  --svc1-1600-left: 10.9vw;
  --svc2-1600-top: 25vh;
  --svc2-1600-left: 19vw;
  --svc3-1600-top: 20vh;
  --svc3-1600-left: -8.8vw;
  --svc4-1600-top: 43vh;
  --svc4-1600-left: -1vw;
  --svc5-1600-top: 55vh;
  --svc5-1600-left: 10.9vw;
  --svc6-1600-top: 47vh;
  --svc6-1600-left: 19vw;

  /* Desktop ~1366Ãƒâ€”768 (ajusta estos valores para esa resoluciÃƒÂ³n) */
  --svc1-1366-top: 28vh;
  --svc1-1366-left: 14.5vw;
  --svc2-1366-top: 20vh;
  --svc2-1366-left: 22.5vw;
  --svc3-1366-top: 18vh;
  --svc3-1366-left: -5vw;
  --svc4-1366-top: 41vh;
  --svc4-1366-left: 3vw;
  --svc5-1366-top: 51vh;
  --svc5-1366-left: 15vw;
  --svc6-1366-top: 44vh;
  --svc6-1366-left: 23vw;

  /* Mobile/Tablet Ã¢â€°Â¤1024px */
  --svc1-mobile-top: 15vh;
  --svc1-mobile-left: 50vw;
  --svc2-mobile-top: 11vh;
  --svc2-mobile-left: 68.5vw;
  --svc3-mobile-top: 14vh;
  --svc3-mobile-left: 8vw;
  --svc4-mobile-top: 24vh;
  --svc4-mobile-left: 25vw;
  --svc5-mobile-top: 27vh;
  --svc5-mobile-left: 51vw;
  --svc6-mobile-top: 19vh;
  --svc6-mobile-left: 68.5vw;

  /* Mobile especÃ­fico 390x844 (iPhone 13/14/15 vertical) */
  --svc1-390x844-top: 15vh;
  --svc1-390x844-left: 50vw;
  --svc2-390x844-top: 11vh;
  --svc2-390x844-left: 68.5vw;
  --svc3-390x844-top: 14vh;
  --svc3-390x844-left: 8vw;
  --svc4-390x844-top: 24vh;
  --svc4-390x844-left: 25vw;
  --svc5-390x844-top: 27vh;
  --svc5-390x844-left: 51vw;
  --svc6-390x844-top: 24vh;
  --svc6-390x844-left: 68.5vw;

  /* Services section header offsets (mÃ³vil) */
  --svcheader-mobile-top: clamp(12px, 5vw, 28px);
  --svcheader-390x844-top: clamp(44px, 9vh, 80px);
  --svcheader-top: var(--svcheader-mobile-top);
  --svcheader-mobile-margin-left: auto;
  --svcheader-mobile-margin-right: auto;
  --svcheader-mobile-text-align: center;
  --svcheader-390x844-margin-left: clamp(1.75rem, 16vw, 4.5rem);
  --svcheader-390x844-margin-right: auto;
  --svcheader-390x844-text-align: left;
  --svcheader-margin-left: var(--svcheader-mobile-margin-left);
  --svcheader-margin-right: var(--svcheader-mobile-margin-right);
  --svcheader-text-align: var(--svcheader-mobile-text-align);
  --svcoverlay-mobile-padding-top: clamp(0.4rem, 2.5vw, 0.9rem);
  --svcoverlay-390x844-padding-top: clamp(0.5rem, 3vw, 1.1rem);
  --svcoverlay-padding-top: var(--svcoverlay-mobile-padding-top);
  --svcheader-desktop-left: 0;
  --svcheader-desktop-right: auto;
  --svcheader-desktop-transform: none;
  --svcheader-desktop-width: max-content;
  --svcheader-desktop-text-align: left;
  --svcheader-desktop-top: clamp(2.5rem, 6vw, 5rem);
  --svcheader-desktop-clearance: calc(var(--svcheader-desktop-top) + clamp(2rem, 3vw, 3.25rem));
  --svcgrid-desktop-top: clamp(4.5rem, 10vw, 7.5rem);
  --svcgrid-desktop-left: clamp(24rem, 32vw, 38rem);
  --svcgrid-desktop-right: auto;
  --svcgrid-desktop-width: clamp(22rem, 36vw, 30rem);
  --svcgrid-desktop-transform: none;
  --svcbelt-desktop-top: clamp(20rem, 28vw, 25rem);
  --svcbelt-desktop-left: clamp(12rem, 20vw, 24rem);
  --svcbelt-desktop-right: auto;
  --svcbelt-desktop-transform: none;
  --svcbelt-desktop-width: max-content;
  --svcbelt-desktop-text-align: left;
  --svcdyn-area-height: clamp(34rem, 48vw, 42rem);

  /* Services cards container offsets (desktop 1600Ãƒâ€”900 base)
     -> Ajusta estos valores para subir/bajar el panel y el texto en 1600Ãƒâ€”900 */
  --svcdyn-1600-top: 50%;
  --svcdyn-1600-right: clamp(-140px, -4vw, 0px);
  --svcdyn-1600-translate: -50%;
  --svctext-1600-margin: -0.2rem; /* opcional: valor negativo acerca mÃƒÂ¡s el texto al borde superior */

  /* Services cards container offsets (~1366Ãƒâ€”768)
     -> Usa estos para ajustar cards y texto cuando el viewport cae en 1366Ãƒâ€”768 */
  --svcdyn-1366-top: clamp(2.4cm, calc(11vw + 0.8cm), calc(150px + 0.8cm));
  --svcdyn-1366-right: clamp(-10px, 0.8vw, 16px);
  --svcdyn-1366-translate: 0;
  --svctext-1366-margin: 0.3rem;

  /* Services cards container offsets (mobile Ã¢â€°Â¤1024px)
     -> Modifica estos si necesitas mover cards/texto en pantallas pequeÃƒÂ±as */
  --svcdyn-mobile-top: auto;
  --svcdyn-mobile-right: 0;
  --svcdyn-mobile-translate: 0;
  --svctext-mobile-margin: 1rem;

  /* Active values (default 1600Ãƒâ€”900) */
  --svcdyn-top: var(--svcdyn-1600-top);
  --svcdyn-right: var(--svcdyn-1600-right);
  --svcdyn-translate: var(--svcdyn-1600-translate);
  --svctext-margin: var(--svctext-1600-margin);

  /* Variables activas (por defecto usan 1600Ãƒâ€”900) */
  --svc1-top: var(--svc1-1600-top);
  --svc1-left: var(--svc1-1600-left);
  --svc2-top: var(--svc2-1600-top);
  --svc2-left: var(--svc2-1600-left);
  --svc3-top: var(--svc3-1600-top);
  --svc3-left: var(--svc3-1600-left);
  --svc4-top: var(--svc4-1600-top);
  --svc4-left: var(--svc4-1600-left);
  --svc5-top: var(--svc5-1600-top);
  --svc5-left: var(--svc5-1600-left);
  --svc6-top: var(--svc6-1600-top);
  --svc6-left: var(--svc6-1600-left);
}

/* AplicaciÃƒÂ³n: todas las vistas consumen las variables activas */
.service-icon.pos-1 { top: var(--svc1-top) !important; left: var(--svc1-left) !important; right: auto !important; bottom: auto !important; }
.service-icon.pos-2 { top: var(--svc2-top) !important; left: var(--svc2-left) !important; right: auto !important; bottom: auto !important; }
.service-icon.pos-3 { top: var(--svc3-top) !important; left: var(--svc3-left) !important; right: auto !important; bottom: auto !important; }
.service-icon.pos-4 { top: var(--svc4-top) !important; left: var(--svc4-left) !important; right: auto !important; bottom: auto !important; }
.service-icon.pos-5 { top: var(--svc5-top) !important; left: var(--svc5-left) !important; right: auto !important; bottom: auto !important; }
.service-icon.pos-6 { top: var(--svc6-top) !important; left: var(--svc6-left) !important; right: auto !important; bottom: auto !important; }

/* <=1024px: activa el set mÃƒÂ³vil/tablet */
  @media (max-width: 1024px) {
    :root {
      --svc1-top: var(--svc1-mobile-top);
      --svc1-left: var(--svc1-mobile-left);
      --svc2-top: var(--svc2-mobile-top);
      --svc2-left: var(--svc2-mobile-left);
      --svc3-top: var(--svc3-mobile-top);
      --svc3-left: var(--svc3-mobile-left);
      --svc4-top: var(--svc4-mobile-top);
      --svc4-left: var(--svc4-mobile-left);
      --svc5-top: var(--svc5-mobile-top);
      --svc5-left: var(--svc5-mobile-left);
      --svc6-top: var(--svc6-mobile-top);
      --svc6-left: var(--svc6-mobile-left);
      --svctext-margin: var(--svctext-mobile-margin);
    }
  }

  @media screen and (min-width: 380px) and (max-width: 400px)
         and (min-height: 830px) and (max-height: 860px)
         and (orientation: portrait) {
    :root {
      --svc1-top: var(--svc1-390x844-top);
      --svc1-left: var(--svc1-390x844-left);
      --svc2-top: var(--svc2-390x844-top);
      --svc2-left: var(--svc2-390x844-left);
      --svc3-top: var(--svc3-390x844-top);
      --svc3-left: var(--svc3-390x844-left);
      --svc4-top: var(--svc4-390x844-top);
      --svc4-left: var(--svc4-390x844-left);
      --svc5-top: var(--svc5-390x844-top);
      --svc5-left: var(--svc5-390x844-left);
      --svc6-top: var(--svc6-390x844-top);
      --svc6-left: var(--svc6-390x844-left);
      --svcheader-top: var(--svcheader-390x844-top);
      --svcheader-margin-left: var(--svcheader-390x844-margin-left);
      --svcheader-margin-right: var(--svcheader-390x844-margin-right);
      --svcheader-text-align: var(--svcheader-390x844-text-align);
      --svcoverlay-padding-top: var(--svcoverlay-390x844-padding-top);
    }
  }

  /* Eliminamos overrides genÃ©ricos â‰¤540 y â‰¤400 para respetar sets especÃ­ficos */


  /* ~1366Ã—768: rango tolerante + landscape para cubrir viewport con barras */
  @media screen and (min-width: 1280px) and (max-width: 1420px)
         and (orientation: landscape) {
    :root {
      --svc1-top: var(--svc1-1366-top);
      --svc1-left: var(--svc1-1366-left);
      --svc2-top: var(--svc2-1366-top);
      --svc2-left: var(--svc2-1366-left);
      --svc3-top: var(--svc3-1366-top);
      --svc3-left: var(--svc3-1366-left);
      --svc4-top: var(--svc4-1366-top);
      --svc4-left: var(--svc4-1366-left);
      --svc5-top: var(--svc5-1366-top);
      --svc5-left: var(--svc5-1366-left);
      --svc6-top: var(--svc6-1366-top);
      --svc6-left: var(--svc6-1366-left);
      --svctext-margin: var(--svctext-1366-margin);
      --svcheader-desktop-left: clamp(2.5rem, 9vw, 5rem);
      --svcheader-desktop-right: auto;
      --svcgrid-desktop-top: clamp(-4rem, 4vw, 4rem);
      --svcgrid-desktop-left: clamp(26rem, 36vw, 40rem);
      --svcbelt-desktop-top: clamp(16rem, 24vw, 22rem);
      --svcbelt-desktop-left: clamp(-20rem, 2vw, 6rem);
    }
    .headline-belt__title {
      margin-top: 3.8rem !important; /* bajar mucho mÃ¡s en 1366x768 */
      margin-left: 1.5cm !important;
    }
    #login-modal .auth-alert {
      font-size: .65rem;
      padding: .2rem .4rem;
      gap: .3rem;
      border-radius: 12px;
    }
    #login-modal .auth-alert::before {
      font-size: .68rem;
    }
    #login-modal.modal--auth {
      padding-top: calc(var(--nav-h, 84px) - 20px);
      padding-bottom: 10px;
    }
    #login-modal.modal--auth .modal__dialog {
      width: min(94%, 380px);
    }
    #login-modal.modal--auth .auth-modal__left {
      min-height: 84px;
      padding: .5rem .7rem;
    }
    #login-modal.modal--auth .auth-modal__right {
      padding: .25rem .8rem .7rem;
      border-radius: 14px;
    }
    #login-modal.modal--auth .modal__content {
      padding: 0 .75rem .5rem;
      max-height: none;
      overflow: visible;
    }
    #login-modal.modal--auth .auth-modal {
      grid-template-rows: auto 1fr;
      gap: .3rem;
    }
    #login-modal .auth-pane {
      max-height: none;
    }
    #asesoria-modal.modal--auth {
      padding-top: calc(var(--nav-h, 84px) - 56px);
      padding-bottom: 8px;
    }
    #asesoria-modal.modal--auth .modal__dialog {
      width: min(92%, 320px);
      max-height: none;
    }
    #asesoria-modal.modal--auth .auth-modal__left {
      min-height: 78px;
      padding: .4rem .6rem;
    }
    #asesoria-modal.modal--auth .auth-modal__right {
      padding: .2rem .65rem .55rem;
      border-radius: 12px;
    }
    #asesoria-modal.modal--auth .modal__content {
      padding: 0 .6rem .4rem;
      max-height: none;
      overflow: visible;
    }
    #asesoria-modal.modal--auth .auth-modal {
      grid-template-rows: auto 1fr;
      gap: .2rem;
    }
    #asesoria-modal.modal--auth .auth-pane {
      max-height: none;
    }
    #asesoria-modal.modal--auth .auth-field {
      margin-bottom: .55rem;
    }
    #asesoria-modal.modal--auth .auth-pane input,
    #asesoria-modal.modal--auth .auth-pane textarea {
      padding: .7rem .85rem;
      border-radius: 10px;
    }
    #asesoria-modal.modal--auth .auth-pane textarea {
      min-height: 72px;
    }
    #asesoria-modal.modal--auth .auth-left__subtitle {
      font-size: .9rem;
      margin: .4rem 0 0;
    }
    #asesoria-modal.modal--auth .auth-btn--block {
      height: 36px;
      font-size: .92rem;
    }
  }
/* 1600Ã—900-ish override: widen range and drop strict height, placed at EOF to win cascade */
@media screen and (min-width: 1500px) and (max-width: 1700px)
       and (orientation: landscape) {
  :root {
    --svcbelt-desktop-left: clamp(0rem, 6rem, 10rem);
  }
}





