/* ── GOOGLE FONTS ────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800&display=swap');

/* ============================================================
   INFOTRAC — Design Tokens
   HubSpot Theme: infotrac-hubspot-theme
   Quinto Piso · v1.0 · Marzo 2026
   ============================================================

   CÓMO USAR:
   Importa este archivo al inicio de cada module.css:
     @import "../../css/theme-tokens.css";

   O úsalo como el primer CSS del tema en theme.json.
   Todos los módulos deben referenciar estas variables,
   NUNCA valores hardcoded de color o tipografía.
   ============================================================ */

:root {

  /* ── COLORES PRIMARIOS ─────────────────────────────────── */
  --color-navy:          #0b2545;   /* Pantone 534C — fondo oscuro, nav, footer */
  --color-white:         #FFFFFF;   /* Blanco — fondos claros, texto sobre oscuro */

  /* ── COLORES SECUNDARIOS / ACENTO ─────────────────────── */
  --color-teal-light:    #9bd9d8;   /* Pantone 324C — fondos alternos, highlights suaves */
  --color-teal-dark:     #51a79c;   /* Pantone 7472C — íconos activos, bordes de acento */
  --color-lime:          #d6df20;   /* Pantone 388C — métricas, badges, elementos de energía */
  --color-purple:        #6459C4;   /* Pantone 2725C — CTA primario, links activos */

  /* ── COLORES DE UI / NEUTROS ───────────────────────────── */
  --color-gray-100:      #F4F6F8;   /* Fondo de secciones alternas */
  --color-gray-200:      #E8EBF0;   /* Bordes, separadores */
  --color-gray-400:      #9AA3B2;   /* Texto secundario, labels */
  --color-gray-700:      #3D4554;   /* Texto cuerpo sobre fondo claro */
  --color-gray-900:      #1A1E2E;   /* Texto principal oscuro */

  /* ── ALIASES SEMÁNTICOS ────────────────────────────────── */
  --color-bg-primary:    var(--color-white);
  --color-bg-dark:       var(--color-navy);
  --color-bg-subtle:     var(--color-gray-100);
  --color-text-primary:  var(--color-gray-900);
  --color-text-secondary:var(--color-gray-400);
  --color-text-on-dark:  var(--color-white);
  --color-text-on-dark-muted: rgba(255,255,255,0.7);
  --color-border:        var(--color-gray-200);
  --color-cta-primary:   var(--color-purple);
  --color-cta-hover:     #5148B0;   /* Purple ligeramente más oscuro para hover */
  --color-accent:        var(--color-teal-dark);
  --color-highlight:     var(--color-lime);

  /* ── TIPOGRAFÍA — FAMILIAS ─────────────────────────────── */
  --font-heading:        'Poppins', sans-serif;         /* Títulos H1–H4, CTAs */
  --font-body:           'Poppins', sans-serif;         /* Cuerpo de texto */
  --font-label:          'Poppins', sans-serif;         /* Eyebrows, labels, badges */

  /* ── TIPOGRAFÍA — PESOS ────────────────────────────────── */
  --font-weight-regular:  400;
  --font-weight-medium:   500;
  --font-weight-semibold: 600;
  --font-weight-bold:     700;
  --font-weight-extrabold:800;

  /* ── TIPOGRAFÍA — ESCALA DESKTOP ───────────────────────── */
  --font-size-h1:        clamp(40px, 5vw, 64px);   /* Hero headline */
  --font-size-h2:        clamp(28px, 3.5vw, 48px); /* Section titles */
  --font-size-h3:        clamp(18px, 2vw, 24px);   /* Card titles */
  --font-size-h4:        18px;
  --font-size-body-lg:   18px;                      /* Intro / descripción */
  --font-size-body:      16px;                      /* Párrafos normales */
  --font-size-body-sm:   14px;
  --font-size-label:     12px;                      /* Eyebrows / badges */
  --font-size-cta:       15px;

  /* ── LINE HEIGHTS ──────────────────────────────────────── */
  --line-height-heading: 1.15;
  --line-height-body:    1.65;
  --line-height-tight:   1.1;

  /* ── LETTER SPACING ────────────────────────────────────── */
  --letter-spacing-tight:  -0.02em;
  --letter-spacing-normal:  0;
  --letter-spacing-label:   0.1em;   /* Eyebrows en mayúsculas */

  /* ── ESPACIADO — Sistema de 8px ────────────────────────── */
  --space-1:    4px;
  --space-2:    8px;
  --space-3:    12px;
  --space-4:    16px;
  --space-5:    24px;
  --space-6:    32px;
  --space-7:    40px;
  --space-8:    48px;
  --space-9:    64px;
  --space-10:   80px;
  --space-11:   96px;
  --space-12:  120px;

  /* ── PADDING DE SECCIONES ──────────────────────────────── */
  --section-padding-y:          var(--space-10);   /* 80px desktop */
  --section-padding-y-lg:       var(--space-12);   /* 120px hero/cta */
  --section-padding-x:          var(--space-6);    /* 32px lateral contenedor */

  /* ── CONTENEDOR ────────────────────────────────────────── */
  --container-max-width:        1200px;
  --container-padding:          var(--space-6);

  /* ── BORDES ─────────────────────────────────────────────── */
  --border-radius-sm:   4px;
  --border-radius-md:   8px;
  --border-radius-lg:   12px;
  --border-radius-xl:   20px;
  --border-radius-pill: 999px;

  /* ── SOMBRAS ────────────────────────────────────────────── */
  --shadow-sm:    0 1px 3px rgba(0,0,0,0.08);
  --shadow-md:    0 4px 16px rgba(0,0,0,0.10);
  --shadow-lg:    0 8px 32px rgba(0,0,0,0.12);
  --shadow-card:       0 2px 12px rgba(11,37,69,0.08);
  --shadow-card-hover: 0 8px 32px rgba(11,37,69,0.16);

  /* ── TRANSICIONES ───────────────────────────────────────── */
  --transition-fast:   150ms ease;
  --transition-base:   250ms ease;
  --transition-slow:   400ms ease;

  /* ── BOTONES ────────────────────────────────────────────── */
  --btn-padding-y:       12px;
  --btn-padding-x:       28px;
  --btn-padding-y-sm:    8px;
  --btn-padding-x-sm:    20px;
  --btn-border-radius:   var(--border-radius-pill);
  --btn-font-size:       var(--font-size-cta);
  --btn-font-weight:     var(--font-weight-semibold);

  /* ── GRID / LAYOUT ──────────────────────────────────────── */
  --grid-gap:        var(--space-6);   /* Gap entre cards en grids */
  --grid-gap-sm:     var(--space-4);
}

