/* =========================
   Capital Humano - CSS (v7 Enhanced)
   - Mejoras estéticas manteniendo estructura
   - Spacing optimizado con clamp()
   - Microinteracciones premium
   - Fondo más sutil y elegante
========================= */
:root{
  /* Paleta */
  --accent:  #003DA5;
  --accent2: #182389;
  --accent3: #1B72FF;

  /* ÚNICO TEMA (BLANCO) */
  --bg0: #F8FBFF;
  --bg1: #F0F6FF;
  --bg2: #E8F1FF;

  --surface: rgba(255,255,255,.78);
  --surface2: rgba(255,255,255,.94);
  --stroke: rgba(14,22,44,.14);

  --text: rgba(10,16,32,.96);
  --muted: rgba(10,16,32,.68);
  --muted2: rgba(10,16,32,.54);

  --shadow-lg: 0 32px 84px rgba(10,16,32,.18);
  --shadow-md: 0 20px 54px rgba(10,16,32,.15);
  --shadow-sm: 0 12px 32px rgba(10,16,32,.12);

  /* Radius / layout / typo (lo dejas igual que ya lo tienes) */
  --r-sm: 14px;
  --r-md: 20px;
  --r-lg: 28px;
  --r-xl: 38px;

  --container: 1240px;
  --header-h: clamp(68px, 6.4vw, 82px);
  --gutter: clamp(20px, 3.4vw, 32px);
  --section-y: clamp(88px, 9.2vw, 152px);

  --fs-hero: clamp(46px, 6.8vw, 94px);
  --fs-h2: clamp(32px, 4.6vw, 64px);
  --fs-h3: clamp(19px, 1.9vw, 24px);
  --fs-body: clamp(15px, 1.25vw, 17px);
  --fs-small: clamp(13px, 1.1vw, 14px);

  --ease: cubic-bezier(.23,.89,.32,1);
  --ease-out: cubic-bezier(.2,.85,.2,1);

  color-scheme: light;
  --font-body: Inter, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
--font-sub: "IBM Plex Sans", Inter, system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
--font-display: "Space Grotesk", Inter, system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
}



/* Base optimizada */
*{ box-sizing: border-box; }
html, body{ height: 100%; }
html{ scroll-behavior: smooth; scroll-padding-top: calc(var(--header-h) + 20px); }

/* Prevent overflow and improve text wrapping across devices */
img, picture, video, svg{ max-width: 100%; height: auto; display: block; }
a{
  color: inherit;
  text-decoration: none;
}
html, body, p, li, span, a, button, input, textarea{ -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; word-break: break-word; overflow-wrap: break-word; hyphens: auto; }
.hero-title .grad{
  hyphens: none;
  word-break: keep-all;
  overflow-wrap: normal;
}
.container{ word-break: break-word; }

/* Utility to avoid overflowing flex items */
.no-overflow, .glass-card, .media-card, .contact-card{ min-width: 0; }


body{
  margin: 0;
  font-family: var(--font-sub);
  color: var(--text);
  font-size: var(--fs-body);
  line-height: 1.7;
  
  /* Fondo mejorado - más sutil y elegante */
  background:
    radial-gradient(900px 620px at 15% 7%,
      color-mix(in oklab, var(--accent) 10%, transparent) 0%,
      transparent 70%
    ),
    radial-gradient(880px 600px at 85% 5%,
      color-mix(in oklab, var(--accent3) 8%, transparent) 0%,
      transparent 70%
    ),
    linear-gradient(180deg, var(--bg0) 0%, var(--bg1) 35%, var(--bg2) 100%);
  
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  padding-top: var(--header-h);
  
}

/* Mejoras de tipografía */
h1, h2, h3, h4 { font-weight: 800; line-height: 1.1; margin-top: 0; }
h1 { letter-spacing: -0.04em; }
h2 { letter-spacing: -0.03em; }
h3 { letter-spacing: -0.02em; }

p { margin-top: 0; margin-bottom: 1.5em; }

/* Auras animadas - mucho más sutiles */
body::before, body::after{
  content: "";
  position: fixed;
  inset: -20vh -20vw;
  pointer-events: none;
  z-index: -2;
  opacity: .16;
  filter: blur(52px);
  will-change: transform;
  mix-blend-mode: screen;
}

body::before{
  background:
    radial-gradient(680px 480px at 18% 15%,
      color-mix(in oklab, var(--accent) 9%, transparent) 0%,
      transparent 70%
    ),
    radial-gradient(720px 500px at 82% 14%,
      color-mix(in oklab, var(--accent2) 8%, transparent) 0%,
      transparent 70%
    );
  animation: floatA 24s var(--ease) infinite alternate;
}

body::after{
  background:
    radial-gradient(780px 580px at 72% 85%,
      color-mix(in oklab, var(--accent3) 7%, transparent) 0%,
      transparent 70%
    );
  animation: floatB 28s var(--ease) infinite alternate;
  opacity: .12;
}

@keyframes floatA { 
  0% { transform: translate3d(-0.8%, -0.8%, 0) scale(1); } 
  100% { transform: translate3d(0.8%, 0.8%, 0) scale(1.03); } 
}

@keyframes floatB { 
  0% { transform: translate3d(0.6%, 0.6%, 0) scale(1.02); } 
  100% { transform: translate3d(-0.6%, -0.6%, 0) scale(1.04); } 
}

/* Reduce motion support */
@media (prefers-reduced-motion: reduce){
  html { scroll-behavior: auto; }
  body::before, body::after, 
  .icon-float, .tilt-card,
  .floating-square, .stat-badge { 
    animation: none !important; 
  }
  * { 
    transition-duration: 0.01ms !important; 
    animation-duration: 0.01ms !important; 
  }
}

/* Containers optimizados */
.container{
  width: min(var(--container), calc(100% - (var(--gutter) * 2)));
  margin: 0 auto;
}

/* Mejoras de accesibilidad */
.sr-only{
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.skip-link{
  position: absolute;
  left: -999px;
  top: 12px;
  background: var(--accent);
  color: white;
  padding: 12px 16px;
  border-radius: 12px;
  font-weight: 700;
  text-decoration: none;
  z-index: 9999;
  transition: left 0.2s var(--ease);
}

.skip-link:focus{
  left: 12px;
  outline: 3px solid var(--accent);
  outline-offset: 2px;
}

/* Estados focus mejorados */
:focus-visible{
  outline: none;
  box-shadow: 
    0 0 0 4px color-mix(in oklab, var(--accent) 25%, transparent),
    0 0 0 1px color-mix(in oklab, var(--accent) 60%, transparent);
}

/* Offset para header fijo */
section[id], main[id]{
  scroll-margin-top: calc(var(--header-h) + 24px);
}

/* =========================
   REVEAL ANIMATIONS (alineado a referencia: más sutil, sin blur)
========================= */
.reveal{
  opacity: 0;
  filter: none;
  transform: translateY(14px);
  transition:
    opacity 700ms ease,
    transform 700ms ease;
  transition-delay: var(--d, 0ms);
  will-change: opacity, transform;
}

.reveal.is-in{
  opacity: 1;
  transform: translateY(0);
}


/* =========================
   HEADER / NAVBAR (optimizado)
========================= */
.site-header{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  background: color-mix(in oklab, var(--bg1) 88%, transparent);
  border-bottom: 1px solid var(--stroke);
  transition: all 0.3s var(--ease);
}

.site-header.is-scrolled{
  background: color-mix(in oklab, var(--bg1) 96%, transparent);
  box-shadow: 0 12px 32px rgba(0,0,0,.2);
  border-bottom-color: color-mix(in oklab, var(--stroke) 70%, transparent);
}

.nav-shell{
  height: var(--header-h);
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 0 var(--gutter);
  width: min(1400px, calc(100% - 20px));
  margin: 0 auto;
}

/* Ensure brand / center / actions layout keeps center nav visually centered
   and actions stay to the right without overlapping on desktop/tablet */
.nav-shell{ justify-content: space-between; }
.nav-actions{ margin-left: 16px; display: flex; align-items: center; gap: 12px; }

.brand{
  display: flex;
  align-items: center;
  min-width: 160px;
  flex-shrink: 0;
}

.brand__logo{
  height: clamp(26px, 2.8vw, 34px);
  width: auto;
  filter: drop-shadow(0 12px 24px rgba(0,0,0,.22));
  transition: transform 0.3s var(--ease);
}

.brand:hover .brand__logo{
  transform: scale(1.05);
}

.nav-center{
  flex: 1 1 auto;
  display: none;
  justify-content: center;
  gap: clamp(12px, 1.8vw, 26px);
  min-width: 0;
  align-items: center;
  flex-wrap: nowrap; /* prefer single line on larger viewports */
}

/* Better nav wrapping & spacing for wide and medium screens */
.nav-center{
  flex-wrap: wrap;
  align-items: center;
  gap: clamp(10px, 2vw, 22px);
}

.nav-link,
.nav-link:hover,
.nav-link:focus,
.nav-link.is-active {
text-decoration: none !important;
border-bottom: none !important;
background-image: none !important;
}

.nav-link::before,
.nav-link::after,
.nav-link:hover::before,
.nav-link:hover::after,
.nav-link:focus::before,
.nav-link:focus::after,
.nav-link.is-active::before,
.nav-link.is-active::after {
content: none !important;
display: none !important;
opacity: 0 !important;
height: 0 !important;
background: none !important;
}
.nav-link{
  display: inline-block;
  white-space: normal;
overflow: visible;
text-overflow: clip;
max-width: none;
}

/* On small devices allow nav text to wrap and give spacing */
@media (max-width: 980px){
  .nav-center{ display: none; justify-content: flex-start; gap: 10px; }
  .nav-link{ white-space: normal; max-width: 160px; padding: 10px 12px; }
}

.nav-link{
  font-size: clamp(14px, 1.1vw, 15px);
  font-weight: 650;
  color: color-mix(in oklab, var(--text) 86%, transparent);
  padding: 12px 18px;
  border-radius: 999px;
  transition: all 0.25s var(--ease);
  white-space: nowrap;
  position: relative;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 260px; /* allow longer labels on desktop/tablet */
}
/* Desktop: SOLO 'Procesamiento de nomina' sin ellipsis */
.nav-center .nav-link[data-i18n-text="nav.capital"]{
  max-width: none;
  white-space: normal;     /* permite saltar de línea */
  overflow: visible;       /* evita recorte */
  text-overflow: clip;     /* quita ... */
  line-height: 1.15;
  hyphens: none;
}
.nav-link::after{
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  transition: all 0.3s var(--ease);
  transform: translateX(-50%);
}

.nav-link:hover{
  background: color-mix(in oklab, var(--surface2) 84%, transparent);
  transform: translateY(-2px);
  color: var(--text);
}

.nav-link:hover::after{
  width: 60%;
}

.nav-link.is-active{
  background: color-mix(in oklab, var(--surface2) 96%, transparent);
  border: 1px solid color-mix(in oklab, var(--stroke) 88%, transparent);
  color: var(--text);
  box-shadow: 0 8px 24px rgba(0,0,0,.12);
}

.nav-link.is-active::after{
  width: 80%;
  height: 3px;
}

.nav-actions{
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}

/* =========================
   NAVBAR - Strict overrides requested by user
   1) Remove any decorative underline/line under nav links in all states
   2) Ensure hover/active highlight area covers the whole link using inline-flex
   3) Hide desktop nav links on mobile and show only the burger
   Note: only layout/visibility adjustments, no visual style/color changes.
========================= */

/* 1) Remove underline/decorative line coming from ::after or borders */
.nav-link::after,
.nav-link:hover::after,
.nav-link.is-active::after{
  display: none !important;
  background: transparent !important;
  border: 0 !important;
  width: 0 !important;
  height: 0 !important;
}

/* 2) Ensure the interactive/highlight area fully contains the link text without changing visual styles */
.nav-center .nav-link{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-sizing: border-box !important;
  white-space: nowrap !important;
}

.nav-link{
  /* keep existing padding but ensure clickable area is consistent */
  -webkit-tap-highlight-color: transparent;
}

.nav-link:focus-visible{
  outline: none;
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--accent) 18%, transparent);
}

/* 3) Mobile: hide desktop nav links, show only burger (menu) */
@media (max-width: 980px){
  .nav-center{ display: none !important; }
  }


.pill-cta{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 20px;
  border-radius: 999px;
  font-weight: 800;
  font-size: clamp(13.5px, 1.1vw, 15px);
  color: white;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  box-shadow: 
    0 16px 40px color-mix(in oklab, var(--accent) 20%, transparent),
    0 0 0 1px color-mix(in oklab, var(--accent) 30%, transparent);
  border: none;
  transition: all 0.25s var(--ease);
  position: relative;
  overflow: hidden;
  white-space: nowrap;
}

