/* ── 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;
}

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

.it-btn--navy:hover,
a.it-btn--navy:hover {
  background-color: var(--color-gray-900) !important;
  border-color: var(--color-gray-900) !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 — Team Module Styles
   infotrac-team.module/module.css
   ============================================================ */

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

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

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

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

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

/* ── GRID ──────────────────────────────────────────────────── */
.it-team__grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-10);
}

.it-team__grid.it-team--cols-2 { grid-template-columns: repeat(2, 1fr); }
.it-team__grid.it-team--cols-3 { grid-template-columns: repeat(3, 1fr); }
.it-team__grid.it-team--cols-4 { grid-template-columns: repeat(4, 1fr); }

/* ── TARJETA BASE ──────────────────────────────────────────── */
.it-team__card {
  display: flex;
  flex-direction: column;
}

/* ── FOTO ──────────────────────────────────────────────────── */
.it-team__photo-wrap {
  position: relative;
  overflow: hidden;
  border-radius: var(--border-radius-md);
  background-color: var(--color-gray-200);
  aspect-ratio: 1 / 1;
  margin-bottom: var(--space-5);
  max-width: 280px;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}

.it-team__photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

.it-team__card:hover .it-team__photo {
  transform: scale(1.04);
}

.it-team__photo-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-gray-400);
}

/* ── INFO (minimal & card) ─────────────────────────────────── */
.it-team__info {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.it-team__name {
  font-family: var(--font-heading);
  font-size: var(--font-size-body-lg);
  font-weight: var(--font-weight-semibold);
  margin: 0;
  line-height: 1.3;
}

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

.it-team__role {
  font-size: var(--font-size-body-sm);
  font-weight: var(--font-weight-medium);
  margin: 0;
  color: var(--color-teal-dark);
}

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

.it-team__bio {
  font-size: var(--font-size-body-sm);
  line-height: var(--line-height-body);
  margin: var(--space-2) 0 0 0;
}

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

/* ── LINKEDIN ──────────────────────────────────────────────── */
.it-team__linkedin {
  display: inline-flex;
  align-items: center;
  margin-top: var(--space-3);
  color: var(--color-teal-dark);
  transition: color var(--transition-base), transform var(--transition-base);
}

.it-team__linkedin:hover {
  color: var(--color-navy);
  transform: translateY(-2px);
}

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

/* ── CTAs DE SECCIÓN ───────────────────────────────────────── */
.it-team__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  justify-content: center;
  margin-top: var(--space-10);
}

/* ── ESTILO: CARD ──────────────────────────────────────────── */
.it-team--card .it-team__card {
  background-color: var(--color-white);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.it-team--card .it-team__card:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-4px);
}

.it-team--card .it-team__photo-wrap {
  border-radius: 0;
  margin-bottom: 0;
}

.it-team--card .it-team__info {
  padding: var(--space-5) var(--space-6);
}

.it-bg-navy.it-team--card .it-team__card {
  background-color: rgba(255,255,255,0.08);
}

/* ── ESTILO: OVERLAY ───────────────────────────────────────── */
.it-team--overlay .it-team__photo-wrap {
  margin-bottom: 0;
  border-radius: var(--border-radius-md);
}

.it-team__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--space-5);
  background: linear-gradient(to top, rgba(11,37,69,0.90) 0%, rgba(11,37,69,0.10) 60%, transparent 100%);
  border-radius: var(--border-radius-md);
}

.it-team--overlay .it-team__name {
  color: var(--color-white);
  font-size: var(--font-size-body);
}

.it-team--overlay .it-team__role {
  color: var(--color-teal-light);
  font-size: var(--font-size-body-sm);
}

/* ── RESPONSIVE ────────────────────────────────────────────── */
@media (max-width: 1023px) {
  .it-team__grid.it-team--cols-4 { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 767px) {
  .it-team__grid.it-team--cols-2,
  .it-team__grid.it-team--cols-3,
  .it-team__grid.it-team--cols-4 {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-7);
  }

  .it-team__header { margin-bottom: var(--space-9); }
}

@media (max-width: 479px) {
  .it-team__grid.it-team--cols-2,
  .it-team__grid.it-team--cols-3,
  .it-team__grid.it-team--cols-4 {
    grid-template-columns: 1fr;
  }
}