/* ── BREAKPOINTS (para referencia en media queries) ─────────
   Se definen como comentario porque CSS vars no funcionan
   en media queries, pero los módulos deben usarlos como guía:

   Mobile:   < 768px
   Tablet:   768px – 1023px
   Desktop:  ≥ 1024px
   Wide:     ≥ 1280px
   ─────────────────────────────────────────────────────────── */


/* ── RESET MÍNIMO ────────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
}

/* ── CLASES UTILITARIAS GLOBALES ─────────────────────────── */

/* Contenedor central */
.it-container {
  max-width: var(--container-max-width);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--container-padding);
  padding-right: var(--container-padding);
}

/* Eyebrow / label de sección */
.it-eyebrow {
  display: inline-block;
  font-family: var(--font-label);
  font-size: var(--font-size-label);
  font-weight: var(--font-weight-medium);
  letter-spacing: var(--letter-spacing-label);
  text-transform: uppercase;
  color: var(--color-teal-dark);
}

.it-eyebrow--light {
  color: var(--color-teal-light);
}

/* Botón primario (morado relleno) */
.it-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--btn-padding-y) var(--btn-padding-x);
  border-radius: var(--btn-border-radius);
  font-family: var(--font-heading);
  font-size: var(--btn-font-size);
  font-weight: var(--btn-font-weight);
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
  transition: background-color var(--transition-base),
              color var(--transition-base),
              border-color var(--transition-base),
              transform var(--transition-fast);
  white-space: nowrap;
  border: 2px solid transparent;
}