.pill-cta::before{
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.2), transparent);
  transition: left 0.6s var(--ease);
}

.pill-cta:hover{
  transform: translateY(-3px);
  box-shadow: 
    0 20px 48px color-mix(in oklab, var(--accent) 24%, transparent),
    0 0 0 1px color-mix(in oklab, var(--accent) 40%, transparent);
}

.pill-cta:hover::before{
  left: 100%;
}

.pill-cta.w-full{
  width: 100%;
}

/* Icon buttons con mejor feedback */
.icon-btn{
  height: 44px;
  width: 44px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  border: 1px solid var(--stroke);
  background: color-mix(in oklab, var(--surface2) 76%, transparent);
  color: var(--text);
  cursor: pointer;
  transition: all 0.25s var(--ease);
  position: relative;
  overflow: hidden;
}

.icon-btn::after{
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(255,255,255,.1), transparent);
  opacity: 0;
  transition: opacity 0.3s var(--ease);
}

.icon-btn:hover{
  transform: translateY(-2px) scale(1.05);
  background: color-mix(in oklab, var(--surface2) 92%, transparent);
  border-color: color-mix(in oklab, var(--accent) 40%, var(--stroke));
  box-shadow: 0 8px 24px rgba(0,0,0,.15);
}

.icon-btn:hover::after{
  opacity: 1;
}

.icon{
  display: grid;
  place-items: center;
  position: relative;
  z-index: 1;
}

.icon svg{
  width: 22px;
  height: 22px;
  transition: transform 0.3s var(--ease);
}

.icon-btn:hover .icon svg{
  transform: rotate(12deg);
}

.i-sun{ display: none; }

/* Language button */
.lang-btn{
  height: 44px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid var(--stroke);
  background: color-mix(in oklab, var(--surface2) 76%, transparent);
  color: var(--text);
  cursor: pointer;
  transition: all 0.25s var(--ease);
}

.lang-btn:hover{
  transform: translateY(-2px);
  background: color-mix(in oklab, var(--surface2) 92%, transparent);
  border-color: color-mix(in oklab, var(--accent) 40%, var(--stroke));
}

.lang{
  font-weight: 800;
  font-size: 15px;
  letter-spacing: .02em;
}

.chev{
  width: 18px;
  height: 18px;
  opacity: .9;
  transition: transform 0.3s var(--ease);
}

.lang-btn:hover .chev{
  transform: translateY(2px);
}

/* Burger menu — igual referencia (acerca/stylebeca) */
.icon-btn.burger{
  width: 46px;
  height: 44px;
  border-radius: 14px;

  background: rgba(27,114,255,.10);
  border: 1px solid rgba(27,114,255,.22);
  box-shadow: 0 12px 26px rgba(19,33,68,.10);

  display: grid; /* visible PC/móvil */
  place-items: center;
  cursor: pointer;

  position: relative;
  overflow: hidden;

  transition: transform .18s var(--ease), box-shadow .18s var(--ease), border-color .18s var(--ease), background .18s var(--ease);
}

/* Apaga el ícono FA (para que NO interfiera con grosor) */
.icon-btn.burger i{
  opacity: 0 !important;
  font-size: 0 !important;
  width: 0 !important;
  height: 0 !important;
}

/* Tres barras dibujadas (grosor controlado) */
.icon-btn.burger::before{
  content:"";
  position:absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 18px;
  height: 2.5px;
  border-radius: 999px;
  background: rgba(11,22,51,.92);
  box-shadow:
    0 -6px 0 rgba(11,22,51,.92),
    0  6px 0 rgba(11,22,51,.92);
}

.icon-btn.burger:hover{
  transform: translateY(-1px);
  background: rgba(27,114,255,.14);
  border-color: rgba(27,114,255,.30);
  box-shadow:
    0 18px 40px rgba(19,33,68,.12),
    0 0 0 4px rgba(27,114,255,.10);
}

.icon-btn.burger:active{
  transform: translateY(0);
  box-shadow:
    0 12px 26px rgba(19,33,68,.10),
    0 0 0 3px rgba(27,114,255,.10);
}

/* =========================================================
   PUENTE DE HOVER PARA HAMBURGUESA (PC)
   - Evita que se cierre al mover el mouse del botón al drawer
========================================================= */
@media (hover: hover) and (pointer: fine){
  .site-header .icon-btn.site-header .icon-btn.burger::after{
    content: "";
    position: absolute;
    top: -14px;
    bottom: -14px;
    right: -36px;
    width: 52px;
    background: transparent;
    pointer-events: auto;
  }
}

/* Drawer mejorado */

.nav-drawer{
  position: fixed;
  inset: 0;
  z-index: 1200;
}

.drawer-backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.6);
  border: 0;
  cursor: pointer;
  animation: fadeIn 0.3s var(--ease) forwards;
}

@keyframes fadeIn{
  from{ opacity: 0; }
  to{ opacity: 1; }
}

html[data-theme="light"] .drawer-backdrop{
  background: rgba(10,16,32,.4);
}


/* Submenú (Inicio ▸) — comportamiento/animación como referencia */
.drawer-summary-link{ text-decoration: none !important; }
.drawer-arrow{
  transition: transform .18s var(--ease);
}
.drawer-submenu{
  margin: 6px 0 10px 0;
  padding: 0 0 0 14px;
  border-left: 1px solid var(--stroke);
}
.drawer-sublink{
  display:block;
  padding: 10px 10px;
  border-radius: 12px;
  font-weight: 800;
  font-size: 14px;
  color: var(--text);
  opacity: .9;
  transition: background .15s var(--ease), opacity .15s var(--ease), transform .15s var(--ease);
  text-decoration:none;
}
.drawer-sublink:hover,
.drawer-sublink:focus-visible{
  background: color-mix(in oklab, var(--accent) 10%, transparent);
  opacity: 1;
  transform: translateY(-1px);
  outline:none;
}

@media (hover: hover) and (pointer: fine){
  .drawer-details:not([open]) > .drawer-submenu{ display:none; }
  .drawer-details:hover > .drawer-submenu{ display:block; }
  .drawer-details:hover > summary .drawer-arrow{ transform: rotate(90deg); }
}
.drawer-panel{
  position: absolute;
  right: max(16px, env(safe-area-inset-right));
  top: calc(var(--header-h) + 10px);
 top: calc(var(--header-h) + 4px);              /* más arriba */
width: min(520px, calc(100% - 28px));          /* más largo (más ancho) */
  background: color-mix(in oklab, var(--bg1) 96%, transparent);
  border: 1px solid var(--stroke);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(24px) saturate(180%);
  -webkit-backdrop-filter: blur(24px) saturate(180%);
  padding: 24px;
  transform-origin: top right;
  animation: slideIn 0.3s var(--ease) both;
}

@keyframes slideIn{
  from{ 
    opacity: 0; 
    transform: translateY(-16px) scale(0.98); 
  }
  to{ 
    opacity: 1; 
    transform: translateY(0) scale(1); 
  }
}

.drawer-top{
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--stroke);
}

.drawer-title{
  font-weight: 900;
  letter-spacing: .02em;
  font-size: 18px;
}
.drawer-logo{
  height: 50px;
  width: auto;
  display: block;
  filter: drop-shadow(0 10px 20px rgba(0,0,0,.10));
}
.drawer-links{
  display: grid;
  gap: 10px;
  margin: 16px 0 24px;
}

.drawer-link{
  padding: 18px 20px;
  border-radius: 18px;
  color: var(--text);
  background: color-mix(in oklab, var(--surface2) 76%, transparent);
  border: 1px solid color-mix(in oklab, var(--stroke) 84%, transparent);
  font-weight: 750;
  transition: all 0.25s var(--ease);
}

.drawer-link:hover{
  background: color-mix(in oklab, var(--surface2) 92%, transparent);
  transform: translateX(4px);
  border-color: color-mix(in oklab, var(--accent) 40%, var(--stroke));
}

.drawer-link.is-active{
  background: color-mix(in oklab, var(--surface2) 98%, transparent);
  border-color: color-mix(in oklab, var(--accent) 30%, var(--stroke));
  box-shadow: 0 8px 24px rgba(0,0,0,.15);
}

.drawer-actions{
  display: grid;
  gap: 14px;
}

/* =========================
   SECTIONS - Separación mejorada
========================= */
.section{
  padding: var(--section-y) 0;
  position: relative;
}

/* Improve headings/titles readability: avoid hyphenation and keep inside boxes */
.hero-title,
.section-title,
.big-title{
  font-family: var(--font-display);
  letter-spacing: -0.091em; /* interletrado -91 (equivalente en em) */
}

/* Services lists: keep items together, avoid dashed word breaks */
.card-link, .benefit h3, .mail, .contact-direct{
  hyphens: none;
  word-break: break-word;
  overflow-wrap: anywhere;
}

/* Ensure service sections and contact card don't overflow their rounded containers */
.section:not(.hero) > .container{
  overflow: hidden;
}

.contact-card{
  overflow: hidden;
  word-break: break-word;
}

/* If titles repeat ("Contáctanos Contáctanos") force single-line visual; collapse duplicate whitespace */
.contact-card .contact-top, .contact-top{ white-space: normal; }


/* Separadores visuales entre secciones */
.section:not(.hero) > .container{
  position: relative;
  padding: clamp(24px, 3.4vw, 42px);
  border-radius: var(--r-xl);
  background: color-mix(in oklab, var(--surface2) 60%, transparent);
  border: 1px solid color-mix(in oklab, var(--stroke) 94%, transparent);
  box-shadow: var(--shadow-sm);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  isolation: isolate;
}

/* Líneas decorativas sutiles */
.section:not(.hero) > .container::before,
.section:not(.hero) > .container::after{
  content: "";
  position: absolute;
  left: clamp(18px, 2.4vw, 28px);
  right: clamp(18px, 2.4vw, 28px);
  height: 1px;
  pointer-events: none;
  opacity: .24;
  background: linear-gradient(90deg,
    transparent,
    color-mix(in oklab, var(--stroke) 92%, transparent),
    transparent
  );
  z-index: 1;
}

.section:not(.hero) > .container::before{
  top: 14px;
}

.section:not(.hero) > .container::after{
  bottom: 14px;
  opacity: .18;
}

/* Curva en sección específica */
.section-curve > .container{
  border-radius: var(--r-xl) var(--r-xl) var(--r-xl) 0;
}

/* Hero section optimizada */
.hero{
  padding-top: clamp(42px, 5.2vw, 86px);
  padding-bottom: var(--section-y);
}

.hero-grid{
  display: grid;
  grid-template-columns: 1.08fr .92fr;
  align-items: center;
  gap: clamp(28px, 5vw, 84px);
}

.back-btn{
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 14px 22px;
  border-radius: 18px;
  border: 1px solid var(--stroke);
  background: color-mix(in oklab, var(--surface2) 74%, transparent);
  color: var(--text);
  width: fit-content;
  box-shadow: var(--shadow-sm);
  transition: all 0.25s var(--ease);
  font-weight: 650;
}

.back-btn:hover{
  transform: translateY(-3px);
  background: color-mix(in oklab, var(--surface2) 90%, transparent);
  border-color: color-mix(in oklab, var(--accent) 40%, var(--stroke));
  box-shadow: var(--shadow-md);
}

.back-btn svg{
  width: 20px;
  height: 20px;
  transition: transform 0.3s var(--ease);
}

.back-btn:hover svg{
  transform: translateX(-4px);
}

/* Badge con animación */
.badge{
  margin-top: clamp(20px, 3vw, 36px);
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 12px 18px;
  border-radius: 999px;
  background: color-mix(in oklab, var(--surface2) 64%, transparent);
  border: 1px solid var(--stroke);
  color: color-mix(in oklab, var(--text) 92%, transparent);
  font-weight: 850;
  font-size: var(--fs-small);
  width: fit-content;
  transition: all 0.3s var(--ease);
}

.badge:hover{
  transform: translateY(-2px);
  background: color-mix(in oklab, var(--surface2) 80%, transparent);
  box-shadow: var(--shadow-sm);
}

.badge__icon{
  width: 38px;
  height: 38px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: color-mix(in oklab, var(--surface2) 76%, transparent);
  border: 1px solid var(--stroke);
  transition: all 0.3s var(--ease);
}

.badge:hover .badge__icon{
  transform: rotate(15deg);
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  border-color: transparent;
}

.badge:hover .badge__icon svg{
  color: white;
}

.badge__icon svg{
  width: 20px;
  height: 20px;
  opacity: .95;
  transition: all 0.3s var(--ease);
}

/* Hero title y gradiente */
.hero-title{
  margin: clamp(22px, 3.2vw, 30px) 0 16px;
  font-size: var(--fs-hero);
  line-height: 1;
  letter-spacing: -0.04em;
}

