/* ===== Header (sin variables) ===== */

/* === Editables rápidos del header ===
   Altura fija header:   78px
   Padding lateral:      16px
   Ancho container:      1200px
   Colores:              bordes #e2e8f0, fondo #fff con blur
   Tamaño logo:          95px (ancho y alto)
   Breakpoint desktop:   900px
*/

/* Header fijo en toda la página */
.site-header{
  position: fixed;           /* <-- antes: sticky */
  top: 0; left: 0; right: 0;
  z-index: 1000;             /* por encima del contenido */
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(6px);
  border-bottom: 1px solid #e2e8f0;
  overflow: visible;
}

.site-header__inner{
  max-width: 1200px;
  margin: 0 auto;

  /* Altura fija del header */
  height: 78px;

  /* Solo padding horizontal; sin padding vertical para que la altura no crezca */
  padding: 0 16px;

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

/* Marca */
.site-header__brand{
  display: inline-flex; align-items: center; gap: 12px;
  font-weight: 800; letter-spacing: .2px;
  height: 100%;
}
.site-header__logo{
  /* Tamaño del logo manual */
  width: 95px;
  height: 95px;
  /* Si tu logo no es cuadrado, podés usar height:auto; y jugar con width */
}
/* solo desktop (≥900px): sube un poco */
@media (min-width: 900px){
  .site-header__logo{
    transform: translateY(-6px); /* - = sube */
    /* o: position: relative; top: -6px; */
  }
}

/* Botón hamburguesa (mobile) */
.site-header__toggle{
  width: 42px; height: 42px;
  border-radius: 10px; border: 1px solid #e2e8f0;
  display: inline-flex; align-items: center; justify-content: center;
  flex-direction: column; gap: 5px; /* apila verticalmente */
}
.site-header__toggle-bar{
  width: 22px; height: 2px; background: #0f172a; border-radius: 2px;
}
.site-header__toggle:focus-visible{ outline: 2px solid #6d28d9; outline-offset: 2px; }

/* ===== Off-canvas (solo MOBILE) ===== */
.site-nav{
  position: fixed; inset: 0;
  pointer-events: none; visibility: hidden; /* cerrado por defecto */
  z-index: 60;
}

/* Fondo oscurecido (valor base; en mobile lo sobreescribimos abajo) */
.offcanvas__overlay{
  position: absolute; inset: 0;
  background: rgba(15,23,42,.45);
  opacity: 0; transition: opacity .25s ease;
}

/* Panel lateral derecho (drawer) */
.offcanvas__panel{
  position: absolute; top: 0; right: 0;
  width: 86vw; max-width: 420px; height: 100vh;
  background: #ffffff; border-left: 1px solid #e2e8f0;
  box-shadow: 0 6px 20px rgba(2,6,23,.08);
  transform: translateX(100%); transition: transform .25s ease;
  display: grid; grid-template-rows: auto 1fr;
  padding: 16px;
}

/* Header del panel */
.offcanvas__header{
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  padding-bottom: 8px; border-bottom: 1px solid #e2e8f0;
}
.offcanvas__title{ font-weight: 700; }
.offcanvas__close{
  width: 36px; height: 36px; border-radius: 10px; border: 1px solid #e2e8f0;
}

/* Lista dentro del panel (mantengo tus clases) */
.site-nav__list{ padding: 12px 0; display: grid; gap: 8px; overflow: auto; }
.site-nav__link{ display: block; padding: 10px 12px; border-radius: 10px; font-weight: 600; }
.site-nav__link:hover{ background: #f8fafc; }
.site-nav__item--cta .btn{ width: 100%; }

/* Estado ABIERTO */
.site-nav.is-open{ pointer-events: auto; visibility: visible; }
.site-nav.is-open .offcanvas__overlay{ opacity: 1; }
.site-nav.is-open .offcanvas__panel{ transform: translateX(0); }

/* ===== Desktop (≥900px) — nav horizontal y centrada, sin “Menú” ni botón X ===== */
@media (min-width: 900px){
  /* ocultar el botón hamburguesa en desktop */
  .site-header__toggle{ display: none; }

  /* layout del header: brand a la izquierda, nav en el ancho disponible */
  .site-header__inner{
    display: grid;
    grid-template-columns: auto 1fr; /* brand | nav */
    align-items: center;
  }

  /* el nav se muestra normal y CENTRADO dentro del header */
  .site-nav{
    position: static; inset: auto; pointer-events: auto; visibility: visible;
    justify-self: center;                 /* <- centra el bloque de navegación */
  }

  /* el panel del off-canvas se “desarma” visualmente */
  .offcanvas__overlay{ display: none; }
  .offcanvas__panel{
    position: static; transform: none; height: auto; width: auto; max-width: none;
    border: 0; box-shadow: none; padding: 0; background: transparent; display: block;
  }
  /* oculta el encabezado y la botonera del panel en desktop */
  .offcanvas__header,
  .offcanvas__actions{ display: none; }

  /* lista horizontal (lo que ya tenías) */
  .site-nav__list{ display: flex; align-items: center; gap: 20px; }
  .site-nav__link{ padding: 8px 10px; border-radius: 8px; font-weight: 500; color: #64748b; }
  .site-nav__link:hover{ background: #f8fafc; color: #0f172a; }
  .site-nav__item--cta .btn{ width: auto; }
}

/* compacta el panel y la lista en MOBILE */
.offcanvas__panel{ padding: 12px; }                   /* antes 16px */
.site-nav__list{ gap: 4px; }                          /* antes 8px */
.site-nav__link{ padding: 10px 10px; }                /* un pelín más cerrado */

/* ===== Layout base de secciones ===== */
.container{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
}
.section{
  padding: 48px 0;
}
.section--alt{
  background: #f8fafc;
}
.section__title{
  font-size: 28px;
  line-height: 1.2;
  margin: 0 0 16px;
}

/* ===== HERO ===== */
.hero__grid{
  display: grid;
  gap: 24px;
}
.hero__title{
  font-size: 36px;
  line-height: 1.15;
  margin: 0 0 12px;
}
.hero__subtitle{
  margin: 0 0 16px;
  color: #64748b;
}
.hero__actions{ display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 8px; }
.hero__note{ font-size: 14px; color: #64748b; }

.hero__media{
  min-height: 220px;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  box-shadow: 0 6px 20px rgba(2, 6, 23, 0.06);
  background: linear-gradient(180deg,#ffffff, #f8fafc);
}

/* ===== CARDS GENERALES ===== */
.cards{
  display: grid;
  gap: 16px;
}
.card{
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  box-shadow: 0 6px 20px rgba(2, 6, 23, 0.06);
  padding: 16px;
}
.card--lite{
  background: #ffffff;
}
.card__title{
  margin: 0 0 8px;
  font-size: 18px;
}
.card__text{
  margin: 0;
  color: #64748b;
}

/* ===== SERVICIOS ===== */
.cards--services{ grid-template-columns: 1fr; }

/* ===== INDUSTRIAS ===== */
.cards--industries{ grid-template-columns: 1fr; }

/* ===== DIFERENCIALES ===== */
.bullets{
  display: grid; gap: 10px;
  padding: 0; margin: 0;
}
.bullets__item{
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #ffffff;
}
.bullets__check{
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: #6d28d9; color: #fff; font-weight: 700;
}

/* ===== FAQ ===== */
.faq{ display: grid; gap: 10px; }
.faq__item{
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #ffffff;
  padding: 8px 12px;
}
.faq__q{
  list-style: none;
  cursor: pointer;
  font-weight: 600;
}
.faq__q::-webkit-details-marker{ display: none; }
.faq__q::after{
  content: "▾";
  float: right;
  transition: transform .2s ease;
}
.faq__item[open] .faq__q::after{ transform: rotate(180deg); }
.faq__a{ color: #64748b; padding-top: 6px; }

/* ===== FORM ===== */
.form__grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.field--full{ grid-column: 1 / -1; }
.field__label{
  display: block;
  font-size: 14px;
  margin: 0 0 6px;
}
.field__input{
  width: 100%;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  padding: 10px 12px;
  font: inherit;
  color: #0f172a;
  background: #ffffff;
}
.field__input--area{ resize: vertical; }
.field__input:focus{ outline: 2px solid #6d28d9; outline-offset: 2px; }
.form__actions{ margin-top: 12px; }

/* ===== FOOTER ===== */
.site-footer{
  border-top: 1px solid #e2e8f0;
  background: #ffffff;
  padding: 24px 0;
}
.site-footer__inner{
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; flex-wrap: wrap;
}
.site-footer__copy{ margin: 0; color: #64748b; }
.site-footer__nav a{ color: #64748b; }
.site-footer__nav .dot{ margin: 0 8px; color: #e2e8f0; }

/* ===== Breakpoints (desktop) ===== */
@media (min-width: 900px){
  .section{ padding: 72px 0; }

  .hero__grid{
    grid-template-columns: 1.1fr .9fr;
    align-items: center;
  }
  .hero__title{ font-size: 48px; }

  .logos__grid{ grid-template-columns: repeat(6,1fr); }

  .cards--services{ grid-template-columns: repeat(4,1fr); }
  .cards--industries{ grid-template-columns: repeat(4,1fr); }
  .cards--cases{ grid-template-columns: repeat(3,1fr); }

  .form__grid{ grid-template-columns: repeat(2,1fr); }
  .field--full{ grid-column: 1 / 3; }
}

/* --- FIX: que la lista no “estire” filas y se pegue arriba --- */
.site-nav__list{ align-content: start; }

/* --- FIX: asegurar niveles y clickeabilidad --- */
.offcanvas__overlay{ z-index: 0; }
.offcanvas__panel{ z-index: 1; }   /* el panel siempre por arriba */

/* (si querés menos aire) */
.offcanvas__panel{ padding: 12px; }
.site-nav__list{ gap: 6px; }
.site-nav__link{ padding: 12px 12px; }

/* ====== MOBILE (≤899px): header visible, overlay sin tapar header, panel desde arriba ====== */
@media (max-width: 899.98px){
  /* el header siempre por arriba del overlay */
  .site-header{ z-index: 1000; }
  .site-nav{ z-index: 995; }

  /* overlay NO cubre el header (oscurece solo el contenido) */
  .offcanvas__overlay{
    position: absolute;
    left: 0; right: 0; bottom: 0;
    top: 78px;              /* <-- alto real de tu header */
    z-index: 996;
  }

  /* *** FIX: que NO se blanquee/oscurezca el contenido al abrir el menú *** */
  .site-nav.is-open .offcanvas__overlay{
    background: transparent;   /* sigue capturando clicks pero no tapa visualmente */
    opacity: 1;
  }

  /* opcional: scrim suave junto al panel para separar */
  .offcanvas__panel::before{
    content: "";
    position: absolute;
    top: 0; bottom: 0; left: -12px;
    width: 12px;
    background: linear-gradient(to left, rgba(2,6,23,.10), rgba(2,6,23,0));
    pointer-events: none;
  }

  /* el panel sale desde ARRIBA y pasa por encima del header */
  .offcanvas__panel{
    top: 0;
    height: 100vh;
    z-index: 1001;
    /* compactar un toque */
    padding: 12px;
  }

  .site-nav__list{ gap: 6px; }
  .site-nav__link{ padding: 12px 12px; }
}

/* ====== DESKTOP (≥900px): restaurar nav horizontal sin overlay/panel ====== */
@media (min-width: 900px){
  .offcanvas__overlay{ display: none; opacity: 0; }
  .offcanvas__panel{
    position: static; transform: none; top: auto; height: auto; width: auto; max-width: none;
    border: 0; box-shadow: none; padding: 0; background: transparent; display: block;
  }
}

/* ============ FORM PRO (scopeado) ============ */

/* Card contenedor */
.form--card{
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  box-shadow: 0 10px 30px rgba(2,6,23,.05);
  padding: 20px;
  margin-top: 6px;
}

/* Texto introductorio y legal */
.form__lead{
  margin: 0 0 10px;
  color: #64748b;
}
.form__actions{
  margin-top: 16px;
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
}
.form__legal{
  margin: 0;
  color: #64748b;
  font-size: 14px;
}

/* Campos */
.form--pro .field{ position: relative; }
.form--pro .field--required .field__label::after{
  content: " *"; color: #6d28d9; font-weight: 700;
}
.form--pro .field__label{
  display: block;
  font-size: 14px;
  margin: 0 0 6px;
  color: #0f172a;
}
.form--pro .field__hint{
  display: block; margin-top: 6px; color: #64748b; font-size: 13px;
}

/* Inputs */
.form--pro .field__input{
  width: 100%;
  height: 48px;
  line-height: 46px;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  padding: 0 14px;
  font: inherit;
  color: #0f172a; background: #fff;
  transition: box-shadow .15s ease, border-color .15s ease, background-color .15s ease;
}
.form--pro .field__input--area{
  min-height: 160px; height: auto; line-height: 1.45; padding: 12px 14px; resize: vertical;
}
.form--pro .field__input::placeholder{ color: #94a3b8; } /* slate-400 approx */

/* Focus + hover */
.form--pro .field__input:hover{ border-color: #cbd5e1; }
.form--pro .field__input:focus{
  outline: none;
  border-color: #6d28d9;
  box-shadow: 0 0 0 3px rgba(109,40,217,.18);
  background: #fff;
}
/* Enfasis del grupo al foco */
.form--pro .field:focus-within .field__label{ color: #6d28d9; }

/* Select estilizado (chevron) */
.form--pro .field__select{
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none' stroke='%2364748b' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'%3E%3Cpolyline points='6 8 10 12 14 8'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 20px;
  padding-right: 40px;
}

/* Estados de validación nativos (HTML5) */
.form--pro .field__input:required:invalid{ border-color: #fecaca; }     /* rojo-200 */
.form--pro .field__input:required:invalid:focus{ box-shadow: 0 0 0 3px rgba(239,68,68,.18); } /* rojo-500 */
.form--pro .field__input:valid{ border-color: #c7f9cc; }                 /* verde-200 suave */
.form--pro .field__input:valid:focus{ box-shadow: 0 0 0 3px rgba(34,197,94,.16); }            /* verde-500 */

/* Botón primario un poco más sólido en formularios */
.form--pro .btn.btn--primary{
  height: 46px; padding: 0 18px;
  border-radius: 14px;
}

/* Grid responsivo (ya tenías base; reforzamos tamaños) */
@media (min-width: 900px){
  .form--pro.form .form__grid{ grid-template-columns: 1fr 1fr; gap: 14px 18px; }
  .form--pro .field--full{ grid-column: 1 / 3; }
  .form--card{ padding: 24px 24px 20px; }
}

/* Honeypot oculto */
.hp{ position: absolute !important; left: -9999px; opacity: 0; height: 0; width: 0; }

/* ===== Teléfono con prefijo visual (+54) ===== */
.form--pro .field--phone{ position: relative; }
.form--pro .field--phone .field__prefix{
  position: absolute;
  top: 50%; left: 14px;
  transform: translateY(-50%);
  height: 28px; line-height: 28px;
  padding: 0 8px;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  background: #f8fafc;
  color: #64748b;
  pointer-events: none;      /* no interfiere con el input */
}
.form--pro .field--phone .field__input{
  padding-left: 64px;        /* deja espacio para el chip +54 */
}

/* ===== Trust bar ===== */
.trust__grid{
  display: grid; gap: 12px;
  grid-template-columns: 1fr 1fr;
}
.trust__item{
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  box-shadow: 0 6px 20px rgba(2,6,23,.04);
  padding: 12px 14px;
}
.trust__item strong{ display:block; margin-bottom: 4px; }
.trust__item span{ color:#64748b; font-size:14px; }

@media (min-width: 900px){
  .trust__grid{ grid-template-columns: repeat(4,1fr); }
}

/* CTA del header: oculto en mobile, visible en desktop */
.site-header__cta{
  display: none;             /* mobile */
  white-space: nowrap;
}

/* ===== Desktop header refinado (≥900px) ===== */
@media (min-width: 900px){
  /* 3 columnas: brand | nav centrada | CTA derecha */
  .site-header__inner{
    display: grid;
    grid-template-columns: auto 1fr auto;  /* IZQ | CENTRO | DER */
    align-items: center;
  }

  /* Menú centrado */
  .site-nav{ justify-self: center; }

  /* Separación un poco mayor entre items de nav */
  .site-nav__list{ gap: 28px; }            /* antes: 20px */

  /* CTA dentro del panel/menú: no se muestra en desktop */
  .site-nav__item--cta{ display: none; }

  /* CTA de header (afuera del nav): visible en desktop */
  .site-header__cta{ display: inline-flex; }

  /* Micro-ajustes de “look pro” */
  .site-nav__link{ font-weight: 600; }     /* un toque más marcado */
  .site-header__brand-text{ letter-spacing: .2px; font-weight: 800; }
}

/* Compensar la altura del header fijo */
main{ padding-top: 78px; }   /* 78px = altura de .site-header__inner */

/* Que las anclas (#seccion) no queden escondidas detrás del header */
:target{ scroll-margin-top: 90px; }



/* ===================== FIX DEFINITIVO OVERLAY (solo mobile) ===================== */
@media (max-width: 899.98px){
  /* El overlay sigue capturando el click, pero NO cubre visualmente el contenido */
  body .site-nav.is-open .offcanvas__overlay{
    background: transparent !important;
    opacity: 1 !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  /* Refuerzo de z-index para que no “aparezca” una lámina blanca entre panel y página */
  .offcanvas__overlay{ z-index: 996; }
  .offcanvas__panel{ z-index: 1001; }
}
/* Kicker + lead para secciones (estilo discreto y pro) */
.section__kicker{ 
  margin: 0 0 6px; font-size: 13px; letter-spacing: .12em; 
  text-transform: uppercase; color: #6d28d9; font-weight: 700;
}
.section__lead{
  margin: 6px 0 16px; color: #64748b;
}


/* === Brand tokens & typography (added) === */
:root{
  --brand-600: #6D28D9; /* default violet */
  --brand-700: #5B21B6;
  --accent-500: #7C3AED;
  --text-900: #0F172A;
  --text-600: #64748B;
  --border:   #E2E8F0;
  --surface:  #F8FAFC;
}
/* Optional blue theme: add class="theme-blue" to <body> to switch */
body.theme-blue{
  --brand-600: #1457D2;
  --brand-700: #0F48AD;
  --accent-500: #00A3FF;
}

body{ font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji"; }

/* Use tokens on key components without refactor */
.section__kicker{ color: var(--brand-600); }
.btn--primary{ background: var(--brand-600); }
.btn--primary:hover{ background: var(--brand-700); }
a{ color: var(--brand-600); }
a:hover{ color: var(--brand-700); }

/* === Reveal on scroll === */
.reveal{ opacity: 0; transform: translateY(14px); transition: opacity .45s ease, transform .45s ease; will-change: opacity, transform; }
.reveal.is-in{ opacity: 1; transform: none; }

/* Cards hover microinteraction */
.card{ transition: transform .18s ease, box-shadow .18s ease; }
.card:hover, .card:focus-within{ transform: translateY(-2px); box-shadow: 0 10px 30px rgba(2,6,23,.08); }

/* Header compressed state */
.site-header.is-scrolled{ box-shadow: 0 8px 26px rgba(2,6,23,.06); border-bottom-color: rgba(226,232,240,.8); }
.site-header.is-scrolled .site-header__inner{ height: 72px; }

/* Services & Industries grids centered and fluid */
.cards--services,
.cards--industries{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 320px));
  justify-content: center;
  gap: 18px;
}

/* Icon block in cards */
.card .card__icon{
  width: 44px; height: 44px; border-radius: 12px;
  display: grid; place-items: center;
  background: var(--surface);
  color: var(--brand-600);
  margin-bottom: 10px;
}

/* Form success alert */
.form__alert{
  margin: 10px 0 16px;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #f0fdf4;
  color: #166534;
  box-shadow: 0 6px 20px rgba(2,6,23,.04);
  font-weight: 600;
}

@media (prefers-reduced-motion: reduce){
  .reveal{ transition: none; transform: none !important; opacity: 1 !important; }
  .card{ transition: none; }
}

/* Header (desktop): afinar el CTA "Contacto" */
@media (min-width: 900px){
  .site-header .site-header__cta{
    height: 38px;          /* antes ~46px */
    padding: 0 14px;       /* menos gordito */
    border-radius: 10px;   /* opcional: menos "pill" */
    box-shadow: 0 4px 14px rgba(2,6,23,.06); /* sombra más liviana (opcional) */
  }
}
/* === Industrias: "ver más" y listado extra === */
.industries__morewrap{ margin-top: 10px; }
.industries__more{ width: auto; }

.industries__list{
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 8px;
}

.pill{
  display: inline-block;
  padding: 6px 10px;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 999px;
  background: #fff;
  color: var(--text-600, #64748b);
  font-size: 14px;
  white-space: nowrap;
}

/* ===== CTA del header: rayo + brillo de texto (desktop + mobile) ===== */

/* Sombras afinadas por tema */
:root{ --cta-shadow: rgba(109,40,217,.25); }           /* violeta (default) */
body.theme-blue{ --cta-shadow: rgba(20,87,210,.25); }  /* azul (opcional) */

/* base del botón (desktop y mobile) */
.site-header .site-header__cta,
.site-nav__item--cta .btn{
  position: relative;
  overflow: hidden;                 /* necesario para el rayo */
  isolation: isolate;               /* que el pseudo no “escape” */
  transition:
    transform .18s ease,
    box-shadow .25s ease,
    background-color .25s ease,
    text-shadow .25s ease;
}

/* Mantener color estable en hover (no oscurecer todo) */
.site-header .site-header__cta.btn--primary:hover,
.site-nav__item--cta .btn.btn--primary:hover{
  background: var(--brand-600, #6D28D9);
}

/* “Rayo” que cruza: usa mezcla SCREEN para iluminar */
.site-header .site-header__cta::before,
.site-nav__item--cta .btn::before{
  content: "";
  position: absolute; inset: -20% -40%;
  background: linear-gradient(120deg,
    rgba(255,255,255,0) 30%,
    rgba(255,255,255,.45) 50%,
    rgba(255,255,255,0) 70%);
  transform: translateX(-120%) rotate(0.001deg);
  transition: transform .7s cubic-bezier(.2,.6,.2,1), opacity .3s ease;
  opacity: .85;                      /* visible pero no “lava” todo */
  mix-blend-mode: screen;            /* ← clave: aclara lo de abajo */
  will-change: transform;
  pointer-events: none;
  z-index: 0;
}

/* Al hover/focus: el rayo cruza suavemente */
.site-header .site-header__cta:hover::before,
.site-header .site-header__cta:focus-visible::before,
.site-nav__item--cta .btn:hover::before,
.site-nav__item--cta .btn:focus-visible::before{
  transform: translateX(120%) rotate(0.001deg);
}

/* Halo sutil + lift, y texto con brillo */
.site-header .site-header__cta:hover,
.site-header .site-header__cta:focus-visible,
.site-nav__item--cta .btn:hover,
.site-nav__item--cta .btn:focus-visible{
  box-shadow: 0 8px 24px var(--cta-shadow);
  transform: translateY(-1px);
  text-shadow:
    0 0 12px rgba(255,255,255,.75),
    0 0 2px  rgba(255,255,255,.75);
}

/* Accesibilidad: respeta “reducir movimiento” */
@media (prefers-reduced-motion: reduce){
  .site-header .site-header__cta::before,
  .site-nav__item--cta .btn::before{ display: none; }
  .site-header .site-header__cta,
  .site-nav__item--cta .btn{
    transition: none;
    transform: none !important;
    text-shadow: none !important;
  }
}
/* ===== Logo header: pop sutil + latido en hover (desktop + mobile) ===== */

/* variable de offset (0 en mobile, -6px en desktop) */
.site-header__logo{ --logo-ty: 0px; }

@media (min-width: 900px){
  /* En tu CSS ya movés el logo -6px: lo preservamos vía variable */
  .site-header__logo{ --logo-ty: -6px; } /* coincide con tu regla actual */
}

/* Estado base: un toque de “pop” y sombra suave */
.site-header__brand{ position: relative; }
.site-header__logo{
  transform: translateY(var(--logo-ty)) scale(1.02);
  transition: transform .25s ease, filter .25s ease;
  filter: drop-shadow(0 2px 10px rgba(2,6,23,.06));
  will-change: transform, filter;
}

/* Latido mientras hay hover/focus */
@keyframes logo-beat {
  0%, 100% {
    transform: translateY(var(--logo-ty)) scale(1.02);
    filter: drop-shadow(0 6px 18px rgba(109,40,217,.18));
  }
  50% {
    transform: translateY(var(--logo-ty)) scale(1.06);
    filter: drop-shadow(0 10px 28px rgba(109,40,217,.28));
  }
}

.site-header__brand:hover .site-header__logo,
.site-header__brand:focus-visible .site-header__logo{
  animation: logo-beat 900ms ease-in-out infinite;
}

/* Mobile/touch: animación de 1 ciclo al tocar (se activa con JS) */
.site-header__brand.is-pulsing .site-header__logo{
  animation: logo-beat 900ms ease-in-out 1;
}

/* Accesibilidad */
@media (prefers-reduced-motion: reduce){
  .site-header__logo{ transition: none; animation: none !important; }
}

/* Teléfono: prefijo editable dentro del input (sin chip fijo) */
.form--pro .field--phone .field__prefix{ display: none; }
.form--pro .field--phone .field__input{ padding-left: 14px; } /* antes 64px por el chip */
/* HERO con imagen: sin deformación y bien encuadrada */
.hero__media{
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 10;          /* relación estable en desktop */
  /* tu borde/sombra/fondo pueden quedar, irán detrás de la foto */
}
.hero__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;               /* ← clave: NO se deforma */
  object-position: 42% 50%;        /* un pelín hacia la izquierda para centrar caras */
  display: block;
  border-radius: inherit;
}

/* Layout del hero en desktop: texto | imagen */
@media (min-width: 900px){
  .hero__grid{
    display: grid;
    gap: 24px;
    grid-template-columns: 1.1fr 1fr;  /* texto un poco más ancho */
    align-items: center;
  }
}

/* En mobile, deja altura mínima y quita aspect-ratio rígido */
@media (max-width: 899.98px){
  .hero__media{ aspect-ratio: auto; min-height: 220px; }
}
/* === Industrias: layout prolijo del "ver más" === */

/* Botón + listado en la misma línea cuando hay espacio */
.industries__morewrap{
  display: inline-flex;       /* se “achica” al contenido y no ocupa todo el ancho */
  flex-wrap: wrap;            /* baja a otra línea si no entra */
  align-items: center;
  column-gap: 12px;           /* espacio horizontal entre botón y pills */
  row-gap: 8px;               /* espacio vertical cuando envuelve */
  margin-top: 10px;
}

/* El botón no debe estirarse */
.industries__more{ width: auto; }

/* Listado de pills: sin celdas vacías ni columnas ficticias */
.industries__list{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 0;              /* ya hay separación vía row-gap arriba */
}

/* Pill compacta y alineada */
.pill{
  display: inline-flex;
  align-items: center;
  height: 36px;
  padding: 0 12px;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 999px;
  background: #fff;
  color: var(--text-600, #64748b);
  font-size: 14px;
  line-height: 1;             /* evita que “salte” la altura */
  white-space: nowrap;
}

/* (Opcional) un separador fino para diferenciar el bloque del grid de cards */
#industrias .industries__morewrap{
  padding-top: 6px;
  border-top: 1px solid rgba(226,232,240,.6);
}
/* ===== Divisores entre secciones ===== */
.section{ position: relative; }

/* a) Divisor global (entre cualquier sección y la siguiente) */
.section + .section::before{
  content:"";
  position: absolute; inset: 0 0 auto 0;  /* top line */
  height: 1px;
  /* línea que se desvanece hacia los lados, elegante */
  background: linear-gradient(90deg,
    rgba(226,232,240,0) 0%,
    var(--border, #E2E8F0) 12%,
    var(--border, #E2E8F0) 88%,
    rgba(226,232,240,0) 100%);
}

/* b) Variante más marcada con color de marca (usar en secciones puntuales) */
.section.section--divider-strong::before{
  height: 2px;
  background: linear-gradient(90deg,
    rgba(109,40,217,0) 0%,
    var(--brand-600, #6D28D9) 16%,
    var(--brand-600, #6D28D9) 84%,
    rgba(109,40,217,0) 100%);
}

/* c) Si preferís que la línea quede alineada a la "container" (no a todo el ancho) */
.section.section--divider-inner > .container{ position: relative; }
.section.section--divider-inner > .container::before{
  content:"";
  position: absolute; left: 0; right: 0; top: -1px;
  height: 1px;
  background: var(--border, #E2E8F0);
  opacity: .8;
}

/* d) Para ocultar el divisor en secciones puntuales */
.section.section--no-divider::before,
.section.section--no-divider > .container::before{ display: none; }

.brand-strip{
  border-top: 1px solid #e2e8f0; border-bottom: 1px solid #e2e8f0; background:#fff;
}
.brand-strip__inner{
  display:flex; align-items:center; justify-content:flex-end; gap:12px; padding:10px 16px;
}
.brand-strip__label{ color:#64748b; font-weight:600; }
.brand-strip__logo{ height:24px; }
@media (min-width:900px){ .brand-strip__logo{ height:28px; } }
/* === Tema Odoo (usa los colores oficiales de Brand Assets) === */


/* === Odoo palette override: scope by class on any container or <body> === */


.brand-strip__logo{ height:24px; min-height:20px; }
@media (min-width:900px){ .brand-strip__logo{ height:28px; }}

/* Partner badge tweaks (keeps same height as other logos) */
.brand-strip__logo--partner{ filter: none; vertical-align: middle; }


/* enforce tokens on primary buttons (wins over earlier base.css rules) */
.btn.btn--primary{ background: var(--brand-600); border-color: transparent; color: #fff; }
.btn.btn--primary:hover{ background: var(--brand-700); }
a{ color: var(--brand-600); }
a:hover{ color: var(--brand-700); }


/* Odoo palette overrides for form focus */
.form--pro .field__input:focus{
  border-color: var(--brand-600);
  box-shadow: 0 0 0 3px rgba(113, 75, 103, .18);
  background: #fff;
}
.form--pro .field:focus-within .field__label{ color: var(--brand-600); }
.form--pro .field--required .field__label::after{ color: var(--brand-600); }

.brand-strip__inner{ display:flex; align-items:center; gap:12px; }