.it-btn:hover {
  transform: translateY(-1px);
}

/* Variante: CTA primario morado */
.it-btn--primary,
a.it-btn--primary,
a.it-btn--primary:link,
a.it-btn--primary:visited {
  background-color: var(--color-cta-primary) !important;
  color: var(--color-white) !important;
  border-color: var(--color-cta-primary) !important;
  text-decoration: none !important;
}

.it-btn--primary:hover,
a.it-btn--primary:hover {
  background-color: var(--color-cta-hover) !important;
  border-color: var(--color-cta-hover) !important;
  color: var(--color-white) !important;
}

/* Variante: outline blanco (sobre fondo oscuro) */
.it-btn--outline-white,
a.it-btn--outline-white,
a.it-btn--outline-white:link,
a.it-btn--outline-white:visited {
  background-color: transparent !important;
  color: var(--color-white) !important;
  border-color: var(--color-white) !important;
  text-decoration: none !important;
}

.it-btn--outline-white:hover,
a.it-btn--outline-white:hover {
  background-color: var(--color-white) !important;
  color: var(--color-navy) !important;
}

/* Variante: outline navy (sobre fondo claro) */
.it-btn--outline-navy,
a.it-btn--outline-navy,
a.it-btn--outline-navy:link,
a.it-btn--outline-navy:visited {
  background-color: transparent !important;
  color: var(--color-navy) !important;
  border-color: var(--color-navy) !important;
  text-decoration: none !important;
}

.it-btn--outline-navy:hover,
a.it-btn--outline-navy:hover {
  background-color: var(--color-navy) !important;
  color: var(--color-white) !important;
}

/* Variante: teal relleno */
.it-btn--teal,
a.it-btn--teal,
a.it-btn--teal:link,
a.it-btn--teal:visited {
  background-color: var(--color-teal-dark) !important;
  color: var(--color-white) !important;
  border-color: var(--color-teal-dark) !important;
  text-decoration: none !important;
}

.it-btn--teal:hover,
a.it-btn--teal:hover {
  background-color: #2E8A80 !important;
  border-color: #2E8A80 !important;
  color: var(--color-white) !important;
}

/* ── TIPOGRAFÍA BASE ─────────────────────────────────────── */
.it-h1 {
  font-family: var(--font-heading);
  font-size: var(--font-size-h1);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-heading);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--color-text-primary);
}

.it-h2 {
  font-family: var(--font-heading);
  font-size: var(--font-size-h2);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-heading);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--color-text-primary);
}

.it-h3 {
  font-family: var(--font-heading);
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-semibold);
  line-height: 1.3;
  color: var(--color-text-primary);
}

/* Texto blanco (sobre fondos oscuros) */
.it-text-white .it-h1,
.it-text-white .it-h2,
.it-text-white .it-h3,
.it-text-white p {
  color: var(--color-white);
}

/* ── SECCIONES — FONDOS ──────────────────────────────────── */
.it-section {
  padding-top: var(--section-padding-y);
  padding-bottom: var(--section-padding-y);
  /* Full-bleed: rompe del wrapper de HubSpot para llegar edge-to-edge del viewport */
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  width: 100vw;
  max-width: 100vw;
  overflow-x: clip;
}

.it-section--lg {
  padding-top: var(--section-padding-y-lg);
  padding-bottom: var(--section-padding-y-lg);
}

.it-bg-white    { background-color: var(--color-white); }
.it-bg-navy     { background-color: var(--color-navy); }
.it-bg-gray     { background-color: var(--color-gray-100); }
.it-bg-teal-lt  { background-color: var(--color-teal-light); }

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media (max-width: 1023px) {
  :root {
    --section-padding-y:    var(--space-9);
    --section-padding-y-lg: var(--space-10);
  }
}