.grad{
  background: linear-gradient(135deg,
    color-mix(in oklab, var(--accent3) 70%, #ffffff),
    color-mix(in oklab, var(--accent) 90%, #ffffff)
  );
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  position: relative;
  display: inline-block;
}

.grad::after{
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, var(--accent3), var(--accent));
  opacity: .4;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.6s var(--ease);
}

.hero-title:hover .grad::after{
  transform: scaleX(1);
}

.hero-text{
  margin: 0 0 clamp(28px, 3.6vw, 44px);
  color: var(--muted);
  font-size: var(--fs-body);
  line-height: 1.9;
  max-width: 62ch;
}

/* Buttons mejorados */
.btn-primary, .btn-ghost{
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 18px 28px;
  border-radius: 20px;
  font-weight: 900;
  font-size: var(--fs-body);
  transition: all 0.3s var(--ease);
  position: relative;
  overflow: hidden;
  border: none;
  cursor: pointer;
  text-decoration: none;
}

.btn-primary{
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color: white;
  box-shadow: 
    0 20px 48px color-mix(in oklab, var(--accent) 18%, transparent),
    0 0 0 1px color-mix(in oklab, var(--accent) 40%, transparent);
}

.btn-primary::before{
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.2), transparent);
  transition: left 0.7s var(--ease);
}

.btn-primary:hover{
  transform: translateY(-4px);
  box-shadow: 
    0 24px 56px color-mix(in oklab, var(--accent) 24%, transparent),
    0 0 0 1px color-mix(in oklab, var(--accent) 60%, transparent);
}

.btn-primary:hover::before{
  left: 100%;
}

.btn-ghost{
  background: color-mix(in oklab, var(--surface2) 76%, transparent);
  border: 1px solid var(--stroke);
  color: var(--text);
}

.btn-ghost:hover{
  transform: translateY(-4px);
  background: color-mix(in oklab, var(--surface2) 94%, transparent);
  border-color: color-mix(in oklab, var(--accent) 40%, var(--stroke));
  box-shadow: var(--shadow-md);
}

.btn-primary svg, .btn-ghost svg{
  width: 20px;
  height: 20px;
  transition: transform 0.3s var(--ease);
}

.btn-primary:hover svg{
  transform: translateX(4px);
}

.btn-ghost:hover svg{
  transform: translateY(-2px);
}

/* Media cards con overlay mejorado */
.media-card{
  position: relative;
  border-radius: var(--r-xl);
  background: color-mix(in oklab, var(--surface2) 76%, transparent);
  border: 1px solid var(--stroke);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  transition: transform 0.4s var(--ease);
}

.media-card:hover{
  transform: translateY(-8px);
}

.media-card.large{
  border-radius: var(--r-xl);
}

.media-img{
  width: 100%;
  height: clamp(340px, 44vw, 580px);
  object-fit: cover;
  display: block;
  filter: saturate(1.05) contrast(1.05);
  transition: transform 0.6s var(--ease);
}

.media-card:hover .media-img{
  transform: scale(1.03);
}

/* Overlay sutil */
.media-card::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg, 
    rgba(0,0,0,.18) 0%, 
    rgba(0,0,0,.06) 40%,
    transparent 100%
  );
  pointer-events: none;
  transition: opacity 0.4s var(--ease);
}

html[data-theme="light"] .media-card::after{
  background: linear-gradient(
    180deg, 
    rgba(255,255,255,.18) 0%, 
    rgba(255,255,255,.08) 40%,
    transparent 100%
  );
}

.media-card:hover::after{
  opacity: 0.8;
}

/* Floating square animado */
.floating-square{
  position: absolute;
  right: 20px;
  top: 20px;
  width: clamp(84px, 10vw, 112px);
  height: clamp(84px, 10vw, 112px);
  border-radius: 22px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  display: grid;
  place-items: center;
  box-shadow: 
    0 24px 56px color-mix(in oklab, var(--accent) 20%, transparent),
    0 0 0 1px color-mix(in oklab, var(--accent) 40%, transparent);
  z-index: 2;
  animation: float 6s var(--ease) infinite alternate;
}

@keyframes float{
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50% { transform: translateY(-12px) rotate(2deg); }
}

.floating-square svg{
  width: 38px;
  height: 38px;
  color: white;
  animation: pulse 2s var(--ease) infinite;
}

@keyframes pulse{
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.9; transform: scale(1.05); }
}

/* Section titles */
.section-title{
  text-align: center;
  font-size: var(--fs-h2);
  letter-spacing: -0.03em;
  margin: 0 0 clamp(32px, 4vw, 56px);
  position: relative;
  display: block;
  left: auto;
  transform: none;
}

.section-title::after{
  content: '';
  position: absolute;
  bottom: -12px;
  left: 25%;
  width: 50%;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  border-radius: 3px;
}

.grad2{
  background: linear-gradient(135deg,
    color-mix(in oklab, var(--accent3) 65%, #ffffff),
    color-mix(in oklab, var(--accent2) 90%, #ffffff)
  );
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* Cards grid con efecto tilt */
.card-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: clamp(18px, 3vw, 36px);
  align-items: stretch;
  margin-top: clamp(18px, 3.4vw, 36px);
  justify-content: center;
  width: 100%;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

.glass-card{
  border-radius: 30px;
  background: color-mix(in oklab, var(--surface2) 74%, transparent);
  border: 1px solid var(--stroke);
  box-shadow: var(--shadow-md);
  padding: clamp(26px, 3.2vw, 42px);
  position: relative;
  overflow: hidden;
  transition: all 0.4s var(--ease);
  min-height: 100%;
  transform-style: preserve-3d;
  perspective: 1000px;
}

.tilt-card{
  transition: transform 0.3s var(--ease);
}

.glass-card:hover{
  transform: 
    translateY(-12px) 
    translateZ(20px)
    rotateX(2deg)
    rotateY(2deg);
  background: color-mix(in oklab, var(--surface2) 88%, transparent);
  box-shadow: 
    var(--shadow-lg),
    0 0 0 1px color-mix(in oklab, var(--accent) 20%, transparent);
}

.card-icon{
  width: 68px;
  height: 68px;
  border-radius: 20px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  display: grid;
  place-items: center;
  box-shadow: 
    0 18px 48px color-mix(in oklab, var(--accent) 18%, transparent),
    0 0 0 1px color-mix(in oklab, var(--accent) 40%, transparent);
  margin-bottom: 20px;
  transition: all 0.4s var(--ease);
}

.glass-card:hover .card-icon{
  transform: scale(1.1) rotate(5deg);
  box-shadow: 
    0 24px 56px color-mix(in oklab, var(--accent) 24%, transparent),
    0 0 0 1px color-mix(in oklab, var(--accent) 60%, transparent);
}

.card-icon svg{
  width: 30px;
  height: 30px;
  color: white;
}

.glass-card h3{
  margin: 20px 0 14px;
  font-size: var(--fs-h3);
  letter-spacing: -0.015em;
  line-height: 1.3;
}

.glass-card p{
  margin: 0 0 24px;
  color: var(--muted);
  line-height: 1.8;
  font-size: var(--fs-body);
}

.card-link{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: color-mix(in oklab, var(--accent) 74%, var(--accent3));
  font-weight: 850;
  font-size: var(--fs-body);
  transition: all 0.3s var(--ease);
}

.card-link:hover{
  color: var(--accent);
  gap: 16px;
}

.card-link svg{
  width: 20px;
  height: 20px;
  transition: transform 0.3s var(--ease);
}

.card-link:hover svg{
  transform: translateX(4px);
}

/* Two column layout */
.two-col{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(28px, 5vw, 88px);
  align-items: center;
}

.mini-badge{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 12px 18px;
  border-radius: 999px;
  background: color-mix(in oklab, var(--surface2) 64%, transparent);
  border: 1px solid var(--stroke);
  color: color-mix(in oklab, var(--accent) 70%, var(--text));
  font-weight: 900;
  font-size: var(--fs-small);
  width: fit-content;
  transition: all 0.3s var(--ease);
}

.mini-badge:hover{
  transform: translateY(-2px);
  background: color-mix(in oklab, var(--surface2) 80%, transparent);
  box-shadow: var(--shadow-sm);
}

.mini-badge svg{
  width: 20px;
  height: 20px;
  color: currentColor;
  transition: transform 0.3s var(--ease);
}

.mini-badge:hover svg{
  transform: rotate(15deg);
}

.big-title{
  margin: 22px 0 24px;
  font-size: clamp(38px, 5.4vw, 72px);
  letter-spacing: -0.035em;
  line-height: 1.05;
}

/* Benefits con iconos animados */
.benefits{
  display: grid;
  gap: clamp(18px, 2.6vw, 28px);
  margin-top: 28px;
}

.benefit{
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 22px;
  align-items: start;
  padding: clamp(20px, 2.8vw, 28px);
  border-radius: 28px;
  background: color-mix(in oklab, var(--surface2) 70%, transparent);
  border: 1px solid var(--stroke);
  box-shadow: var(--shadow-sm);
  transition: all 0.3s var(--ease);
}

.benefit:hover{
  transform: translateY(-4px);
  background: color-mix(in oklab, var(--surface2) 86%, transparent);
  box-shadow: var(--shadow-md);
  border-color: color-mix(in oklab, var(--accent) 30%, var(--stroke));
}

.benefit-ico{
  width: 56px;
  height: 56px;
  border-radius: 18px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  display: grid;
  place-items: center;
  transition: all 0.4s var(--ease);
}

.benefit:hover .benefit-ico{
  transform: scale(1.1) rotate(5deg);
  box-shadow: 
    0 16px 40px color-mix(in oklab, var(--accent) 20%, transparent),
    0 0 0 1px color-mix(in oklab, var(--accent) 50%, transparent);
}

.benefit-ico svg{
  width: 24px;
  height: 24px;
  color: white;
  transition: transform 0.3s var(--ease);
}

.benefit:hover .benefit-ico svg{
  transform: scale(1.1);
}

.benefit h3{
  margin: 4px 0 10px;
  font-size: clamp(17px, 1.6vw, 21px);
  line-height: 1.3;
}

.benefit p{
  margin: 0;
  color: var(--muted);
  line-height: 1.75;
  font-size: var(--fs-body);
}

/* CTA section */
.cta-text{
  color: var(--muted);
  line-height: 1.9;
  margin: 0 0 28px;
  font-size: var(--fs-body);
  max-width: 64ch;
}

.cta-actions{
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  margin-top: 20px;
}

.stat-badge{
  position: absolute;
  left: 20px;
  bottom: 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 20px;
  border-radius: 22px;
  background: color-mix(in oklab, var(--bg1) 96%, transparent);
  border: 1px solid var(--stroke);
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transition: all 0.4s var(--ease);
  z-index: 2;
  max-width: calc(100% - 40px);
  min-width: 0;
  flex-wrap: wrap;
}

.media-card:hover .stat-badge{
  transform: translateY(-8px);
  box-shadow: var(--shadow-lg);
}

.stat-ico{
  width: 52px;
  height: 52px;
  border-radius: 18px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  display: grid;
  place-items: center;
  transition: all 0.4s var(--ease);
}

.stat-badge:hover .stat-ico{
  transform: rotate(15deg) scale(1.1);
}

.stat-ico svg{
  width: 24px;
  height: 24px;
  color: white;
}

.stat-num{
  font-size: clamp(24px, 2.6vw, 32px);
  font-weight: 950;
  line-height: 1;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.stat-sub{
  font-size: var(--fs-small);
  color: var(--muted);
  margin-top: 4px;
  font-weight: 650;
}

/* Contact section */
.contact-top{
  text-align: center;
  margin-bottom: clamp(28px, 3.8vw, 48px);
}

/* Ensure contact header content is centered and not touching edges */
.contact-top{
  padding-left: clamp(16px, 6vw, 40px);
  padding-right: clamp(16px, 6vw, 40px);
}

.contact-top .section-title.big{
  margin-top: 8px;
  max-width: 54ch;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

/* Reduce visual crowding: ensure the 'Contáctanos' duplicate is hidden (we hid .grad2 earlier in contact-top) */
.contact-top .mini-badge{ margin-bottom: 8px; }

/* Servicios: center title and ensure it stays inside the container */
#servicios > .container{ display: block; padding-left: clamp(20px, 4vw, 40px); padding-right: clamp(20px, 4vw, 40px); }
#servicios .section-title{ max-width: 62ch; margin-left: auto; margin-right: auto; text-align: center; }

/* Navbar: ensure links form a single horizontal bar on desktop/tablet with even spacing */
.nav-center{
  justify-content: center;
  gap: clamp(12px, 2.4vw, 32px);
  flex-wrap: nowrap; /* keep single row when possible */
}

.nav-link{
  display: inline-flex;
  max-width: none;
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
}
/* If viewport shrinks, allow nav-center to scroll horizontally instead of wrapping weirdly */
@media (max-width: 1100px){
  .nav-center{ overflow-x: auto; -webkit-overflow-scrolling: touch; gap: 12px; padding-bottom: 6px; }
  .nav-center::-webkit-scrollbar{ height: 6px; }
}

/* Ensure the main services cards are centered within their container */
.card-grid{ justify-items: center; }

/* Extra safety: make contact-card padding larger so text/buttons don't touch edges */
.contact-card{ padding-left: clamp(20px, 4vw, 40px); padding-right: clamp(20px, 4vw, 40px); }

/* Ensure contact form fields and actions are visually centered and spaced */
.contact-card{
  display: block;
  padding: clamp(20px, 3.4vw, 40px);
}

.contact-card .form-grid{ gap: clamp(14px, 2.6vw, 24px); }
.contact-card .cta-actions{ justify-content: center; }
.contact-card .mail{ justify-content: center; display: inline-flex; }

/* Make sure contact title and subtitle are centered and constrained */
.contact-top .section-title, .contact-top .section-sub{ margin-left: auto; margin-right: auto; max-width: 62ch; }

.section-title.big{
  margin-top: 20px;
  font-size: clamp(36px, 5vw, 68px);
}

.section-sub{
  margin: 14px 0 0;
  color: var(--muted);
  font-size: var(--fs-body);
  max-width: 48ch;
  margin-left: auto;
  margin-right: auto;
}

.contact-card{
  width: min(940px, 100%);
  margin: 0 auto;
  border-radius: var(--r-xl);
  background: color-mix(in oklab, var(--surface2) 74%, transparent);
  border: 1px solid var(--stroke);
  box-shadow: var(--shadow-lg);
  padding: clamp(24px, 3.6vw, 42px);
  transition: transform 0.4s var(--ease);
}

.contact-card:hover{
  transform: translateY(-4px);
}

.form-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(18px, 2.6vw, 28px);
  margin-bottom: 24px;
}

.field{
  position: relative;
  display: block;
}

.field-ico{
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  color: var(--muted2);
  transition: color 0.3s var(--ease);
  z-index: 1;
}

.field-ico--top{
  top: 22px;
  transform: none;
}

.field input,
.field textarea{
  width: 100%;
  border-radius: 18px;
  border: 1px solid var(--stroke);
  background: color-mix(in oklab, var(--bg1) 62%, transparent);
  color: var(--text);
  outline: none;
  padding: 16px 18px 16px 52px;
  font-size: var(--fs-body);
  font-family: var(--font-sub);
  transition: all 0.3s var(--ease);
  position: relative;
}

html[data-theme="light"] .field input,
html[data-theme="light"] .field textarea{
  background: rgba(255,255,255,.96);
}

.field input::placeholder,
.field textarea::placeholder{
  color: var(--muted2);
  transition: color 0.3s var(--ease);
}

.field input:focus,
.field textarea:focus{
  border-color: color-mix(in oklab, var(--accent) 60%, var(--stroke));
  box-shadow: 
    0 0 0 4px color-mix(in oklab, var(--accent) 20%, transparent),
    inset 0 0 0 1px color-mix(in oklab, var(--accent) 30%, transparent);
  background: color-mix(in oklab, var(--bg1) 70%, transparent);
}

.field input:focus::placeholder,
.field textarea:focus::placeholder{
  color: color-mix(in oklab, var(--muted2) 70%, transparent);
}

.field input:focus ~ .field-ico,
.field textarea:focus ~ .field-ico{
  color: var(--accent);
}

.field textarea{
  resize: vertical;
  min-height: 180px;
  padding-top: 18px;
  line-height: 1.6;
}

.field--full{
  grid-column: 1 / -1;
}

.contact-direct{
  text-align: center;
  margin-top: clamp(22px, 3vw, 34px);
  color: var(--muted);
  font-size: var(--fs-body);
}

.mail{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-top: 14px;
  color: color-mix(in oklab, var(--accent) 72%, var(--accent3));
  font-weight: 900;
  font-size: var(--fs-body);
  transition: all 0.3s var(--ease);
}

.mail:hover{
  color: var(--accent);
  gap: 16px;
}

.mail svg{
  width: 20px;
  height: 20px;
  transition: transform 0.3s var(--ease);
}

.mail:hover svg{
  transform: translateY(-2px);
}

/* Footer mejorado */
.site-footer{
  margin-top: clamp(28px, 4vw, 56px);
padding-top: clamp(34px, 4.6vw, 72px);
  background: linear-gradient(
    180deg, 
    transparent 0%, 
    color-mix(in oklab, var(--bg1) 46%, rgba(0,0,0,0)) 20%,
    color-mix(in oklab, var(--bg2) 80%, rgba(0,0,0,0)) 100%
  );
  position: relative;
  overflow: hidden;
}

.site-footer::before{
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, 
    transparent,
    color-mix(in oklab, var(--stroke) 60%, transparent),
    transparent
  );
}

.footer-grid{
  display: grid;
  grid-template-columns: 1.4fr .9fr .9fr 1.2fr;
 gap: clamp(18px, 2.6vw, 44px);
padding-bottom: 28px;
  position: relative;
  z-index: 1;
}

.footer-logo img{
  height: clamp(36px, 3.4vw, 46px);
  width: auto;
  filter: drop-shadow(0 12px 28px rgba(0,0,0,.22));
  transition: transform 0.4s var(--ease);
}

.footer-logo:hover img{
  transform: scale(1.05);
}

.footer-desc{
  margin: 22px 0 28px;
  color: var(--muted);
  line-height: 1.8;
  font-size: var(--fs-body);
  max-width: 42ch;
}

/* Iconos flotantes en elementos del footer */
.icon-float{
  animation: iconFloat 4s var(--ease) infinite alternate;
}

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

.meta-row{
  display: flex;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 16px;
}

.meta-ico{
  width: 38px;
  height: 38px;
  border-radius: 14px;
  border: 1px solid var(--stroke);
  background: color-mix(in oklab, var(--surface2) 62%, transparent);
  display: grid;
  place-items: center;
  flex-shrink: 0;
  transition: all 0.3s var(--ease);
}

.meta-row:hover .meta-ico{
  transform: translateY(-3px);
  background: color-mix(in oklab, var(--surface2) 80%, transparent);
  border-color: color-mix(in oklab, var(--accent) 40%, var(--stroke));
}

.meta-ico svg{
  width: 20px;
  height: 20px;
  color: var(--muted);
  transition: color 0.3s var(--ease);
}

.meta-row:hover .meta-ico svg{
  color: var(--accent);
}

.meta-title{
  font-weight: 900;
  font-size: var(--fs-body);
}

.meta-sub{
  color: var(--muted);
  margin-top: 4px;
  font-size: var(--fs-small);
  line-height: 1.5;
}

/* Social icons */
.social{
  margin-top: 28px;
}

.social-title{
  font-weight: 900;
  margin-bottom: 16px;
  font-size: var(--fs-body);
}

.social-row{
  display: flex;
  gap: 12px;
}

.social-btn{
  width: 46px;
  height: 46px;
  border-radius: 14px;
  border: 1px solid var(--stroke);
  background: color-mix(in oklab, var(--surface2) 62%, transparent);
  display: grid;
  place-items: center;
  transition: all 0.3s var(--ease);
  position: relative;
  overflow: hidden;
}

.social-btn::before{
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  opacity: 0;
  transition: opacity 0.3s var(--ease);
}

.social-btn:hover{
  transform: translateY(-4px) scale(1.05);
  border-color: transparent;
  box-shadow: 0 12px 32px rgba(0,0,0,.2);
}

.social-btn:hover::before{
  opacity: 1;
}

.social-btn svg{
  width: 20px;
  height: 20px;
  color: color-mix(in oklab, var(--text) 92%, transparent);
  position: relative;
  z-index: 1;
  transition: color 0.3s var(--ease);
}

.social-btn:hover svg{
  color: white;
}

/* Footer columns */
.footer-col h3{
  margin: 8px 0 22px;
  font-size: 15px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--text) 80%, transparent);
}

.footer-col a{
  display: block;
  padding: 12px 0;
  color: color-mix(in oklab, var(--text) 80%, transparent);
  font-size: var(--fs-body);
  transition: all 0.25s var(--ease);
  position: relative;
  padding-left: 0;
}

.footer-col a::before{
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  width: 6px;
  height: 6px;
  background: var(--accent);
  border-radius: 50%;
  transform: translateY(-50%) scale(0);
  transition: transform 0.3s var(--ease);
}

.footer-col a:hover{
  color: var(--text);
  padding-left: 16px;
}

.footer-col a:hover::before{
  transform: translateY(-50%) scale(1);
}

.footer-contact .soon{
  color: color-mix(in oklab, var(--accent) 66%, var(--accent3));
  margin: 0 0 20px;
  font-size: var(--fs-body);
  line-height: 1.6;
}

.contact-row{
  display: flex;
  gap: 14px;
  margin: 20px 0;
  align-items: flex-start;
}

.contact-ico{
  width: 46px;
  height: 46px;
  border-radius: 14px;
  border: 1px solid var(--stroke);
  background: color-mix(in oklab, var(--surface2) 62%, transparent);
  display: grid;
  place-items: center;
  flex-shrink: 0;
  transition: all 0.3s var(--ease);
}

.contact-row:hover .contact-ico{
  transform: translateY(-3px);
  background: color-mix(in oklab, var(--surface2) 80%, transparent);
  border-color: color-mix(in oklab, var(--accent) 40%, var(--stroke));
}

.contact-ico svg{
  width: 20px;
  height: 20px;
  color: color-mix(in oklab, var(--text) 86%, transparent);
  transition: color 0.3s var(--ease);
}

.contact-row:hover .contact-ico svg{
  color: var(--accent);
}

.maps{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-top: 16px;
  color: color-mix(in oklab, var(--accent) 66%, var(--accent3));
  font-weight: 900;
  font-size: var(--fs-body);
  transition: all 0.3s var(--ease);
}

.maps:hover{
  color: var(--accent);
  gap: 16px;
}

.maps svg{
  width: 18px;
  height: 18px;
  transition: transform 0.3s var(--ease);
}

.maps:hover svg{
  transform: translateX(4px);
}

/* Footer bottom */
.footer-bottom{
  border-top: 1px solid var(--stroke);
  padding: 22px 0 32px;
  position: relative;
}

.footer-bottom::before{
  content: '';
  position: absolute;
  top: -1px;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, 
    transparent,
    color-mix(in oklab, var(--stroke) 60%, transparent),
    transparent
  );
}

.bottom-row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}

.copyright{
  color: var(--muted);
  font-size: var(--fs-small);
}

.legal{
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
}

.legal a{
  color: var(--muted);
  font-size: var(--fs-small);
  transition: color 0.25s var(--ease);
}

.legal a:hover{
  color: var(--text);
}

/* FAB button */
.fab{
  position: fixed;
  left: max(18px, env(safe-area-inset-left));
  bottom: max(20px, env(safe-area-inset-bottom));
  width: 48px;
  height: 48px;
  border-radius: 999px;
  border: 1px solid var(--stroke);
  background: color-mix(in oklab, var(--surface2) 66%, transparent);
  color: var(--text);
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  cursor: pointer;
  transition: all 0.3s var(--ease);
  font-weight: 900;
  font-size: 18px;
  display: grid;
  place-items: center;
  z-index: 999;
}

.fab:hover{
  transform: translateY(-4px) scale(1.05);
  background: color-mix(in oklab, var(--surface2) 84%, transparent);
  border-color: color-mix(in oklab, var(--accent) 50%, var(--stroke));
  box-shadow: 
    var(--shadow-lg),
    0 0 0 1px color-mix(in oklab, var(--accent) 30%, transparent);
}

/* =========================
   RESPONSIVE BREAKPOINTS
========================= */
@media (max-width: 1200px){
  .nav-link{ padding: 12px 16px; }
  .nav-center{ gap: 16px; }
  
  .hero-grid{ gap: clamp(24px, 4vw, 64px); }
  .two-col{ gap: clamp(24px, 4vw, 64px); }
  
  .footer-grid{ grid-template-columns: 1.2fr .9fr .9fr 1fr; }
}

@media (max-width: 1024px){
  .card-grid{ grid-template-columns: repeat(2, 1fr); }
  .glass-card:last-child{ grid-column: 1 / -1; max-width: 500px; margin: 0 auto; }
}

/* ==== User-requested NAV fixes and mobile behavior overrides ==== */
/* Remove the decorative underline under nav items */
.nav-link::after{ display: none !important; }

/* Ensure nav labels show fully on desktop/tablet (no ellipsis) */
.nav-link{
  text-overflow: clip !important;
  max-width: none !important;
  overflow: visible !important;
}