@media (max-width: 767px) {
  :root {
    --section-padding-y:    var(--space-8);
    --section-padding-y-lg: var(--space-9);
    --container-padding:    var(--space-5);
    --grid-gap:             var(--space-5);
  }
}

   INFOTRAC — Contact Module Styles
   infotrac-contact.module/module.css
   ============================================================ */

/* ── EYEBROW CON BORDE (fondo navy) ───────────────────────── */
.it-contact .it-eyebrow--light {
  border: 1px solid var(--color-teal-light);
  border-radius: var(--border-radius-sm);
  padding: 3px 10px;
}

/* ── ENCABEZADO ────────────────────────────────────────────── */
.it-contact__header {
  text-align: center;
  margin-bottom: var(--space-12);
}

/* Layout two-col: alinear header a la izquierda (texto izq, form der) */
.it-contact--two-col .it-contact__header {
  text-align: left;
  max-width: 100%;
  margin-bottom: 0;  /* el gap del left-col maneja el spacing */
}

/* Columna izquierda en two-col: header arriba + info debajo, mismo nivel que form */
.it-contact__left-col {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

.it-contact__headline {
  margin: var(--space-3) 0 var(--space-5) 0;
}

.it-bg-navy .it-contact__headline { color: var(--color-white); }
.it-bg-white .it-contact__headline,
.it-bg-gray  .it-contact__headline { color: var(--color-navy); }

.it-contact__description {
  max-width: 580px;
  margin: 0 auto;
  font-size: var(--font-size-body-lg);
  line-height: var(--line-height-body);
}

/* Layout two-col: descripción no se centra */
.it-contact--two-col .it-contact__description {
  margin: 0;
  max-width: 100%;
}

.it-bg-navy .it-contact__description { color: var(--color-text-on-dark-muted); }
.it-bg-white .it-contact__description,
.it-bg-gray  .it-contact__description { color: var(--color-gray-700); }

/* ── BODY ──────────────────────────────────────────────────── */
.it-contact__body {
  display: grid;
  gap: var(--space-12);
}

.it-contact--two-col .it-contact__body {
  grid-template-columns: 1fr 1.4fr;
  align-items: start;
}

.it-contact--centered .it-contact__body {
  grid-template-columns: 1fr;
  max-width: 640px;
  margin: 0 auto;
}

/* ── INFO DE CONTACTO ──────────────────────────────────────── */
.it-contact__info {
  display: flex;
  flex-direction: column;
  gap: var(--space-7);
}

.it-contact__item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
}

.it-contact__icon {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.it-bg-navy .it-contact__icon {
  background-color: rgba(255,255,255,0.10);
  color: var(--color-teal-light);
}

.it-bg-white .it-contact__icon,
.it-bg-gray  .it-contact__icon {
  background-color: var(--color-teal-light);
  color: var(--color-navy);
}

.it-contact__link {
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-medium);
  text-decoration: none;
  transition: color var(--transition-base);
  padding-top: 11px;
}

.it-bg-navy .it-contact__link {
  color: var(--color-white);
}

.it-bg-navy .it-contact__link:hover {
  color: var(--color-teal-light);
}

.it-bg-white .it-contact__link,
.it-bg-gray  .it-contact__link {
  color: var(--color-navy);
}

.it-bg-white .it-contact__link:hover,
.it-bg-gray  .it-contact__link:hover {
  color: var(--color-teal-dark);
}

.it-contact__text {
  font-size: var(--font-size-body);
  padding-top: 11px;
}

.it-bg-navy .it-contact__text { color: var(--color-text-on-dark-muted); }
.it-bg-white .it-contact__text,
.it-bg-gray  .it-contact__text { color: var(--color-gray-700); }

/* ── FORMULARIO ────────────────────────────────────────────── */
.it-contact__form-wrap {
  background-color: var(--color-white);
  border-radius: var(--border-radius-lg);
  padding: var(--space-8) var(--space-9);
  box-shadow: var(--shadow-card);
}

.it-bg-white .it-contact__form-wrap,
.it-bg-gray  .it-contact__form-wrap {
  box-shadow: var(--shadow-card-hover);
}