/* Mobile: keep nav items in one visual row and allow horizontal scroll to avoid wrapping/mixing */
@media (max-width: 980px){
  .nav-center{
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    gap: 12px !important;
    padding-bottom: 6px;
  }

  .nav-center a.nav-link{
    flex: 0 0 auto;
    white-space: nowrap;
    min-width: 120px;
    padding: 10px 14px;
  }

  /* Ensure visible tap targets and avoid overlap with actions */
  .nav-actions{ right: 8px; }
}

/* Small visual tweak: show subtle scrollbar on medium widths */
@media (max-width: 1100px){
  .nav-center{ scrollbar-width: thin; }
}


@media (max-width: 980px){
  /* show condensed nav on smaller screens but allow readable wrapping */
  .nav-center{ display: none; justify-content: flex-start; gap: 10px; flex-wrap: wrap; }
  .hero-grid{ grid-template-columns: 1fr; }
  .two-col{ grid-template-columns: 1fr; }
  
  .footer-grid{ 
    grid-template-columns: 1fr 1fr; 
    gap: clamp(24px, 3vw, 48px);
  }
  
  .section:not(.hero) > .container{
    padding: clamp(20px, 2.8vw, 32px);
  }
}

@media (max-width: 768px){
  .card-grid{ grid-template-columns: 1fr; }
  .glass-card:last-child{ grid-column: auto; max-width: none; }
  
  .form-grid{ grid-template-columns: 1fr; }
  
  .footer-grid{ grid-template-columns: 1fr; }
  
  .cta-actions{ 
    flex-direction: column; 
    gap: 16px;
  }
  
  .btn-primary, .btn-ghost{ 
    width: 100%; 
    justify-content: center;
  }
  
  .pill-cta{ display: none; }
  /* Keep theme toggle visible on mobile and ensure it's placed to the right */
  .lang-btn{ display: inline-flex; margin-left: 8px; min-width: 44px; height: 44px; padding: 0 12px; }
  .nav-actions{ margin-left: auto; }
  }

@media (max-width: 640px){
  .nav-shell{ 
    padding: 0 clamp(16px, 3vw, 24px); 
    width: 100%; 
  }
  
  .section:not(.hero) > .container{
    padding: 20px;
    border-radius: 24px;
  }
  
  .hero-title{ font-size: clamp(36px, 8vw, 48px); }
  .section-title{ font-size: clamp(28px, 6vw, 36px); }
  .big-title{ font-size: clamp(32px, 7vw, 40px); }
  
  .bottom-row{ 
    flex-direction: column; 
    align-items: flex-start;
    gap: 16px;
  }
  
  .legal{ gap: 16px; }
}

@media (max-width: 480px){
  :root{
    --gutter: clamp(16px, 2.8vw, 20px);
    --section-y: clamp(64px, 7vw, 88px);
  }
  
  .hero-grid, .two-col{ gap: clamp(20px, 3vw, 32px); }
  
  .benefit{ 
    grid-template-columns: 1fr;
    gap: 16px;
  }
  
  .benefit-ico{ 
    width: 48px; 
    height: 48px; 
    justify-self: start;
  }
  
  .floating-square{ 
    width: 72px; 
    height: 72px; 
    right: 12px; 
    top: 12px; 
  }
  
  .floating-square{ position: static; margin: 12px 0 0 auto; }

  .stat-badge{ 
    position: static; 
    left: auto; 
    bottom: auto; 
    padding: 14px 16px;
    margin-top: 12px;
    transform: none;
    width: 100%;
    box-sizing: border-box;
  }
}

/* =========================
   Fixes after HTML review
   - hide duplicated visual text in contact header
   - center servicios container and constrain width
   - mobile header: move actions (burger + theme) to right and ensure tap targets
========================= */

/* Hide the duplicated span in the contact title without editing HTML */
.contact-top .grad2{ display: none; }

/* Ensure servicios section is visually centered and constrained */
#servicios > .container{
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
  padding-left: clamp(20px, 3vw, 36px);
  padding-right: clamp(20px, 3vw, 36px);
}

/* Mobile header: position actions to the right edge to avoid overlap */
@media (max-width: 980px){
  .nav-shell{ position: relative; }
  .nav-actions{
    position: absolute;
    right: clamp(12px, 4vw, 18px);
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    gap: 8px;
    align-items: center;
    background: transparent;
  }

  /* Ensure hamburger and theme toggle have comfortable tap size */
  .burger, .lang-btn, .icon-btn{ min-width: 44px; min-height: 44px; height: 44px; padding: 8px; border-radius: 12px; }

  /* Keep nav-center readable but below header when needed */
  .nav-center{ margin-right: 120px; }
}

@media (max-width: 640px){
  .nav-actions{ right: 12px; }
  .nav-center{ margin-right: 140px; }
}
.btn-ghost{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
}

.btn-ghost .icon{
  width:20px;
  height:20px;
}
/* Language selector */
.language-selector{ position:relative; }
.language-btn{
  display:flex;
  align-items:center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--bg) 86%, var(--primary) 14%);
  border: 1px solid color-mix(in srgb, var(--primary) 16%, var(--border));
  color: var(--text);
  cursor:pointer;
  transition: transform var(--t-fast), box-shadow var(--t-fast), background var(--t-fast);
}
body:not(.theme-dark) .language-btn{
  box-shadow: 0 12px 26px rgba(19,33,68,0.10);
}
.language-btn:hover{ transform: translateY(-1px); }
.language-btn i{ font-size: 12px; transition: transform var(--t-fast); }
.language-btn[aria-expanded="true"] i{ transform: rotate(180deg); }

.language-flag{
  width: 18px;
  height: 18px;
  border-radius: 6px;
  background: linear-gradient(135deg, rgba(31,94,255,0.35), rgba(43,140,255,0.25));
  box-shadow: 0 10px 22px rgba(31,94,255,0.12);
}

.language-dropdown{
  position:absolute;
  right:0;
  top: calc(100% + 10px);
  list-style:none;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: var(--shadow);
  min-width: 230px;
  padding: 8px;
  opacity:0;
  visibility:hidden;
  transform: translateY(-8px);
  transition: opacity var(--t-fast), transform var(--t-fast), visibility var(--t-fast);
  z-index: calc(var(--z-header) + 30);
}
body:not(.theme-dark) .language-dropdown{
  box-shadow: var(--shadow-lg);
}
.language-dropdown.show{
  opacity:1;
  visibility:visible;
  transform: translateY(0);
}
.language-option{
  width:100%;
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 10px;
  background: transparent;
  border:none;
  border-radius: 12px;
  cursor:pointer;
  color: var(--text);
  font-weight: 900;
  transition: background var(--t-fast);
}
.language-option:hover{
  background: color-mix(in srgb, var(--primary) 10%, transparent);
}
.lang-option-flag{
  width: 18px;
  height: 18px;
  border-radius: 6px;
  background: linear-gradient(135deg, rgba(31,94,255,0.35), rgba(43,140,255,0.25));
}

/* Mobile language select */
.mobile-language-select{
  width: 100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--bg) 92%, #0b1220 8%);
  color: var(--text);
  font-weight: 900;
}
/* FIX: quitar línea del botón "Volver a Servicios" */
.back-btn{
  border: 0 !important;
}/* FIX: quitar línea/aro del CTA "¿Eres colaborador?" (shadow 1px) */
.pill-cta{
  box-shadow: 0 16px 40px color-mix(in oklab, var(--accent) 20%, transparent) !important;
}
/* FIX: quitar líneas del menú hamburguesa (drawer) */
.drawer-top{
  border-bottom: 0 !important;
}

.drawer-link{
  border: 0 !important;
}
/* CTA title: evita "servi-cios" (no cortar palabras con guiones) */
.cta .big-title{
  hyphens: none !important;          /* desactiva hyphenation */
  -webkit-hyphens: none !important;
  word-break: keep-all !important;   /* no partir palabras */
  overflow-wrap: normal !important;  /* no forzar cortes dentro */
}

/* por si algún navegador intenta cortar igual */
.cta .big-title *{
  hyphens: none !important;
  -webkit-hyphens: none !important;
  word-break: keep-all !important;
  overflow-wrap: normal !important;
}

/* =========================================================
   AJUSTES SOLICITADOS (ONLY CSS)
   1) Reveal scroll más rápido (menos blur / menos tardado)
   2) Títulos: Azul rey vs negro (intercambio solicitado)
   ========================================================= */

/* 1) Reveal alineado a referencia (sin blur, movimiento sutil) */
.reveal{
  opacity: 0;
  filter: none;
  transform: translateY(14px);
  transition: opacity 700ms ease, transform 700ms ease;
  transition-delay: var(--d, 0ms);
  will-change: opacity, transform;
}
.reveal.is-in{
  opacity: 1;
  transform: translateY(0);
}

/* 2) Intercambio de colores en títulos (Azul rey = var(--accent), Negro = var(--text)) */

/* HERO: "Procesamiento" azul, "de nómina" negro */
.hero-title{
  color: var(--text) !important; /* parte “de nómina” */
}
.hero-title .grad{
  /* anula cualquier gradiente anterior y fuerza azul rey */
  background: none !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
  color: var(--accent) !important;
  -webkit-text-fill-color: var(--accent) !important;
}

/* SECCIÓN SERVICIOS: "Servicios" azul, "Procesamiento de nómina" negro */
.section-title{
  color: var(--text);
}
.section-title > span:first-child{
  color: var(--accent) !important; /* "Servicios" */
}
.section-title .grad2{
  background: none !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
  color: var(--text) !important;              /* "Procesamiento de nómina" */
  -webkit-text-fill-color: var(--text) !important;
}

/* BENEFICIOS: "Beneficios de" azul, "Procesamiento de nómina" negro */
.big-title{
  color: var(--accent) !important; /* “Beneficios de” */
}
.big-title .grad{
  background: none !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
  color: var(--text) !important;              /* “Procesamiento / de nómina” */
  -webkit-text-fill-color: var(--text) !important;
}

/* CTA: "Todos los servicios" azul / "en un solo lugar" negro (wrappers vienen del JS) */
.big-title .split-blue{
  color: var(--accent) !important;
  display: block;
}
.big-title .split-black{
  color: var(--text) !important;
  display: block;
}


/* =========================================================
   MENÚ HAMBURGUESA — MATCH REFERENCIA (index/stylebeca)
   - No cambia IDs existentes (usa #navToggle / #navClose / #navDrawer existentes en JS)
   - Implementa estructura/clases de la referencia en capital.html
========================================================= */

/* Aliases para reusar estética de referencia con tokens de Capital */
:root{
  --bg: var(--bg0);
  --bg-soft: var(--bg1);
  --border: var(--stroke);
  --primary: var(--accent);
  --primary-2: var(--accent2);

  /* Sombras similares a referencia */
  --shadow-soft: 0 12px 26px rgba(19,33,68,0.10);
  --shadow:      0 18px 55px rgba(19,33,68,0.14);
  --shadow-lg:   0 28px 90px rgba(19,33,68,0.22);
}

/* Header (solo lo necesario para referencia) */
.header{
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  background: color-mix(in oklab, var(--bg1) 88%, transparent);
  border-bottom: 1px solid var(--stroke);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
}

.header-container{
  height: var(--header-h);
  display: flex;
  align-items: center;
  gap: 16px;
}

.logo-img{
  height: 34px;
  width: auto;
  display: block;
  object-fit: contain;
}

/* Deshabilita cualquier nav horizontal: todo vive en hamburguesa */
.nav.nav-disabled{ display:none !important; }
.nav{ display:none !important; }

.header-controls{
  margin-left: auto;
  display:flex;
  align-items:center;
  gap: 10px;
}

/* Botón hamburguesa visible también en PC */
.menu-toggle{
  width: 46px;
  height: 46px;
  border-radius: 16px;
  border: 1px solid rgba(24,35,137,0.16);
  background: rgba(255,255,255,0.78);
  box-shadow: var(--shadow-soft);
  display: grid;
  place-items: center;
  padding: 0;
  cursor: pointer;
  transition: transform 150ms ease, box-shadow 150ms ease;
  -webkit-tap-highlight-color: transparent;
}
.menu-toggle:hover{ transform: translateY(-1px); }
.menu-toggle i{
  font-size: 18px;
  color: rgba(11,21,53,0.88);
}

/* Overlay */
.mobile-menu-overlay{
  position: fixed;
  inset: 0;
  background: rgba(11,21,53,0.28);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 250ms ease, visibility 250ms ease;
  z-index: 10010;
}
.mobile-menu-overlay.show{
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* Drawer */
.mobile-menu{
  position: fixed;
  top: 0;
  right: 0;
  width: min(92vw, 420px);
  height: 100dvh;
  background: rgba(255,255,255,0.92);
  border-left: 1px solid rgba(24,35,137,0.14);
  border-radius: 26px 0 0 26px;
  box-shadow: var(--shadow-lg);
  transform: translateX(110%);
  transition: transform 250ms ease;
  z-index: 10030;
  display: flex;
  flex-direction: column;
  padding-top: env(safe-area-inset-top);
  padding-bottom: env(safe-area-inset-bottom);
}
.mobile-menu.open{ transform: translateX(0); }

.mobile-menu-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 18px 16px 14px;
  background: linear-gradient(135deg, rgba(0,61,165,0.10), rgba(91,117,182,0.12));
  border-bottom: 1px solid rgba(24,35,137,0.12);
}

.close-menu{
  width: 46px;
  height: 46px;
  border-radius: 16px;
  border: 1px solid rgba(24,35,137,0.16);
  background: rgba(255,255,255,0.78);
  box-shadow: var(--shadow-soft);
  display: grid;
  place-items: center;
  cursor:pointer;
  transition: transform 150ms ease;
}
.close-menu:hover{ transform: translateY(-1px); }

.mobile-nav-list{
  list-style:none;
  padding: 12px;
  margin: 0;
  flex: 1 1 auto;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.mobile-nav-item{ list-style:none; margin-bottom: 8px; }

/* Acordeón */
.mobile-accordion{ padding: 8px 0; }
.menu-details{ width: 100%; }
.menu-details > summary{ list-style:none; cursor: pointer; }
.menu-details > summary::-webkit-details-marker{ display:none; }

.mobile-nav-link{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 14px 14px;
  border-radius: 16px;
  text-decoration:none;
  color: rgba(11,21,53,0.84);
  font-weight: 900;
  background: rgba(220,226,239,0.55);
  border: 1px solid rgba(24,35,137,0.12);
  transition: background 150ms ease, transform 150ms ease, border-color 150ms ease;
}
.mobile-nav-link:hover{
  background: rgba(220,226,239,0.55);
  transform: translateY(-1px);
  border-color: rgba(24,35,137,0.18);
}
.mobile-nav-link i{
  transition: transform 180ms ease;
}

/* Links dentro del summary (texto clickeable) */
.mobile-summary-link{
  display:flex;
  align-items:center;
  gap: 10px;
  text-decoration:none;
  color: inherit;
}

/* Submenu */
.mobile-submenu{
  list-style:none;
  margin: 10px 0 8px 0;
  padding: 0 0 0 14px;
  border-left: 1px solid rgba(24,35,137,0.18);
}
.mobile-sub-link{
  display:block;
  padding: 12px 12px;
  border-radius: 14px;
  font-weight: 900;
  color: rgba(11,21,53,0.84);
  text-decoration:none;
  background: transparent;
  transition: background 150ms ease, transform 150ms ease;
}
.mobile-sub-link:hover{
  background: rgba(220,226,239,0.55);
  transform: translateX(2px);
}

/* Flecha rota cuando details abierto */
.menu-details[open] > summary i{ transform: rotate(90deg); }

/* Active/current page (si JS marca .active o aria-current) */
.mobile-menu .mobile-nav-link.active,
.mobile-menu .mobile-nav-link[aria-current="page"]{
  background: color-mix(in srgb, var(--primary) 18%, transparent) !important;
  border-color: color-mix(in srgb, var(--primary) 22%, transparent) !important;
  transform: none !important;
}

/* Scroll lock */
body.menu-open{
  overflow: hidden;
  height: 100%;
  touch-action: none;
}


/* Drawer root wrapper */
.nav-drawer{
  position: fixed;
  inset: 0;
  z-index: 10010;
}


/* =========================================================
   PATCH 2026-02-22 — Mobile header / language / scrollbar fixes
   - NO cambia IDs ni estructura
   - Solo corrige escala/overflow en móvil (idiomas + controles)
========================================================= */

/* Evita que el header "salte" por el safe-area en móviles modernos */
.site-header{
  padding-left: env(safe-area-inset-left);
  padding-right: env(safe-area-inset-right);
}

/* Controles del header: no envolver raro en móvil */
.header-controls{
  flex-wrap: nowrap;
  min-width: 0;
}

/* Botón de idioma: tamaño consistente (igual a hamburguesa) */
.language-btn{
  height: 44px;
  padding: 0 12px;
  border-radius: 14px;
  min-width: 44px;
}
.language-flag,
.lang-option-flag{
  display: inline-flex;
  width: 18px;
  height: 18px;
  align-items: center;
  justify-content: center;
}
.language-code{
  font-weight: 850;
  font-size: 12px;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

/* Dropdown: evita recortes en pantallas pequeñas */
.language-dropdown{
  max-width: min(260px, calc(100vw - 24px));
}

/* Botón hamburguesa: tamaño fijo consistente */
.menu-toggle{
  width: 46px;
  height: 44px;
  border-radius: 14px;
  padding: 0;
}

/* En móviles chicos, el CTA del header suele romper el layout: lo ocultamos */
@media (max-width: 520px){
  .header-controls .btn.btn-primary.btn-sm{
    display: none;
  }
}

/* Drawer: ancho completo en pantallas muy pequeñas (sin bordes raros) */
@media (max-width: 420px){
  .mobile-menu{
    width: 100vw;
    border-left: 0;
  }
}

/* Mejor scroll interno del drawer (si el contenido es largo) */
.mobile-nav-list{
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}


/* =========================================================
   PATCH 2026-02-22b — 'Eres colaborador' + iconos header (móvil/desktop)
   - MÓVIL: ocultar CTA colaborador y ajustar tamaños/posiciones de idioma + hamburguesa como referencia
   - DESKTOP: CTA colaborador con tamaño/padding como referencia
   - NO cambia IDs ni HTML
========================================================= */

/* DESKTOP / general: CTA colaborador como referencia (pill) */
.header-controls .btn.btn-primary.btn-sm{
  border-radius: 999px;
  padding: 10px 14px;
  line-height: 1;
  white-space: nowrap;
}

/* MÓVIL/TABLET: ocultar 'Eres colaborador' y dejar SOLO iconos (idioma + menú) */
@media (max-width: 980px){
  .header-controls .btn.btn-primary.btn-sm{
    display: none !important;
  }

  /* Espaciado exacto de controles */
  .header-controls{
    gap: 10px;
  }

/* Idioma: móvil más cuadrado (no ovalado) */
.language-btn{
  height: 36px !important;
  min-width: 36px !important;
  padding: 0 10px !important;
  border-radius: 10px !important;   /* antes 999px */
  width: auto !important;
  justify-content: center !important;
  white-space: nowrap !important;
}

/* Hamburguesa: móvil cuadrado */
.menu-toggle{
  width: 36px !important;
  height: 36px !important;
  border-radius: 10px !important;   /* antes 999px */
  padding: 0 !important;
  display: grid !important;
  place-items: center !important;
}
}

/* =========================================================
   PATCH 2026-02-22c — Fix visual de "Procesamiento de nómina"
   Objetivo:
   - Corregir "continuidad" visual (separación/partido raro) del texto
   - Quitar línea del submenú (sin tocar HTML/IDs)
   ========================================================= */

/* 1) Asegura espacio visual aunque el i18n deje pegado ...</span>de... */
.hero-title .grad{
  margin-right: .18em; /* evita 'Procesamientode' cuando falta el espacio en el string */
}

/* 2) Menú hamburguesa: quitar la línea (border-left) del submenú */
.mobile-submenu{
  border-left: 0 !important;
  padding-left: 0 !important;  /* sin sangría que dependía de la línea */
  margin-left: 0 !important;
}

/* 3) Texto "Procesamiento de nómina" dentro del submenú: sin cortes raros */
.mobile-sub-link[data-i18n-text="nav.svc.payroll"]{
  white-space: normal;        /* permite 2 líneas si hace falta */
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;   /* NO separar nó-mi-na */
  line-height: 1.15;
  letter-spacing: 0;
}

/* Si la pantalla es muy chica, baja un poco el tamaño para que no se vea “mal cortado” */
@media (max-width: 380px){
  .mobile-sub-link[data-i18n-text="nav.svc.payroll"]{
    font-size: 13.5px;
  }
}


/* =========================================================
   PATCH 2026-02-22d — Fix definitivo de cortes/guiones en móvil (Hero)
   Problema en móvil (captura):
   - "Procesamiento de no- mina" (hyphenation automática)
   - "nues- tros" por <br> + hyphenation
   Solución:
   - Desactivar hyphenation y cortes agresivos SOLO en el hero
   - En móvil ocultar <br> del texto para que fluya natural
   - Mantener IDs / HTML intactos
========================================================= */

/* HERO: no partir palabras (ni títulos ni texto) */
.hero-title,
.hero-title *{
  hyphens: none !important;
  -webkit-hyphens: none !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
}

/* Permite saltar solo en espacios (evita 'no-' en medio) */
.hero-title{
  white-space: normal;
  text-wrap: balance; /* mejora el reparto de líneas (soportado en navegadores modernos) */
}

/* Texto del hero: sin guiones automáticos */
.hero-text,
.hero-text *{
  hyphens: none !important;
  -webkit-hyphens: none !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
}

/* En móvil: quita los <br> forzados que están rompiendo frases */
@media (max-width: 560px){
  .hero-text br{
    display: none !important;
  }
}

/* =========================================================
   PATCH — Menú hamburguesa (Capital) paleta Morning Cloud
   - Cabecera: #DCE2EF
   - Cuerpo drawer: blanco
   - Botones principales: #DCE2EF + texto gris oscuro
   - Subservicios: transparentes, sin borde, sin contorno
   - NO cambia IDs ni estructura
========================================================= */

#mobile-menu{
  background: #FFFFFF !important;              /* cuerpo del drawer */
  border-left: 1px solid rgba(11,21,53,0.12) !important;
}

/* Cabecera completa (logo + botón cerrar) */
#mobile-menu .mobile-menu-header{
  background: #DCE2EF !important;              /* Morning cloud */
  border-bottom: 1px solid rgba(11,21,53,0.12) !important;
}

/* Botón X dentro de la cabecera (para que combine con la cabecera) */
#mobile-menu .close-menu{
  background: #DCE2EF !important;
  border: 1px solid rgba(11,21,53,0.12) !important;
  box-shadow: none !important;
  color: rgba(11,21,53,0.86) !important;      /* gris oscuro */
}
#mobile-menu .close-menu i{
  color: rgba(11,21,53,0.86) !important;
}

/* Fondo de la lista interior (asegura blanco total debajo de la cabecera) */
#mobile-menu .mobile-nav-list,
#mobile-menu nav{
  background: #FFFFFF !important;
}

/* Botones principales del menú (Inicio/Servicios/etc.) */
#mobile-menu .mobile-nav-link,
#mobile-menu .mobile-nav-summary{
  background: rgba(220,226,239,0.55);              /* Morning cloud */
  border: 1px solid rgba(11,21,53,0.12) !important;
  box-shadow: none !important;
  color: rgba(11,21,53,0.86) !important;      /* gris oscuro */
}

/* Texto interno de los summary (link dentro del summary) */
#mobile-menu .mobile-summary-link,
#mobile-menu .mobile-summary-link span{
  color: rgba(11,21,53,0.86) !important;
}

/* Chevron/flecha */
#mobile-menu .mobile-nav-summary i{
  color: rgba(11,21,53,0.70) !important;
}

/* Hover/focus de botones principales (mantener misma paleta, sin azul) */
#mobile-menu .mobile-nav-link:hover,
#mobile-menu .mobile-nav-summary:hover,
#mobile-menu .mobile-nav-link:focus-visible,
#mobile-menu .mobile-nav-summary:focus-visible{
  background: #DCE2EF !important;
  border-color: rgba(11,21,53,0.16) !important;
  box-shadow: none !important;
}

/* Estado activo (evita que se pinte con el color primario azul) */
#mobile-menu .mobile-nav-link.active,
#mobile-menu .mobile-nav-link[aria-current="page"],
#mobile-menu .mobile-nav-summary.active,
#mobile-menu .mobile-nav-summary[aria-current="page"]{
  background: #DCE2EF !important;
  border-color: rgba(11,21,53,0.16) !important;
  box-shadow: none !important;
  transform: none !important;
}

/* Submenú: sin línea lateral */
#mobile-menu .mobile-submenu{
  border-left: 0 !important;
  padding-left: 0 !important;   /* opcional para quitar sangría ligada a la línea */
  margin-left: 0 !important;
  background: transparent !important;
}

/* Subservicios: transparentes, sin contorno, sobre fondo blanco */
#mobile-menu .mobile-sub-link{
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  color: rgba(11,21,53,0.86) !important;
}