.it-contact__form-title {
  font-family: var(--font-heading);
  font-size: var(--font-size-body-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--color-navy);
  margin: 0 0 var(--space-6) 0;
}

/* ── PLACEHOLDER (sin form_id configurado) ─────────────────── */
.it-contact__form-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  min-height: 200px;
  text-align: center;
  color: var(--color-gray-500);
}

.it-contact__form-placeholder p {
  font-size: var(--font-size-body-sm);
  line-height: 1.6;
  margin: 0;
}

/* ── ESTILOS DE CAMPOS DEL FORM HUBSPOT ────────────────────── */
/* Estas reglas dan estilo a los inputs del formulario nativo de HubSpot */
.it-contact__form-wrap .hs-form fieldset {
  max-width: 100% !important;
}

.it-contact__form-wrap .hs-form .hs-form-field {
  margin-bottom: var(--space-5) !important;
}

.it-contact__form-wrap .hs-form label {
  font-family: var(--font-body) !important;
  font-size: var(--font-size-body-sm) !important;
  font-weight: var(--font-weight-medium) !important;
  color: var(--color-navy) !important;
  margin-bottom: var(--space-2) !important;
  display: block !important;
}

.it-contact__form-wrap .hs-form input[type="text"],
.it-contact__form-wrap .hs-form input[type="email"],
.it-contact__form-wrap .hs-form input[type="tel"],
.it-contact__form-wrap .hs-form textarea,
.it-contact__form-wrap .hs-form select {
  width: 100% !important;
  padding: 0.65rem var(--space-4) !important;
  border: 1.5px solid var(--color-gray-300) !important;
  border-radius: var(--border-radius-sm) !important;
  font-family: var(--font-body) !important;
  font-size: var(--font-size-body) !important;
  color: var(--color-gray-900) !important;
  background: var(--color-white) !important;
  transition: border-color var(--transition-base), box-shadow var(--transition-base) !important;
  box-sizing: border-box !important;
}

.it-contact__form-wrap .hs-form input:focus,
.it-contact__form-wrap .hs-form textarea:focus,
.it-contact__form-wrap .hs-form select:focus {
  outline: none !important;
  border-color: var(--color-teal-dark) !important;
  box-shadow: 0 0 0 3px rgba(63,169,156,0.15) !important;
}

.it-contact__form-wrap .hs-form textarea {
  min-height: 110px !important;
  resize: vertical !important;
}

.it-contact__form-wrap .hs-form input[type="submit"],
.it-contact__form-wrap .hs-form .hs-button {
  background-color: var(--color-navy) !important;
  color: var(--color-white) !important;
  font-family: var(--font-body) !important;
  font-size: var(--font-size-body) !important;
  font-weight: var(--font-weight-semibold) !important;
  border: none !important;
  border-radius: var(--border-radius-pill) !important;
  padding: 0.75rem var(--space-8) !important;
  cursor: pointer !important;
  transition: background-color var(--transition-base), transform var(--transition-base) !important;
  letter-spacing: 0.01em !important;
}

.it-contact__form-wrap .hs-form input[type="submit"]:hover,
.it-contact__form-wrap .hs-form .hs-button:hover {
  background-color: var(--color-teal-dark) !important;
  transform: translateY(-2px) !important;
}

.it-contact__form-wrap .hs-error-msgs {
  list-style: none !important;
  margin: var(--space-2) 0 0 0 !important;
  padding: 0 !important;
}

.it-contact__form-wrap .hs-error-msgs li label {
  color: #c0392b !important;
  font-size: var(--font-size-body-sm) !important;
  font-weight: var(--font-weight-regular) !important;
}

/* ── RESPONSIVE ────────────────────────────────────────────── */
@media (max-width: 899px) {
  .it-contact--two-col .it-contact__body {
    grid-template-columns: 1fr;
  }

  .it-contact__info {
    flex-direction: row;
    flex-wrap: wrap;
    gap: var(--space-5) var(--space-8);
  }
}

@media (max-width: 599px) {
  .it-contact__form-wrap {
    padding: var(--space-6);
  }

  .it-contact__info {
    flex-direction: column;
  }
}