/* Hover/focus de subservicios: mantener transparentes */
#mobile-menu .mobile-sub-link:hover,
#mobile-menu .mobile-sub-link:focus-visible,
#mobile-menu .mobile-sub-link.active,
#mobile-menu .mobile-sub-link[aria-current="page"]{
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  color: rgba(11,21,53,0.86) !important;
  transform: none !important;
  text-decoration: none !important;
}

/* Quita cualquier subrayado/after heredado */
#mobile-menu a,
#mobile-menu a:hover,
#mobile-menu a:focus-visible{
  text-decoration: none !important;
}
#mobile-menu a::after,
#mobile-menu .active::after{
  content: none !important;
}

/* =========================================================
   FIX FINAL CTA (SOLO CSS) — NO TOCA HTML/JS/i18n
   "Todos los servicios en un" = azul marino #182389
   "solo lugar" = negro #000000
   Este bloque debe quedar al FINAL ABSOLUTO
========================================================= */

/* 1) Neutraliza cualquier gradiente/transparent aplicado al H2 del CTA */
.cta .big-title,
.cta .big-title[data-i18n],
.section.cta .big-title{
  background: none !important;
  background-image: none !important;
  -webkit-background-clip: border-box !important;
  background-clip: border-box !important;
  color: inherit !important;
  -webkit-text-fill-color: currentColor !important;
  text-fill-color: currentColor !important;
}

/* 2) Fuerza colores exactos en los spans del CTA */
.cta .big-title > .split-blue,
.section.cta .big-title > .split-blue,
.section.cta .col-content .big-title > .split-blue{
  display: block !important;
  color: #182389 !important;
  background: none !important;
  background-image: none !important;
  -webkit-background-clip: border-box !important;
  background-clip: border-box !important;
  -webkit-text-fill-color: #182389 !important;
  text-fill-color: #182389 !important;
}

.cta .big-title > .split-black,
.section.cta .big-title > .split-black,
.section.cta .col-content .big-title > .split-black{
  display: block !important;
  color: #000000 !important;
  background: none !important;
  background-image: none !important;
  -webkit-background-clip: border-box !important;
  background-clip: border-box !important;
  -webkit-text-fill-color: #000000 !important;
  text-fill-color: #000000 !important;
}

/* 3) Si algún fix anterior aplica color a todos los hijos del título, lo anulamos aquí */
.cta .big-title > .split-blue *,
.cta .big-title > .split-black *{
  color: inherit !important;
  -webkit-text-fill-color: currentColor !important;
  background: none !important;
}

/* 4) Fallback visual si por i18n temporalmente desaparecen spans (opcional, no rompe nada) */
.cta .big-title:not(:has(> .split-blue)){
  color: #182389 !important;
  background: none !important;
  -webkit-text-fill-color: #182389 !important;
}

/* =========================================================
   PATCH 2026-02-24 — Botones estilo referencia (rectangulares)
   - NO toca IDs
   - EXCLUYE menú hamburguesa / drawer
   - Aplica desde "Eres colaborador" hasta "Enviar mensaje"
========================================================= */

:root{
  --btn-ref-bg-top: #6B86CC;
  --btn-ref-bg-bottom: #5D77BE;
  --btn-ref-border: #4A62A8;
  --btn-ref-border-2: #7E98DA;
  --btn-ref-text: #F6F9FF;
  --btn-ref-text-shadow: rgba(52, 68, 125, .9);
}

/* Base: links/botones visibles del contenido + CTA header (NO menú hamburguesa) */
.header-controls .btn.btn-primary.btn-sm,
.back-btn,
a.btn-primary,
button.btn-primary[type="submit"],
a.btn-ghost,
.card-link{
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 44px;
  padding: 10px 16px !important;
  border-radius: 6px !important; /* más rectangular/cuadrado */
  border: 1px solid var(--btn-ref-border) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.18), rgba(255,255,255,0) 38%),
    linear-gradient(180deg, var(--btn-ref-bg-top), var(--btn-ref-bg-bottom)) !important;
  color: var(--btn-ref-text) !important;
  text-decoration: none !important;
  font-weight: 800 !important;
  line-height: 1.1;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.22),
    inset 0 -1px 0 rgba(38,52,102,.22),
    0 1px 0 var(--btn-ref-border-2),
    0 6px 14px rgba(43, 59, 115, .18) !important;
  text-shadow: 0 1px 0 var(--btn-ref-text-shadow);
  transition: transform .16s ease, filter .16s ease, box-shadow .16s ease;
  cursor: pointer;
}

/* Ajustes por tipo */
.header-controls .btn.btn-primary.btn-sm{
  min-height: 40px;
  padding: 9px 14px !important;
  border-radius: 6px !important;
}

.card-link{
  min-height: 40px;
  padding: 9px 14px !important;
  gap: 8px !important;
  margin-top: 4px;
}

/* SVG/iconos dentro de botones */
.back-btn svg,
a.btn-primary svg,
button.btn-primary[type="submit"] svg,
a.btn-ghost svg,
.card-link svg{
  width: 18px !important;
  height: 18px !important;
  color: currentColor !important;
  opacity: .98;
  filter: drop-shadow(0 1px 0 rgba(52,68,125,.45));
}

/* Hover / focus / active: mantener mismo look (sin ovalados ni estilos previos) */
.header-controls .btn.btn-primary.btn-sm:hover,
.back-btn:hover,
a.btn-primary:hover,
button.btn-primary[type="submit"]:hover,
a.btn-ghost:hover,
.card-link:hover{
  transform: translateY(-1px) !important;
  filter: brightness(1.03);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.24),
    inset 0 -1px 0 rgba(38,52,102,.26),
    0 1px 0 var(--btn-ref-border-2),
    0 8px 16px rgba(43, 59, 115, .22) !important;
  color: var(--btn-ref-text) !important;
  text-decoration: none !important;
  gap: 10px !important; /* neutraliza animación de .card-link */
}

.header-controls .btn.btn-primary.btn-sm:active,
.back-btn:active,
a.btn-primary:active,
button.btn-primary[type="submit"]:active,
a.btn-ghost:active,
.card-link:active{
  transform: translateY(0) !important;
  filter: brightness(.98);
  box-shadow:
    inset 0 1px 2px rgba(33,44,88,.32),
    0 1px 0 var(--btn-ref-border-2) !important;
}

/* Respetamos layout actual; sólo estética. */
@media (max-width: 768px){
  a.btn-primary,
  button.btn-primary[type="submit"],
  a.btn-ghost{
    border-radius: 6px !important;
  }
}


/* =========================================================
   PATCH FINAL 2026-02-24b — Botones planos exactos + menú más cuadrado
   Objetivo:
   - Botones tipo referencia "Conocer más" (plano, 2 tonos, sin efecto 3D)
   - Texto blanco exacto en botones
   - Mantener IDs y HTML intactos
   - Menú hamburguesa / drawer con esquinas menos ovaladas
   ESTE BLOQUE DEBE QUEDAR AL FINAL ABSOLUTO
========================================================= */

:root{
  --btn-flat-main: #5B75B6;   /* color base detectado de la referencia */
  --btn-flat-side: #4F66AE;   /* franja izquierda más oscura */
  --btn-flat-text: #FFFFFF;
  --btn-flat-radius: 3px;     /* más cuadrado/rectangular */
  --btn-flat-h: 44px;
}

/* 1) BOTONES DEL SITIO (EXCLUYE botón hamburguesa y links del drawer)
   - "Eres colaborador"
   - Hero CTA / CTA section
   - Volver a servicios
   - Ver más (cards)
   - Enviar mensaje (submit)
*/
.header-controls .btn.btn-primary.btn-sm,
main .back-btn,
main a.btn-primary,
main button.btn-primary,
main a.btn-ghost,
main button.btn-ghost,
main .card-link{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;

  min-height: var(--btn-flat-h) !important;
  padding: 10px 16px !important;
  border-radius: var(--btn-flat-radius) !important;

  /* look plano (sin brillo/3D), con franja izquierda */
  background: linear-gradient(90deg, var(--btn-flat-side) 0 16%, var(--btn-flat-main) 16% 100%) !important;
  background-image: linear-gradient(90deg, var(--btn-flat-side) 0 16%, var(--btn-flat-main) 16% 100%) !important;
  border: 0 !important;
  box-shadow: none !important;
  text-shadow: none !important;
  filter: none !important;

  color: var(--btn-flat-text) !important;
  text-decoration: none !important;
  font-weight: 800 !important;
  line-height: 1.05 !important;
  letter-spacing: 0 !important;

  transform: none !important;
  transition: background-color .12s ease, opacity .12s ease !important;
  overflow: hidden !important;
  cursor: pointer !important;
}

/* ajuste de tamaños para botones pequeños */
.header-controls .btn.btn-primary.btn-sm{
  min-height: 40px !important;
  padding: 8px 14px !important;
  border-radius: 3px !important;
  font-size: 14px !important;
}

main .card-link{
  min-height: 40px !important;
  padding: 8px 14px !important;
  gap: 8px !important;
}

/* Quita brillo/shimmer heredado */
.header-controls .btn.btn-primary.btn-sm::before,
main .btn-primary::before,
main .btn-ghost::before,
main .back-btn::before{
  content: none !important;
  display: none !important;
}

/* Iconos dentro de botones: sin animación ni sombras */
main .back-btn svg,
main a.btn-primary svg,
main button.btn-primary svg,
main a.btn-ghost svg,
main button.btn-ghost svg,
main .card-link svg{
  width: 18px !important;
  height: 18px !important;
  color: #FFFFFF !important;
  stroke: currentColor !important;
  filter: none !important;
  opacity: 1 !important;
  transform: none !important;
}

/* Hover/Focus/Active: mantener look plano (sin levantar, sin glow) */
.header-controls .btn.btn-primary.btn-sm:hover,
.header-controls .btn.btn-primary.btn-sm:focus-visible,
.header-controls .btn.btn-primary.btn-sm:active,
main .back-btn:hover,
main .back-btn:focus-visible,
main .back-btn:active,
main a.btn-primary:hover,
main a.btn-primary:focus-visible,
main a.btn-primary:active,
main button.btn-primary:hover,
main button.btn-primary:focus-visible,
main button.btn-primary:active,
main a.btn-ghost:hover,
main a.btn-ghost:focus-visible,
main a.btn-ghost:active,
main button.btn-ghost:hover,
main button.btn-ghost:focus-visible,
main button.btn-ghost:active,
main .card-link:hover,
main .card-link:focus-visible,
main .card-link:active{
  background: linear-gradient(90deg, var(--btn-flat-side) 0 16%, var(--btn-flat-main) 16% 100%) !important;
  background-image: linear-gradient(90deg, var(--btn-flat-side) 0 16%, var(--btn-flat-main) 16% 100%) !important;
  color: #FFFFFF !important;
  border: 0 !important;
  box-shadow: none !important;
  text-shadow: none !important;
  filter: none !important;
  transform: none !important;
  opacity: .98;
  text-decoration: none !important;
  gap: 10px !important; /* neutraliza animaciones previas */
  outline: none !important;
}

/* 2) MENÚ HAMBURGUESA (FORMA más cuadrada / menos ovalada)
   - solo corrige radios + apariencia plana
   - no cambia IDs ni comportamiento JS
*/

/* Botón hamburguesa del header */
.menu-toggle{
  border-radius: 8px !important;
  width: 40px !important;
  height: 40px !important;
  padding: 0 !important;
  box-shadow: none !important;
}

/* En móvil muy pequeño mantenemos compacto pero cuadrado */
@media (max-width: 980px){
  .menu-toggle{
    width: 36px !important;
    height: 36px !important;
    border-radius: 8px !important;
  }
}

/* Botón cerrar del drawer */
#mobile-menu .close-menu{
  border-radius: 8px !important;
  width: 40px !important;
  height: 40px !important;
  box-shadow: none !important;
}

/* Botones del menú lateral (Inicio, Servicios, etc.) */
#mobile-menu .mobile-nav-link,
#mobile-menu .mobile-nav-summary{
  border-radius: 8px !important;
  box-shadow: none !important;
}

/* Sub-links del menú lateral (Procesamiento de nómina, etc.) */
#mobile-menu .mobile-sub-link{
  border-radius: 8px !important;
  box-shadow: none !important;
}

/* Opciones de idioma (por si se ven ovaladas en tu header) */
.language-btn{
  border-radius: 8px !important;
  box-shadow: none !important;
}
.language-option{
  border-radius: 8px !important;
}

/* Quita "levantamiento" visual del menú/drawer si alguna regla previa lo aplica */
.menu-toggle:hover,
.menu-toggle:active,
#mobile-menu .close-menu:hover,
#mobile-menu .close-menu:active,
#mobile-menu .mobile-nav-link:hover,
#mobile-menu .mobile-nav-summary:hover,
#mobile-menu .mobile-sub-link:hover{
  transform: none !important;
  box-shadow: none !important;
}

/* =========================================================
   PATCH FINAL 2026-02-24c — Quitar franjas (botones + títulos)
   - Elimina la franja lateral de color en TODOS los botones estilizados
   - Elimina franjas/subrayados azules decorativos en títulos solicitados
   - No toca IDs / HTML / JS
========================================================= */

:root{
  --btn-flat-solid: #5B75B6;  /* azul del botón (sin franja) */
  --btn-flat-solid-hover: #5B75B6; /* mismo color para evitar efecto visual */
  --btn-flat-solid-text: #FFFFFF;
}

/* 1) BOTONES: quitar franja izquierda (gradiente) y dejar color plano */
.header-controls .btn.btn-primary.btn-sm,
main .back-btn,
main a.btn-primary,
main button.btn-primary,
main button.btn-primary[type="submit"],
main a.btn-ghost,
main button.btn-ghost,
main .card-link,
main .pill-cta{
  background: var(--btn-flat-solid) !important;
  background-image: none !important;
  color: var(--btn-flat-solid-text) !important;
  border: 0 !important;
  box-shadow: none !important;
  text-shadow: none !important;
  filter: none !important;
}

.header-controls .btn.btn-primary.btn-sm:hover,
.header-controls .btn.btn-primary.btn-sm:focus-visible,
.header-controls .btn.btn-primary.btn-sm:active,
main .back-btn:hover,
main .back-btn:focus-visible,
main .back-btn:active,
main a.btn-primary:hover,
main a.btn-primary:focus-visible,
main a.btn-primary:active,
main button.btn-primary:hover,
main button.btn-primary:focus-visible,
main button.btn-primary:active,
main button.btn-primary[type="submit"]:hover,
main button.btn-primary[type="submit"]:focus-visible,
main button.btn-primary[type="submit"]:active,
main a.btn-ghost:hover,
main a.btn-ghost:focus-visible,
main a.btn-ghost:active,
main button.btn-ghost:hover,
main button.btn-ghost:focus-visible,
main button.btn-ghost:active,
main .card-link:hover,
main .card-link:focus-visible,
main .card-link:active,
main .pill-cta:hover,
main .pill-cta:focus-visible,
main .pill-cta:active{
  background: var(--btn-flat-solid-hover) !important;
  background-image: none !important;
  color: var(--btn-flat-solid-text) !important;
  border: 0 !important;
  box-shadow: none !important;
  text-shadow: none !important;
  filter: none !important;
  transform: none !important;
  opacity: 1 !important;
}

/* Neutraliza animaciones heredadas que generan "franja"/brillo en botones */
.header-controls .btn.btn-primary.btn-sm::before,
main .back-btn::before,
main .btn-primary::before,
main .btn-ghost::before,
main .card-link::before,
main .pill-cta::before,
.header-controls .btn.btn-primary.btn-sm::after,
main .back-btn::after,
main .card-link::after,
main .pill-cta::after{
  content: none !important;
  display: none !important;
  background: none !important;
}

/* Asegura color blanco del texto/iconos en botones */
.header-controls .btn.btn-primary.btn-sm,
main .back-btn,
main a.btn-primary,
main button.btn-primary,
main a.btn-ghost,
main button.btn-ghost,
main .card-link,
main .pill-cta,
main .back-btn svg,
main .btn-primary svg,
main .btn-ghost svg,
main .card-link svg,
main .pill-cta svg,
main .btn-ghost .icon,
main .btn-ghost i{
  color: #FFFFFF !important;
  stroke: currentColor !important;
}

/* 2) TÍTULOS: quitar franja azul decorativa */
.hero-title .grad::after,
.grad::after,
.section-title::after{
  content: none !important;
  display: none !important;
  background: none !important;
  width: 0 !important;
  height: 0 !important;
  opacity: 0 !important;
}

.hero-title:hover .grad::after{
  transform: none !important;
}

/* Si algún título tiene línea decorativa por box-shadow/border (extra patchs), neutralizar */
.hero-title .grad,
.section-title,
.section-title .grad2{
  box-shadow: none !important;
}
/* =========================================================
   DESIGN SYSTEM / LAYOUT TOKENS (GLOBAL)
   - No usa selectores por #id
   - Enfocado a sincronía: ancho / escala / spacing
   - Pegar al FINAL del CSS global (después de todo)
========================================================= */

:root{
  /* Container */
  --ds-container-max: 1100px;
  --ds-container-pad: clamp(18px, 3vw, 28px);

  /* Header + anchors */
  --ds-header-h: 74px;
  --ds-anchor-offset: 92px; /* header (74) + 18px */

  /* Secciones (ritmo vertical) */
  --ds-section-pad: clamp(70px, 7vw, 110px);

  /* Hero */
  --ds-hero-pt: 58px;
  --ds-hero-pb: 40px;
  --ds-hero-gap: clamp(26px, 4vw, 68px);

  /* Tipografía */
  --ds-h1: clamp(40px, 5.4vw, 70px);
  --ds-h2: clamp(34px, 4.4vw, 56px);
  --ds-sub: 15px;
}

/* Base */
html{ font-size: 16px; }
body{ line-height: 1.65; }

/* Normaliza el offset de anclas: usa SOLO scroll-margin (evita doble offset) */
html{ scroll-padding-top: 0px; } /* importante si alguna página ya traía scroll-padding */
section{ scroll-margin-top: var(--ds-anchor-offset); }

/* Tokens “puente” para páginas que ya usan estas variables */
:root{
  --header-h: var(--ds-header-h);
  --gutter: var(--ds-container-pad);
  --section-y: var(--ds-section-pad);
}

/* Contenedor estándar */
.container{
  width: 100%;
  max-width: var(--ds-container-max);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--ds-container-pad);
  padding-right: var(--ds-container-pad);
}

/* Ritmo vertical de secciones */
section,
.section{
  padding-top: var(--ds-section-pad);
  padding-bottom: var(--ds-section-pad);
}

/* Header fijo: contrato de altura */
.site-header{
  height: var(--ds-header-h);
}
.site-header .nav-shell{
  height: var(--ds-header-h);
}

/* Asegura que el primer bloque no quede debajo del header fijo */
body{
  padding-top: var(--ds-header-h);
}

/* HERO */
.section.hero,
.hero{
  padding-top: var(--ds-hero-pt);
  padding-bottom: var(--ds-hero-pb);
  min-height: calc(100vh - var(--ds-header-h));
  display: flex;
  align-items: center;
}

.hero-grid{
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: var(--ds-hero-gap);
  align-items: center;
}

@media (max-width: 860px){
  .hero-grid{ grid-template-columns: 1fr; }
  .section.hero, .hero{ min-height: auto; }
}

/* Grids tipo “Servicios / cards” */
.card-grid,
.services-grid,
.cards-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 32px;
}

@media (max-width: 980px){
  .card-grid,
  .services-grid,
  .cards-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px){
  .card-grid,
  .services-grid,
  .cards-grid{
    grid-template-columns: 1fr;
  }
}

/* Tipografía consistente */
.hero-title,
.hero h1{
  font-size: var(--ds-h1);
  line-height: 1.05;
}

.section-title{
  font-size: var(--ds-h2);
  line-height: 1.12;
}

.subtitle,
.hero-subtitle,
.section-subtitle{
  font-size: var(--ds-sub);
  line-height: 1.65;
}

@media (max-width: 520px){
  .hero-title,
  .hero h1{ font-size: 38px; }

  .section-title{ font-size: 28px; }

  .subtitle,
  .hero-subtitle,
  .section-subtitle{ font-size: 15px; }
}
/* ================================
   FIX: Anchor #contacto (desktop)
   Evita doble offset (scroll-padding + scroll-margin)
================================ */
html{
  scroll-padding-top: 0; /* apaga el offset global; nos quedamos con scroll-margin */
}

/* deja un solo offset (el correcto) */
section[id],
main[id]{
  scroll-margin-top: calc(var(--header-h) + 10px); /* antes: +24 */
}

/* ================================
   FIX: correo visible/completo
================================ */
.contact-direct .mail{
  max-width: 100%;
  padding-inline: 12px;

  /* evita recortes: */
  white-space: normal;
  overflow: visible;
  text-overflow: clip;

  /* el <a> es inline-flex: permitimos wrap real */
  flex-wrap: wrap;
  justify-content: center;
  text-align: center;
  line-height: 1.25;
}

.contact-direct .mail svg{
  flex: 0 0 auto;
}

/* ================================
   Compactar Contacto en PC
   (para que el correo quede visible “más arriba”)
================================ */
@media (min-width: 860px){
  .section.contact{
    padding-top: clamp(56px, 4vw, 86px);
    padding-bottom: clamp(56px, 4vw, 86px);
  }

  .contact-top{
    margin-bottom: clamp(18px, 2.2vw, 28px);
  }

  .contact-card{
    padding: clamp(18px, 2.4vw, 30px);
  }

  .form-grid{
    gap: clamp(14px, 2vw, 22px);
    margin-bottom: 18px;
  }

  .field textarea{
    min-height: 140px; /* antes: 180px */
  }

  .contact-direct{
    margin-top: clamp(14px, 2vw, 22px);
  }
}

/* =========================
   CONTACTO COMERCIAL
   - Título dividido: azul rey / negro
========================= */
.contact-commercial{
  width: min(940px, 100%);
  margin: clamp(26px, 4vw, 38px) auto 0;
}

.contact-commercial-card{
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(240px, .82fr);
  gap: clamp(22px, 3vw, 34px);
  align-items: stretch;
  padding: clamp(24px, 3.4vw, 38px);
  border-radius: var(--r-xl);
  background: linear-gradient(135deg,
    color-mix(in oklab, var(--surface2) 92%, transparent),
    color-mix(in oklab, var(--bg1) 82%, transparent)
  );
  border: 1px solid color-mix(in oklab, var(--stroke) 92%, transparent);
  box-shadow: var(--shadow-lg);
  position: relative;
  overflow: hidden;
}

.contact-commercial-card::before{
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top right,
    color-mix(in oklab, var(--accent3) 12%, transparent) 0%,
    transparent 42%
  );
  pointer-events: none;
}

.contact-commercial-info,
.contact-commercial-media{
  position: relative;
  z-index: 1;
}

.contact-commercial-info{
  min-width: 0;
}

.contact-commercial-badge{
  margin-bottom: 12px;
}

.contact-commercial-title{
  margin: 0 0 14px;
  font-family: var(--font-display);
  font-size: clamp(30px, 4.1vw, 48px);
  line-height: .98;
  letter-spacing: -0.04em;
}

.contact-commercial-title .split-blue,
.contact-commercial-title .split-black{
  display: block;
}

.contact-commercial-title .split-blue{
  color: #182389 !important;
  -webkit-text-fill-color: #182389 !important;
}

.contact-commercial-title .split-black{
  color: #000000 !important;
  -webkit-text-fill-color: #000000 !important;
  margin-top: .08em;
}

.contact-commercial-text{
  color: var(--muted);
  margin-bottom: 22px;
  max-width: 54ch;
}

.contact-commercial-data{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.contact-commercial-item{
  padding: 16px 18px;
  border-radius: 18px;
  background: color-mix(in oklab, var(--surface2) 84%, transparent);
  border: 1px solid color-mix(in oklab, var(--stroke) 90%, transparent);
  min-width: 0;
}

.contact-commercial-label{
  display: block;
  margin-bottom: 6px;
  font-size: var(--fs-small);
  font-weight: 800;
  color: var(--muted2);
  text-transform: uppercase;
  letter-spacing: .05em;
}

.contact-commercial-value,
.contact-commercial-link{
  margin: 0;
  font-weight: 800;
  color: var(--text);
  word-break: break-word;
}

.contact-commercial-link{
  text-decoration: none;
}

.contact-commercial-link:hover{
  color: var(--accent);
}

.contact-commercial-media{
  display: flex;
}

.contact-commercial-image-frame{
  width: 100%;
  min-height: clamp(260px, 32vw, 100%);
  border-radius: 28px;
  border: 1px solid color-mix(in oklab, var(--stroke) 90%, transparent);
  background: linear-gradient(180deg,
    color-mix(in oklab, var(--bg1) 96%, transparent),
    color-mix(in oklab, var(--surface2) 88%, transparent)
  );
  overflow: hidden;
  display: flex;
}

.contact-commercial-image-placeholder{
  width: 100%;
  display: grid;
  place-items: center;
  padding: 24px;
  text-align: center;
}

.contact-commercial-image-text{
  color: var(--muted2);
  font-weight: 800;
}

@media (max-width: 860px){
  .contact-commercial-card{
    grid-template-columns: 1fr;
  }

  .contact-commercial-data{
    grid-template-columns: 1fr;
  }

  .contact-commercial-image-frame{
    min-height: 240px;
  }
}
