/* ====================================================================
   ASPharma MPV2 — main.css
   ────────────────────────────────────────────────────────────────────
   SCOPE: Cimientos, layout y componentes NO-DS.

   Contiene:
     • :root (tokens: colores, spacing, tipografía, shadows, transitions)
     • Reset, tipografía base, utilidades (.text-h*, .btn, containers)
     • Layout: grids (.services-grid, .value-grid, .industries-grid,
       .differentials-grid, .footer-grid), contenedores de sección,
       breakpoints responsive
     • Componentes NO-DS: nav, hero, footer, industries, contact-form,
       forms (floating labels, selects, phone picker), timeline layout
       estructural (.timeline__row, __content, __badge, __image-*)
     • Wrappers de sección (.services-section, .stats-bar,
       .process-timeline outer)

   NO contiene:
     • Cards DS (service/value/differential/result, stats items,
       timeline marker visual) → design-system.css
     • Hovers DS, reveals, motion                → design-system.css
     • Gradientes y variantes visuales de marca   → design-system.css
     • Componentes de conversión (banner, sticky, modales,
       lead-magnet, formularios conversacionales) → conversion.css

   Mobile-first · Single-file scaffolding · No build step
   Cache-bust por filemtime() desde templates/head.php
   ==================================================================== */

/* ====== 1. RESET & BASE ====== */

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: var(--font-weight-body);
  line-height: 1.65;
  letter-spacing: var(--track-body);
  color: var(--content-body);
  background-color: var(--surface-page);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

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

a {
  color: inherit;
  text-decoration: none;
}

ul,
ol {
  list-style: none;
}

button,
input,
select,
textarea {
  font: inherit;
  color: inherit;
  border: none;
  background: none;
}

button {
  cursor: pointer;
}

/* ====== 2. CUSTOM PROPERTIES ====== */

:root {
  /* ════════════════════════════════════════════════════════════════════
     CAPA 1 — PRIMITIVOS (paleta cruda)
     Único lugar a tocar para rebrandear. NO consumir directo en componentes.
     ════════════════════════════════════════════════════════════════════ */

  /* Azure → Navy Luxury "Camiseta v2" (paleta primaria del proyecto) */
  --palette-azure-50-rgb:   220, 230, 245;   /* #DCE6F5 */
  --palette-azure-100-rgb:  180, 200, 225;   /* #B4C8E1 */
  --palette-azure-500-rgb:  27, 42, 74;      /* #1B2A4A — brand-primary (camiseta v2 main) */
  --palette-azure-600-rgb:  21, 35, 63;      /* #15233F — hover */
  --palette-azure-700-rgb:  16, 25, 53;      /* #101935 — deep (camiseta v2 shadow) */
  --palette-azure-50:       rgb(var(--palette-azure-50-rgb));
  --palette-azure-100:      rgb(var(--palette-azure-100-rgb));
  --palette-azure-500:      rgb(var(--palette-azure-500-rgb));
  --palette-azure-600:      rgb(var(--palette-azure-600-rgb));
  --palette-azure-700:      rgb(var(--palette-azure-700-rgb));

  /* Teal → Dorado Luxury "Camiseta v2" (paleta acento del proyecto)
     Gold cálido (#C8A45D) reemplaza al bronce olivo previo.
     teal-700 = brand-accent texto: AA Normal en blanco (~4.55:1).
     teal-800 = hover/deeper: AA strong (~6.5:1). */
  --palette-teal-50-rgb:    247, 240, 218;   /* #F7F0DA — cream cálido */
  --palette-teal-100-rgb:   232, 215, 165;   /* #E8D7A5 — champagne soft */
  --palette-teal-400-rgb:   212, 183, 121;   /* #D4B779 — gold claro */
  --palette-teal-500-rgb:   200, 164, 93;    /* #C8A45D — vivid camiseta v2 (brand-accent-vivid) */
  --palette-teal-600-rgb:   168, 133, 63;    /* #A8853F — mid gold */
  --palette-teal-700-rgb:   139, 110, 46;    /* #8B6E2E — brand-accent texto (AA 4.55:1) */
  --palette-teal-800-rgb:   107, 83, 32;     /* #6B5320 — brand-accent-hover (AA strong 6.5:1) */
  --palette-teal-50:        rgb(var(--palette-teal-50-rgb));
  --palette-teal-100:       rgb(var(--palette-teal-100-rgb));
  --palette-teal-400:       rgb(var(--palette-teal-400-rgb));
  --palette-teal-500:       rgb(var(--palette-teal-500-rgb));
  --palette-teal-600:       rgb(var(--palette-teal-600-rgb));
  --palette-teal-700:       rgb(var(--palette-teal-700-rgb));
  --palette-teal-800:       rgb(var(--palette-teal-800-rgb));

  /* Neutros (warm grays — Luxury) */
  --palette-gray-0-rgb:      255, 255, 255;
  --palette-gray-1000-rgb:   0, 0, 0;
  --palette-gray-0:      rgb(var(--palette-gray-0-rgb));
  --palette-gray-50:     #f9f9f9;
  --palette-gray-100:    #f3f3f4;
  --palette-gray-200:    #e2e2e2;
  --palette-gray-400:    #c1c7cf;
  --palette-gray-600:    #41474e;
  --palette-gray-900:    #1a1c1c;
  --palette-gray-1000:   rgb(var(--palette-gray-1000-rgb));

  /* Neutro cálido */
  --palette-cream-50:    #FAF9F5;

  /* Estado */
  --palette-green-500:   #22C55E;
  --palette-amber-500:   #F59E0B;
  --palette-red-500:     #EF4444;

  /* Link azul (sistema) */
  --palette-blue-500:    #0D6EFD;

  /* ════════════════════════════════════════════════════════════════════
     CAPA 2 — SEMÁNTICOS (esto es lo que consume el resto del CSS)
     ════════════════════════════════════════════════════════════════════ */

  /* Marca — semánticos hex + RGB triplets sincronizados.
     Los temas pueden override SOLO los -rgb del primitivo y todo se actualiza. */
  --brand-primary:        var(--palette-azure-500);
  --brand-primary-rgb:    var(--palette-azure-500-rgb);
  --brand-primary-hover:  var(--palette-azure-600);
  --brand-primary-hover-rgb: var(--palette-azure-600-rgb);
  --brand-primary-active: var(--palette-azure-700);
  --brand-primary-active-rgb: var(--palette-azure-700-rgb);
  --brand-primary-soft:   var(--palette-azure-50);
  /* Accent — gold Camiseta v2 (#C8A45D vivid como accent principal).
     Contraste sobre blanco: ~3:1 (AA Large only). Decisión consciente para
     priorizar identidad visual; el hover (teal-700 #8B6E2E) es AA Normal.
     Único accent del proyecto, paleta Luxury. */
  --brand-accent:           var(--palette-teal-500);
  --brand-accent-rgb:       var(--palette-teal-500-rgb);
  --brand-accent-hover:     var(--palette-teal-700);
  --brand-accent-hover-rgb: var(--palette-teal-700-rgb);
  --brand-accent-soft:      var(--palette-teal-50);
  --brand-accent-vivid:     var(--palette-teal-500); /* alias — mismo valor que accent */
  --brand-accent-vivid-rgb: var(--palette-teal-500-rgb);
  --brand-accent-deep:      var(--palette-teal-800); /* para texto pequeño en superficies claras */
  --brand-accent-deep-rgb:  var(--palette-teal-800-rgb);
  --brand-accent-text-strong: var(--palette-teal-700); /* #8B6E2E (4.55:1) — dorado de TEXTO para cifras display grandes (reusa teal-700, no duplica hex) */

  /* Focus ring — gold deep (#6B5320) sobre superficies claras: 7.6:1 vs
     cream — AAA Non-text Contrast (1.4.11). Coherente con la identidad
     gold del proyecto. Para superficies oscuras hay un override más
     abajo que usa palette-teal-400 (gold claro). */
  --focus-ring:        var(--brand-accent-deep);
  --focus-ring-offset: 2px;

  /* Superficies */
  --surface-page:         var(--palette-gray-0);     /* fondo del documento */
  --surface-muted:        var(--palette-gray-50);    /* secciones alternas */
  --surface-card:         var(--palette-gray-100);   /* cards/contenedores */
  --surface-warm:         var(--palette-cream-50);   /* contenido cálido */
  --surface-navy-deep:    #101935;                   /* voz "autoridad" unificada — camiseta v2 deep (logos/sustainability/final-cta) */
  --surface-dark:         var(--palette-gray-1000);  /* sección Premium Support (legacy) */
  --surface-inverse:      var(--brand-primary);      /* secciones brand */

  /* Contenido (texto) */
  --content-heading:      var(--palette-gray-1000);  /* H1/H2/H3 negro puro */
  --content-strong:       var(--palette-gray-900);   /* texto fuerte */
  --content-body:         var(--palette-gray-900);   /* body principal */
  --content-muted:        var(--palette-gray-600);   /* secundario / footer */
  --content-on-brand:     var(--palette-gray-0);     /* texto sobre brand */
  --content-on-brand-rgb: var(--palette-gray-0-rgb); /* RGB para overlays */
  --content-on-accent:    var(--palette-gray-1000);  /* texto sobre accent */
  --content-on-dark:      var(--palette-gray-0);     /* texto sobre negro */
  --content-on-dark-rgb:  var(--palette-gray-0-rgb); /* RGB para overlays blancos */

  /* Surface RGB (overlays sobre dark) */
  --surface-dark-rgb:     var(--palette-gray-1000-rgb);

  /* Bordes — Luxury: tinte dorado en border-subtle (camiseta v2) */
  --border-subtle:        rgba(200, 164, 93, 0.18);
  --border-strong:        var(--palette-gray-600);
  --border-on-dark:       rgba(var(--content-on-dark-rgb),0.12);

  /* Eyebrow / Kicker (overline encima de H2)
     Tokens dedicados para que theme-builder controle independiente del accent */
  --eyebrow-color:        var(--brand-accent);
  --eyebrow-color-on-dark: rgba(var(--content-on-dark-rgb), 0.85);
  --eyebrow-tracking:     0.1em;
  --eyebrow-weight:       var(--font-weight-medium);

  /* ════════════════════════════════════════════════════════════════════
     CARDS — Sistema híbrido (slots numerados + aliases semánticos)
     ════════════════════════════════════════════════════════════════════
     Capa 1: 5 slots numerados (--card-bg-01..05) que el theme-builder
             controla y representan los colores disponibles para cards.
     Capa 2: aliases semánticos (--card-bg-default, elevated, brand,
             accent, dark) que apuntan a los slots — el código los lee.
     Capa 3: tokens contextuales (--card-bg, --card-text) que las
             secciones override para tonal elevation automática.
     ════════════════════════════════════════════════════════════════════ */

  /* Capa 1 — slots numerados (theme-builder controla) */
  --card-bg-01: var(--surface-page);    /* default — blanco */
  --card-bg-02: var(--surface-card);    /* elevated — gris claro */
  --card-bg-03: var(--brand-primary);   /* destacada — brand */
  --card-bg-04: var(--brand-accent);    /* destacada — accent */
  --card-bg-05: var(--surface-dark);    /* dark */

  --card-text-01: var(--content-body);
  --card-text-02: var(--content-body);
  --card-text-03: var(--content-on-brand);
  --card-text-04: var(--content-on-accent);
  --card-text-05: var(--content-on-dark);

  /* Capa 2 — aliases semánticos (legibilidad) */
  --card-bg-default:    var(--card-bg-01);
  --card-bg-elevated:   var(--card-bg-02);
  --card-bg-brand:      var(--card-bg-03);
  --card-bg-accent:     var(--card-bg-04);
  --card-bg-dark:       var(--card-bg-05);

  --card-text-default:    var(--card-text-01);
  --card-text-on-brand:   var(--card-text-03);
  --card-text-on-accent:  var(--card-text-04);
  --card-text-on-dark:    var(--card-text-05);

  /* Capa 3 — tokens contextuales (las secciones los override) */
  --card-bg:    var(--card-bg-default);
  --card-text:  var(--card-text-default);

  /* Premium Luxury dark cards (value--dark · service--lux · industry--lux)
     Sub-paleta dedicada: gradiente navy + textos crema/azul-gris + ícono oro.
     Valores exactos del diseño Luxury; consumida por design-system.css. */
  --card-dark-bg-from:     #173962;   /* gradiente top — navy medio */
  --card-dark-bg-to:       #0A1F38;   /* gradiente top — navy profundo */
  --card-dark-title:       #F1E7C7;   /* título/tag sobre dark — crema */
  --card-dark-text:        #A4B2C5;   /* desc sobre dark — azul-gris */
  --card-dark-icon:        #E8DDB5;   /* ícono — crema claro */
  --card-dark-icon-border: #9C8C3F;   /* borde del ícono — oro */

  /* Acción (CTAs) — Luxury: indigo vibrante #6161FF para máximo contraste
     sobre fondos navy. Hover oscurece misma familia. Botón secundario:
     outline dorado (signature Luxury). */
  --action-primary-bg:            #6161FF;
  --action-primary-bg-rgb:        97, 97, 255;
  --action-primary-bg-hover:      #4A4AE6;
  --action-primary-bg-hover-rgb:  74, 74, 230;
  --action-primary-text:          var(--content-on-brand);
  --action-primary-text-rgb:      var(--content-on-brand-rgb);
  --action-secondary-bg:          var(--surface-page);
  --action-secondary-text:        var(--brand-primary);
  --action-secondary-border:      var(--palette-teal-500);
  --action-accent-bg:             var(--brand-accent);
  --action-accent-text:           var(--content-on-accent);
  --action-on-dark-bg:            var(--surface-page);
  --action-on-dark-text:          var(--palette-gray-1000);

  /* Nav CTA "Variante A" — pill blanco sobre nav navy (texto navy, círculo
     navy→indigo en hover). Navy/indigo se reusan de --brand-primary /
     --action-primary-bg. */
  --cta-nav-bg:                   var(--surface-page);  /* #ffffff — pill reposo */
  --cta-nav-bg-hover:             #eef0fb;               /* off-white teñido indigo (hover) */

  /* Links */
  --link-default:         var(--palette-blue-500);
  --link-brand:           var(--brand-primary);

  /* Estado (semánticos) */
  --state-success:        var(--palette-green-500);
  --state-warning:        var(--palette-amber-500);
  --state-error:          var(--palette-red-500);

  /* ════════════════════════════════════════════════════════════════════
     TIPOGRAFÍA
     ════════════════════════════════════════════════════════════════════ */

  --font-heading: 'Nunito Sans', ui-sans-serif, system-ui, sans-serif;
  --font-body:    'Nunito Sans', ui-sans-serif, system-ui, sans-serif;
  --font-label:   var(--font-heading);

  /* Pesos parametrizados */
  --font-weight-light:    300;
  --font-weight-regular:  400;
  --font-weight-body:     400;       /* cuerpo base */
  --font-weight-medium:   500;
  --font-weight-semibold: 600;
  --font-weight-bold:     700;
  --font-weight-heading:  500;       /* default medio para headings y micro-UI (labels, th, badges) */
  --font-weight-display:  300;       /* firma editorial Lubrizol: titulares display/sección Light */
  --font-weight-subhead:  500;

  /* Escala tipográfica — spec tipográfico v2.0 (display 44 → legal 12).
     Titulares Light 300/400 + tracking negativo. Tracking en em para que
     escale. Paleta del proyecto intacta (navy/bronce/indigo). */

  /* Display / Hero */
  --text-display:   44px;          /* 2.75rem */
  --lh-display:     1.08;
  --weight-display: 300;
  --track-display:  -0.04em;

  /* Hero title — spec fluida (laurus), Nunito Sans. Independiente de la escala display. */
  --text-hero:         clamp(2rem, 4.167vw, 5rem);  /* piso 32px móvil · 4.167vw fluido · tope 80px = spec @1920 (evita runaway en >2K) */
  --text-hero-clean:   3.5rem;             /* 56px — título del hero "clean" (spec .v6__h1); 36px en ≤768 */
  --lh-hero:           1.2;                /* = 5vw ÷ 4.167vw */
  --track-hero:        -0.02em;            /* ≡ -0.083vw cuando font = 4.167vw */
  --hero-title-max-w:  62.76vw;            /* ≈ 903px @1440; se auto-limita por .hero__content (1280px) */
  /* Motion-toggle del hero (fuente única; consumido también por design-system.css) */
  --hero-toggle-size:  44px;               /* 44×44 (WCAG 2.5.8) */
  --hero-toggle-inset: clamp(1rem, 4vw, 2.5rem);
  --hero-toggle-band:  calc(var(--hero-toggle-size) + var(--hero-toggle-inset) + var(--sp-4)); /* banda reservada bajo el contenido */

  /* H1 — alias de display para la utilidad .text-h1 */
  --text-h1:        44px;          /* 2.75rem */
  --lh-h1:          1.08;
  --weight-h1:      300;
  --track-h1:       -0.04em;

  /* H2 — titular de sección (patrón Split) */
  --text-h2:        38px;          /* 2.375rem */
  --lh-h2:          1.10;
  --weight-h2:      300;           /* eyebrow line; el main se sube a 400 en .section-header__title */
  --track-h2:       -0.04em;

  /* H3 — sub-sección / subtítulo de bloque (spec 22px / 400) */
  --text-h3-section:   22px;       /* 1.375rem */
  --lh-h3-section:     1.30;
  --weight-h3-section: 400;
  --track-h3-section:  -0.02em;

  /* Card title (18px). El spec pide 600, pero la identidad del proyecto
     (CLAUDE.md: "card-titles y micro-UI en 500") y la carga de fuente
     —sin itálica 600— mandan: se conserva 500 para evitar fake-bold en
     los títulos itálicos (.value-card__title). */
  --text-h3:        18px;
  --lh-h3:          1.40;
  --weight-h3:      500;
  --track-card:     -0.04em;       /* ≈ -0.72px a 18px */
  --text-card-title: var(--text-h3);

  /* Roles de título spec sin token previo */
  --text-faq:          48px;       /* 3rem — FAQ title */
  --text-legal-title:  40px;       /* 2.5rem — título de página legal */
  --text-contact:      38px;       /* 2.375rem — trust title / step question */

  /* Pasos de escala añadidos — cierran gaps 22→38 y >44.
     Sin override mobile a propósito: preservan el render actual. */
  --text-figure:    52px;          /* 3.25rem — cifra hero (stat-card value) */
  --text-figure-md: 24px;          /* 1.5rem  — cifras / índices secundarios */
  --text-h3-lg:     28px;          /* 1.75rem — heading entre h3-section (22) y h2 (38) */
  --text-subhead:   20px;          /* 1.25rem — sub-título / nav prominente / dialog */

  /* Card desc / body chico — token histórico --text-h4 */
  --text-h4:        14px;
  --lh-h4:          21px;          /* ratio 1.5 */
  --weight-h4:      400;

  /* Roles restantes Lubrizol */
  --text-link-lg:   22px;          /* large link */
  --text-lead:      18px;          /* bajada / lead */
  --text-base:      16px;          /* base / nav / UI */
  --text-cta:       15px;          /* 0.9375rem — label de CTA de conversión (body/nav) */
  --text-cta-lg:    17px;          /* 1.0625rem — label del CTA primario del hero (más grande) */
  --text-h5:        13px;
  --text-body-lg:   16px;
  --text-body:      14px;          /* Lubrizol body */
  --text-small:     13px;
  --text-label:     14px;          /* Lubrizol label / cta */
  --text-eyebrow:   11px;
  --text-caption:   12px;
  --text-legal:     12px;          /* legal / footer */

  /* Glyphs / inputs decorativos — sin equivalente en la escala de texto (M1) */
  --text-input-big: 32px;          /* 2rem — input conversacional grande (.cl-input--big); 24px en ≤768px */
  --text-glyph-md:  32px;          /* 2rem — icono decorativo mediano (modal lead-magnet) */
  --text-glyph-lg:  40px;          /* 2.5rem — icono decorativo grande (success lead-magnet) */

  /* Tracking por rol (em) — spec v2.0 */
  --track-lead:     -0.01em;
  --track-body:     -0.01em;

  /* Line-heights genéricos de fallback */
  --lh-heading:   1.3;
  --lh-body:      1.5;
  --lh-tight:     1.15;

  /* ════════════════════════════════════════════════════════════════════
     ESPACIADO
     ════════════════════════════════════════════════════════════════════ */

  /* Semántico (nueva identidad) */
  --space-inline:   20px;   /* gap entre elementos */
  --space-block:    32px;   /* gap entre bloques */
  --space-section:  60px;   /* aire vertical de secciones */

  /* Escala utilitaria 8px (se mantiene por retrocompatibilidad) */
  --sp-1:  0.25rem;
  --sp-2:  0.5rem;
  --sp-4:  1rem;
  --sp-6:  1.5rem;
  --sp-8:  2rem;
  --sp-12: 3rem;
  --sp-16: 4rem;
  --sp-24: 6rem;

  /* Escala específica Linear App */
  --sp-linear-2:  2px;
  --sp-linear-24: 24px;
  --sp-linear-28: 28px;
  --sp-linear-32: 32px;
  --sp-linear-36: 36px;
  --sp-linear-40: 40px;
  --sp-linear-47: 47px;
  --sp-linear-56: 56px;
  --sp-linear-60: 60px;
  --sp-linear-71: 71px;

  /* ════════════════════════════════════════════════════════════════════
     RADIOS
     ════════════════════════════════════════════════════════════════════ */

  --radius-xs:      4px;     /* cards con ícono */
  --radius-sm:      12px;    /* banner morado / utilitario chico */
  --radius-card:    8px;     /* Luxury — radio editorial unificado */
  --radius-md:      20px;    /* banner amarillo */
  --radius-section: 8px;     /* Luxury — radio editorial unificado */
  --radius-button:  40px;    /* botón primario */
  --radius-pill:    9999px;  /* Luxury — pills full round */
  --radius-pill-xl: 9999px;  /* unified */
  --radius-full:    9999px;  /* circular */

  /* ════════════════════════════════════════════════════════════════════
     SOMBRAS
     ════════════════════════════════════════════════════════════════════ */

  --shadow-sm:         0 1px 3px rgba(0,0,0,0.08);
  --shadow-md:         0 4px 16px rgba(33,37,41,0.10);
  --shadow-lg:         0 12px 40px rgba(33,37,41,0.14);
  /* Luxury: ultra-flat con tinte dorado (camiseta v2) */
  --shadow-card:       0 1px 0 rgba(200, 164, 93, 0.12);
  --shadow-card-hover: 0 20px 40px rgba(33,37,41,0.15), 0 8px 16px rgba(33,37,41,0.10);
  --shadow-cta:        0 4px 20px rgba(var(--brand-primary-rgb),0.35);
  --shadow-ambient:    0 4px 12px rgba(25,28,30,0.04), 0 20px 40px rgba(25,28,30,0.08);
  --shadow-ambient-low: 0 4px 12px rgba(25,28,30,0.04);

  /* ════════════════════════════════════════════════════════════════════
     TRANSICIONES
     ════════════════════════════════════════════════════════════════════ */

  --transition-fast: 150ms cubic-bezier(0.4,0,0.2,1);
  --transition-base: 200ms cubic-bezier(0.4,0,0.2,1);
  --transition-slow: 300ms cubic-bezier(0.34,1.56,0.64,1);
  --t-fast:   0.15s ease;
  --t-normal: 0.25s ease;
  --t-slow:   0.4s ease;

  /* ════════════════════════════════════════════════════════════════════
     LAYOUT
     ════════════════════════════════════════════════════════════════════ */

  --max-width:      1280px;
  --container-max:  1200px;
  --container-pad:  clamp(1rem, 5vw, 3rem);
  /* Padding compacto — el header queda cerca del nav al anclar, pero
     mantiene aire suficiente para separar secciones consecutivas. */
  --section-py:     clamp(1.5rem, 3.5vw, 3rem);
  --section-py-lg:  clamp(2rem, 5vw, 4rem);

  --nav-height:             4.5rem;
  /* Sincronizado con --nav-height para que el scroll-margin-top matchee
     EXACTAMENTE la altura real del nav fijo. Mantener como referencia
     (no valor literal) garantiza que si --nav-height cambia, el offset
     se ajusta solo.

     (El top-banner fue eliminado del proyecto — el nav está siempre
     en top:0 y la altura del nav es la única variable del cálculo.) */
  --section-anchor-offset:  var(--nav-height);

  /* Z-index scale */
  --z-banner:       90;
  --z-nav:          100;
  --z-mobile-menu:  200;
  --z-overlay:      300;

  /* outline variant (utilidad de borde tenue) */
  --color-outline-variant: rgba(195, 198, 214, 0.2);
}

/* Móvil ≤768px — escala de display reducida (spec tipográfico v2.0 §7).
   Solo se re-declaran los tokens de tamaño; pesos/tracking/lh se heredan. */
@media (max-width: 768px) {
  :root {
    --text-figure:       38px;   /* 2.375rem — era 52 (cifra hero) */
    --text-display:      32px;   /* 2rem    — era 44 */
    --text-hero-clean:   36px;   /* 2.25rem — era 56 (título hero clean) */
    --text-h1:           32px;   /* 2rem */
    --text-h2:           26px;   /* 1.625rem — era 38 */
    --text-h3-section:   20px;   /* 1.25rem  — era 22 */
    --text-faq:          32px;   /* 2rem    — era 48 */
    --text-legal-title:  28px;   /* 1.75rem — era 40 */
    --text-contact:      26px;   /* 1.625rem — era 38 */
    --text-input-big:    24px;   /* 1.5rem  — era 32 (input conversacional) */
  }
}

/* ====== 3. TYPOGRAPHY ====== */

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  color: var(--content-heading);
  font-weight: var(--font-weight-heading);  /* default 500; .text-h1/.text-h2 y titulares display repisan a 300 */
  line-height: var(--lh-heading);
  text-wrap: balance;
}

p {
  text-wrap: pretty;
}

p + p {
  margin-top: 1.5em;  /* spacing visible entre párrafos consecutivos (WCAG 1.4.8). */
}

.text-h1 {
  font-size: var(--text-h1);
  font-weight: var(--weight-h1);
  line-height: var(--lh-h1);
  letter-spacing: var(--track-h1);
}

.text-h2 {
  font-size: var(--text-h2);
  font-weight: var(--weight-h2);
  line-height: var(--lh-h2);
  letter-spacing: var(--track-h2);
}

.text-h3 {
  font-size: var(--text-h3);
  font-weight: var(--weight-h3);
  line-height: var(--lh-h3);
}

.text-h4 {
  font-size: var(--text-h4);
  font-weight: var(--weight-h4);
  line-height: var(--lh-h4);
}

.hero__title {
  font-size: var(--text-hero);           /* spec hero fluida; ver token en :root */
  font-weight: var(--font-weight-display);
  line-height: var(--lh-hero);
  letter-spacing: var(--track-hero);
}

/* .section-header (split layout + eyebrow) → design-system.css */

/* ====== 4. LAYOUT UTILITIES ====== */

.section-container {
  max-width: var(--max-width);
  margin-left: auto;
  margin-right: auto;
  padding-left: 1rem;
  padding-right: 1rem;
}

/* Scroll offset: fuente única en :root (--section-anchor-offset) */
[id] {
  scroll-margin-top: var(--section-anchor-offset);
}

.section-padding {
  padding-top: var(--section-py);
  padding-bottom: var(--section-py);
}

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

.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;
}

[hidden] {
  display: none !important;
}

/* ====== 5. BUTTONS ====== */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-family: var(--font-heading);
  font-weight: var(--font-weight-subhead);
  font-size: var(--text-base);
  line-height: 1;
  padding: 0.875rem 1.75rem;
  border-radius: 0.5rem;
  min-height: 44px;
  transition: transform var(--transition-base),
              box-shadow var(--transition-base),
              background-color var(--transition-base),
              border-color var(--transition-base);
  white-space: nowrap;
}

.btn:active {
  transform: scale(0.98);
}

.btn--primary {
  background-color: var(--action-primary-bg);
  color: var(--action-primary-text);
  box-shadow: var(--shadow-cta);
  border-radius: var(--radius-pill);          /* pill — unifica con hero/nav CTA */
}

/* CTA de conversión = IDÉNTICO al hero-cta: pill firme, padding asimétrico,
   15px/500. Excluye el botón "volver" (.nav__cta--back). */
.btn--primary:not(.nav__cta--back):has(.icon) {
  gap: 0.625rem;
  padding: 0.5rem 1.125rem 0.5rem 0.5rem;
  font-size: var(--text-cta);                 /* 15px — igual que hero-cta */
  font-weight: var(--font-weight-medium);     /* 500 */
}

/* Indigo en TODO contexto (igual que el hero-cta): anula la inversión a blanco
   que .btn--primary hace en secciones oscuras. */
[data-nav-theme="dark"] .btn--primary:not(.nav__cta--back):has(.icon),
[data-nav-theme="dark"] .btn--primary:not(.nav__cta--back):has(.icon):hover {
  background-color: var(--action-primary-bg);
  color: var(--content-on-brand);
}
[data-nav-theme="dark"] .btn--primary:not(.nav__cta--back):has(.icon):hover {
  background-color: var(--action-primary-bg-hover);
}

.btn--primary:hover {
  background-color: var(--action-primary-bg-hover);
  transform: translateY(-2px);
  box-shadow: 0 14px 30px -5px rgba(var(--action-primary-bg-rgb),0.4);
}

/* Sobre fondo oscuro (hero, sustainability, footer): invertir
   colores para garantizar contraste AAA (~21:1) con cualquier tema. */
[data-nav-theme="dark"] .btn--primary {
  background-color: var(--surface-page);    /* blanco */
  color: var(--content-heading);            /* casi negro — 21:1 sobre blanco */
  box-shadow: 0 8px 24px -8px rgba(0, 0, 0, 0.45);
}

/* Hover: inversión completa → negro con texto blanco (21:1 también).
   Da feedback dramático y mantiene AAA. */
[data-nav-theme="dark"] .btn--primary:hover {
  background-color: var(--surface-dark);    /* negro/gray-1000 */
  color: var(--content-on-dark);            /* blanco */
  box-shadow: 0 14px 30px -8px rgba(0, 0, 0, 0.6);
}

/* Evitar inversión de botón primario si está dentro de una tarjeta clara en sección oscura (ej. formulario de contacto) */
[data-nav-theme="dark"] .contact-card .btn--primary {
  background-color: var(--action-primary-bg);
  color: var(--action-primary-text);
  box-shadow: var(--shadow-cta);
}

[data-nav-theme="dark"] .contact-card .btn--primary:hover {
  background-color: var(--action-primary-bg-hover);
  color: var(--action-primary-text);
  box-shadow: 0 14px 30px -5px rgba(var(--action-primary-bg-rgb),0.4);
}

.btn--secondary {
  background-color: transparent;
  color: var(--content-heading);
  border: 2px solid var(--border-subtle);
}

.btn--secondary:hover {
  border-color: var(--brand-accent);
  color: var(--brand-accent-hover);
  transform: translateY(-2px);
}

.btn--ghost {
  background-color: transparent;
  color: #fff;
  border: 2px solid rgba(var(--content-on-dark-rgb),0.3);
}

.btn--ghost:hover {
  border-color: rgba(var(--content-on-dark-rgb),0.6);
  background-color: rgba(var(--content-on-dark-rgb),0.08);
  transform: translateY(-2px);
}

.btn--primary-white {
  background-color: var(--action-primary-bg);
  color: var(--action-primary-text);
  box-shadow: var(--shadow-cta);
}

.btn--primary-white:hover {
  background-color: var(--action-primary-bg-hover);
  transform: translateY(-2px);
}

.btn .icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

/* ====== 6. NAVIGATION ====== */

.nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--z-nav);
  background-color: var(--palette-azure-700);
  border-bottom: 1px solid rgba(var(--content-on-dark-rgb),0.08);
  transition: background-color var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}

/* Estado scrolled — UNIFICADO: mismo navy deep (#101935) en todas las
   secciones, claras u oscuras. Match exacto con --surface-navy-deep
   (hero / sustainability / final-cta) para coherencia de paleta. */
.nav.scrolled {
  background-color: rgba(var(--palette-azure-700-rgb), 0.88);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  box-shadow: none;
}

.nav.nav--on-dark {
  background-color: transparent;
  border-bottom-color: rgba(var(--content-on-dark-rgb),0.06);
}

/* Sobre sección oscura + scroll: mismo color que cualquier otra scrolled.
   El nav no debe cambiar de tono al cruzar secciones — un solo estado
   visual evita saltos cromáticos y mantiene identidad coherente. */
.nav.nav--on-dark.scrolled {
  background-color: rgba(var(--palette-azure-700-rgb), 0.88);
}

.nav__inner {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  max-width: var(--max-width);
  margin: 0 auto;
  min-height: var(--nav-height);
  padding: 0 1rem;
}

.nav__brand {
  display: inline-flex;
  align-items: center;
  gap: 0.625rem;
  flex-shrink: 0;
  text-decoration: none;
  line-height: 1;
}

.nav__logo {
  flex-shrink: 0;
  height: 32px;
  width: auto;
  display: block;
}

.nav__brand-name {
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.01em;
  color: rgba(255, 255, 255, 0.92);
  white-space: nowrap;
  line-height: 1;
}

.nav__brand-name__suffix {
  font-weight: 400;
  color: rgba(255, 255, 255, 0.6);
  letter-spacing: 0.04em;
}

@media (max-width: 480px) {
  .nav__brand-name__suffix {
    display: none;
  }
}

/* FIX-8 (WCAG 2.4.1): skip-link. Oculto vía transform (no display:none, así
   permanece en el árbol de accesibilidad y focusable). Al recibir foco baja
   con un pill navy Luxury y focus ring dorado. */
.skip-link {
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, -150%);
  z-index: 2000; /* por encima del nav sticky */
  padding: 0.625rem 1.25rem;
  font-family: var(--font-heading);
  font-size: var(--text-small);
  font-weight: var(--font-weight-medium);
  color: #fff;
  background: var(--surface-navy-deep);
  border-radius: 9999px;
  box-shadow: 0 6px 20px rgba(0, 35, 73, 0.22);
  text-decoration: none;
  transition: transform var(--transition-base);
}

.skip-link:focus {
  transform: translate(-50%, 0.75rem);
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
}

.nav__links {
  display: none;
  align-items: center;
  gap: 0.125rem; /* separación mínima entre opciones */
  /* FIX-2: ahora es <ul>/<li> semántico — reset de la lista nativa. */
  list-style: none;
  margin: 0;
  padding: 0;
}

/* FIX-2: cada <li> es flex item del nav; el <a> ocupa la celda con su pill. */
.nav__links li {
  display: flex;
}

.nav__link {
  font-family: var(--font-heading);
  font-size: var(--text-label);            /* 14px — §1 (antes 13) */
  font-weight: var(--font-weight-medium);
  color: rgba(var(--content-on-dark-rgb), 0.72);  /* blanco 72% — §1 (antes 60%) */
  padding: 0.375rem 0.75rem;
  border-radius: 9999px; /* pill como Sign up (ref: linear.app) */
  transition: color var(--transition-fast),
              background-color var(--transition-fast);
  display: inline-flex;
  align-items: center;
}

.nav__link:hover {
  color: var(--content-on-dark);           /* blanco 100% — §1 */
  background-color: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.nav__actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-left: auto; /* empuja a la derecha en mobile (ref: linear.app) */
}

/* Language switcher — consistent with .nav__link */
.lang-switcher {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-family: var(--font-heading);
  font-size: var(--text-small);
  font-weight: var(--font-weight-medium);
  color: rgba(255, 255, 255, 0.6);
  padding: 0.375rem 0.75rem;
  background-color: transparent;
  border: none;
  border-radius: 9999px;
  text-decoration: none;
  transition: color var(--transition-fast),
              background-color var(--transition-fast);
}

.lang-switcher:hover {
  color: #fff;
  background-color: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.lang-switcher__icon {
  width: 0.875rem;
  height: 0.875rem;
  flex-shrink: 0;
}



.nav__cta {
  display: none;
}

/* ── Nav CTA "Variante A" — pill blanco, círculo-flecha a la izquierda ──────
   Vive sobre la nav navy (transparente/sólida). Spec ASPHARMA_NavCTA_Spec §7.
   Oculto en mobile (el hamburger toma el relevo); visible en ≥1024px. */
.nav-cta {
  display: none;
  align-items: center;
  gap: 0.625rem;
  padding: 0.5rem 1.125rem 0.5rem 0.5rem;   /* asimétrico: el círculo aporta aire a la izq */
  background: var(--cta-nav-bg);
  color: var(--brand-primary);
  border-radius: var(--radius-pill);
  font-family: var(--font-heading);
  font-size: var(--text-h4);                /* 14px */
  font-weight: var(--font-weight-medium);   /* 500 */
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  transition: background var(--transition-base), color var(--transition-base),
              transform var(--transition-fast);
}

.nav-cta__arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: none;
  width: 26px;
  height: 26px;
  border-radius: var(--radius-full);
  background: var(--brand-primary);
  color: var(--content-on-dark);            /* ícono blanco */
  transition: background var(--transition-base);
}

.nav-cta__arrow-icon {
  width: 15px;
  height: 15px;
  transition: transform 250ms ease;
}

.nav-cta:hover {
  background: var(--cta-nav-bg-hover);
}

.nav-cta:hover .nav-cta__arrow {
  background: var(--action-primary-bg);     /* indigo */
}

/* ↗ (45°) → → (horizontal): rotación 45° en sentido horario */
.nav-cta:hover .nav-cta__arrow-icon {
  transform: rotate(45deg);
}

.nav-cta:active {
  transform: scale(0.98);
}

.nav-cta:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.5);  /* anillo claro sobre nav navy */
}

@media (prefers-reduced-motion: reduce) {
  .nav-cta__arrow-icon { transition: none; }
  .nav-cta:hover .nav-cta__arrow-icon { transform: none; }
}

@media (min-width: 1024px) {
  .nav-cta { display: inline-flex; }
}

/* CTA del menú mobile — full-width (panel blanco → pill relleno indigo). */
.mobile-menu__cta-btn {
  width: 100%;
}

/* Botón "volver" en páginas legales: navy sólido (NO el indigo de
   conversión), texto blanco, mismo tamaño/posición que el CTA, con aire
   respecto al switcher de idioma y flecha invertida. Especificidad
   .nav__cta.nav__cta--back para ganarle al .btn--primary (indigo).
   En mobile FUERZA visibilidad — el botón Volver es la acción principal
   de la página legal, no debe quedar oculto detrás del hamburger. */
.nav__cta--back {
  display: inline-flex;
  margin-left: 1rem;
}

.nav__cta.nav__cta--back {
  flex-direction: row;            /* flecha a la izquierda (igual que "Enviar mensaje") */
  background-color: #1B2A4A;      /* mismo navy que el botón Enviar mensaje (--cl-navy) */
  box-shadow: 0 8px 24px -10px rgba(27, 42, 74, 0.5);
}

.nav__cta.nav__cta--back:hover {
  background-color: #00305f;      /* mismo hover que submit-mode */
  box-shadow: 0 14px 30px -8px rgba(0, 48, 95, 0.55);
}

.nav__cta--back .nav__cta-back-arrow {
  transform: scaleX(-1);
}

/* Mobile (< 640px): compactar para que conviva con el hamburger sin
   romper layout. Padding más chico, font reducida, margin-left mínimo. */
@media (max-width: 640px) {
  .nav__cta--back {
    margin-left: 0.5rem;
  }
  .nav__cta.nav__cta--back {
    padding: 0.5rem 0.875rem;
    font-size: var(--text-small);
    gap: 0.375rem;
  }
  .nav__cta--back .nav__cta-back-arrow {
    width: 0.875rem;
    height: 0.875rem;
  }
}

.hamburger {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 0.375rem;
  color: #fff;
  transition: background-color var(--transition-fast),
              color var(--transition-fast);
}

.hamburger:hover {
  background-color: rgba(var(--content-on-dark-rgb),0.1);
}

.hamburger .icon {
  width: 24px;
  height: 24px;
}

.hamburger__close {
  display: none;
}

.hamburger[aria-expanded="true"] .hamburger__open {
  display: none;
}

.hamburger[aria-expanded="true"] .hamburger__close {
  display: block;
}

/* Mobile menu */
.mobile-menu {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: var(--z-mobile-menu);
  background-color: rgba(var(--content-on-dark-rgb),0.98);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  display: flex;
  flex-direction: column;
  padding: 5rem 1.5rem 2rem;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: opacity var(--transition-base),
              visibility var(--transition-base),
              transform var(--transition-base);
}

.mobile-menu.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.mobile-menu__link {
  display: block;
  font-family: var(--font-heading);
  font-size: var(--text-subhead);
  font-weight: var(--font-weight-subhead);
  color: var(--content-heading);
  padding: 1rem 0;
  border-bottom: 1px solid var(--border-subtle);
  min-height: 44px;
}

.mobile-menu__link:hover {
  color: var(--brand-accent-deep);   /* #6B5320 — overlay blanco 98% (V1), era --brand-accent (2.35:1) */
}

.mobile-menu__cta {
  margin-top: auto;
  text-align: center;
}

/* ====== 7. HERO ====== */

/* min-height (no height fijo): el título display fluido de la spec hero crece
   en varias líneas y el hero se estira para contenerlo sin recortar las
   capability-pills. overflow:hidden recorta el video a la caja (no el contenido,
   que ya cabe porque la caja crece). El object-fit:cover del video escala según
   la altura de la caja, así que en pantallas anchas el encuadre puede variar
   levemente — tradeoff aceptado. padding-bottom reserva la banda del
   .hero__motion-toggle (absolute abajo-derecha) para que no pise el contenido. */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: flex-start;
  padding-top: 16vh;
  padding-bottom: var(--hero-toggle-band);
  overflow: hidden;
  background-color: var(--content-heading);
}

.hero__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  /* Encuadre desplazado hacia la derecha: deja la columna izquierda
     (donde vive el texto) sobre la zona más opaca del overlay y revela
     el punto de interés del video en el lado visible. NOTA: el video es
     16:9; en viewports 16:9 llena el hero exacto y no hay recorte
     horizontal, así que object-position-x no panea (solo afecta en
     ventanas más angostas que 16:9). */
  object-position: 75% center;
  z-index: 1;
}

/* Gradient horizontal que protege la columna izquierda (donde vive el texto)
   con opacidad fuerte y revela el video hacia la derecha. Mismo navy deep
   que el nav y secciones oscuras (palette-azure-700 = #101935). */
.hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  /* Triple capa de izq a der → final compositing:
     1. Capa base sólida — piso mínimo de oscuridad uniforme, evita que
        cualquier frame claro del video pierda contraste.
     2. Vignette vertical — refuerza top/bottom para legibilidad de nav
        y trust badges.
     3. Gradient horizontal — peso fuerte sobre el texto (izquierda),
        revela el video desde ~la mitad hacia la derecha. */
  background:
    linear-gradient(
      180deg,
      rgba(0, 0, 0, 0.26) 0%,
      rgba(0, 0, 0, 0.0) 30%,
      rgba(0, 0, 0, 0.0) 70%,
      rgba(0, 0, 0, 0.32) 100%
    ),
    linear-gradient(
      90deg,
      rgba(var(--palette-azure-700-rgb), 0.96) 0%,
      rgba(var(--palette-azure-700-rgb), 0.90) 45%,
      rgba(var(--palette-azure-700-rgb), 0.55) 65%,
      rgba(var(--palette-azure-700-rgb), 0.18) 85%,
      rgba(var(--palette-azure-700-rgb), 0.04) 100%
    ),
    rgba(var(--palette-azure-700-rgb), 0.10);
}

.hero__noise {
  position: absolute;
  inset: 0;
  z-index: 3;
  opacity: 0.03;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  background-repeat: repeat;
  background-size: 256px 256px;
  pointer-events: none;
}

.hero__content {
  position: relative;
  z-index: 4;
  max-width: var(--max-width);
  width: 100%;
  margin: 0 auto;
  padding: 0 1rem;
  color: var(--content-on-dark);
}

.hero-badge {
  /* Voz Luxury: pill bronce con dot lateral. Sobre fondo dark del hero,
     uso bronze-100 (más luminoso) para contraste AA. */
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-heading);
  font-size: var(--text-eyebrow);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgb(var(--palette-teal-100-rgb));
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(var(--palette-teal-400-rgb), 0.28);
  padding: 6px 14px;
  border-radius: 9999px;
  margin-bottom: clamp(2rem, 4vh, 2.75rem);
  font-variant-numeric: tabular-nums;
}

.hero-badge__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgb(var(--palette-teal-100-rgb));
  flex-shrink: 0;
  box-shadow: 0 0 0 3px rgba(var(--palette-teal-400-rgb), 0.15);
}

.hero__title {
  color: var(--content-on-dark);
  max-width: var(--hero-title-max-w);
  margin-bottom: clamp(2.75rem, 4.5vh, 3.75rem);
  text-shadow:
    0 1px 2px rgba(0, 0, 0, 0.55),
    0 4px 18px rgba(var(--palette-azure-700-rgb), 0.85);
}

.hero__subtitle {
  font-size: clamp(1rem, 1.3vw, 1.125rem);
  color: rgba(var(--content-on-dark-rgb),0.92);
  max-width: 640px;
  line-height: 1.7;
  margin-bottom: clamp(2.75rem, 5vh, 3.5rem);
  text-shadow:
    0 1px 2px rgba(0, 0, 0, 0.5),
    0 2px 12px rgba(var(--palette-azure-700-rgb), 0.75);
}

.hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}

.hero__microcopy {
  font-size: var(--text-caption);
  color: rgba(var(--content-on-dark-rgb),0.5);
  margin-bottom: 1.25rem;
}

/* CTA terciario del hero: "Descargar guía" como link de texto discreto
   (P1-4: jerarquía clara, un solo botón primario). */
.hero__guide-link {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin: -0.5rem 0 1.25rem;
  padding: 0;
  background: none;
  border: 0;
  cursor: pointer;
  font-family: inherit;
  font-size: var(--text-small);
  color: rgba(var(--content-on-dark-rgb),0.72);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color var(--transition-fast);
}
.hero__guide-link:hover { color: rgba(var(--content-on-dark-rgb),1); }
.hero__guide-link svg { flex: none; }

/* Cinturón de capacidades del hero — voz Luxury, hairline gold +
   glass navy. Posicionado después de los trust-badges como "credentials"
   bar inferior. Separación generosa del CTA stack vía margin-top fluido,
   coronado con un hairline dorado horizontal que separa visualmente. */
.hero__capabilities {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: clamp(2.5rem, 6vh, 4rem);
  padding-top: 1.25rem;
  border-top: 1px solid rgba(var(--palette-teal-500-rgb), 0.22);
  max-width: 880px;
}

.capability-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.45rem 0.95rem;
  font-family: var(--font-heading);
  font-size: var(--text-eyebrow);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.06em;
  color: rgb(var(--palette-teal-100-rgb));
  background: rgba(var(--palette-azure-700-rgb), 0.45);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid rgba(var(--palette-teal-500-rgb), 0.32);
  border-radius: 9999px;
  white-space: nowrap;
  transition: background 200ms ease, border-color 200ms ease, color 200ms ease;
}

@media (hover: hover) {
  .capability-pill:hover {
    background: rgba(var(--palette-azure-700-rgb), 0.62);
    border-color: rgba(var(--palette-teal-500-rgb), 0.5);
    color: rgb(var(--palette-teal-50-rgb));
  }
}

/* Stagger entrance — fade + slide-up secuencial, suma vida al hero sin
   competir con la animación principal del CTA. */
@media (prefers-reduced-motion: no-preference) {
  .capability-pill {
    opacity: 0;
    transform: translateY(8px);
    animation: capPillIn 600ms cubic-bezier(0.16, 1, 0.3, 1) forwards;
  }
  .capability-pill:nth-child(1) { animation-delay: 280ms; }
  .capability-pill:nth-child(2) { animation-delay: 340ms; }
  .capability-pill:nth-child(3) { animation-delay: 400ms; }
  .capability-pill:nth-child(4) { animation-delay: 460ms; }
  .capability-pill:nth-child(5) { animation-delay: 520ms; }
  .capability-pill:nth-child(6) { animation-delay: 580ms; }

  @keyframes capPillIn {
    to { opacity: 1; transform: translateY(0); }
  }
}

/* ══════════════════════════════════════════════════════════════════════
   HERO — variante "clean" (fondo video full-bleed como el original)
   Activada con ?hero=clean. Reusa .hero__video / .hero__overlay / .hero__noise
   para el fondo (mismo gradiente navy que protege la izquierda y revela el
   video a la derecha). Contenido minimal sobre fondo oscuro: título 44px/300
   + bajada + 1 CTA, en blanco. Sin badge/pills/urgency.
   ══════════════════════════════════════════════════════════════════════ */
.hero-clean {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: flex-end;         /* contenido abajo-izquierda (estilo Indfrag) */
  overflow: hidden;
  padding-block: clamp(6rem, 16vh, 9rem) var(--hero-toggle-band);
  background-color: var(--content-heading);
  color: var(--content-on-dark);
}

.hero-clean__inner {
  position: relative;
  z-index: 4;                    /* sobre video(1) / overlay(2) / noise(3) */
  width: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 1rem;
}

.hero-clean__content {
  width: 100%;                   /* la barra inferior abarca todo el container */
}

.hero-clean__title {
  font-size: var(--text-hero-clean);       /* 56px (36 en ≤768px) — spec .v6__h1 */
  font-weight: var(--font-weight-display); /* 300 Light */
  line-height: var(--lh-hero);             /* 1.2 */
  letter-spacing: var(--track-hero);       /* -0.02em */
  color: var(--content-on-dark);
  max-width: 37.5rem;                      /* ~600px — columna del título (4 líneas balanceadas a 56px) */
  margin: 1.6rem 0 1.4rem;                 /* spec .v6__h1 */
  text-wrap: balance;                      /* reparte palabras para igualar el largo de líneas */
  text-shadow:
    0 1px 2px rgba(0, 0, 0, 0.5),
    0 4px 18px rgba(var(--palette-azure-700-rgb), 0.8);
}

/* Palabra-clave del título en dorado vivo itálica (acento de marca sobre navy). */
.hero-clean__title-key {
  color: var(--brand-accent);   /* #C8A45D — buen contraste sobre el navy oscuro */
  font-style: italic;
  white-space: nowrap;          /* "por separado" siempre en una sola pieza */
}

.hero-clean__subtitle {
  font-size: var(--text-lead);             /* 18px — spec */
  font-weight: var(--font-weight-light);   /* 300 Light — spec */
  line-height: 1.6;                        /* §3 — antes 1.8 (más compacto) */
  color: rgba(var(--content-on-dark-rgb), 0.92);
  max-width: 46ch;
  margin: 0;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.45);
}

/* Barra inferior estilo Indfrag: kicker (izq) + CTA pill (der) entre 2 hairlines. */
.hero-clean__bar {
  display: flex;
  flex-direction: column;        /* CTA apilado debajo del microcopy */
  align-items: flex-start;
  gap: clamp(1rem, 2.5vh, 1.5rem);
  margin-top: clamp(2.5rem, 7vh, 4.5rem);  /* sube título+subtítulo; la barra queda fija abajo */
}

.hero-clean__kicker {
  margin: 0;
  font-size: var(--text-small);            /* 13px — §2 (antes 16); nivel más bajo de la jerarquía */
  font-weight: var(--font-weight-medium);
  color: rgba(var(--content-on-dark-rgb), 0.6);  /* blanco 60% — §2 (antes 85%) */
}

/* ── Hero CTA — pill indigo, círculo-flecha blanco a la izquierda ───────────
   Variante "inversa" del nav-cta (mismo sistema): allá pill blanco/círculo navy,
   acá pill indigo/círculo blanco. Misma microinteracción de rotación de flecha.
   width auto (sin .btn) → sin min-width/padding heredado que infle el ancho. */
.hero-cta {
  display: inline-flex;
  align-items: center;
  width: auto;                                /* el ancho sigue al contenido */
  min-width: 0;                               /* nada fuerza un ancho mínimo */
  gap: 0.625rem;                              /* 10px */
  padding: 0.625rem 1.125rem 0.625rem 0.5rem; /* ~10px vertical (más compacto) · der 18px · izq 8px (círculo pega) */
  background: var(--action-primary-bg);       /* indigo #6161FF */
  color: var(--content-on-brand);             /* texto blanco sobre indigo */
  border-radius: var(--radius-pill);
  font-family: var(--font-heading);
  font-size: var(--text-cta-lg);              /* 17px */
  font-weight: var(--font-weight-medium);     /* 500 */
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  transition: background var(--transition-base), transform var(--transition-fast);
}

.hero-cta__arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: none;
  width: 28px;                                /* círculo 28px — más compacto (era 30); apenas > nav (26) */
  height: 28px;
  border-radius: var(--radius-full);
  background: var(--surface-page);            /* círculo blanco */
  color: var(--action-primary-bg);            /* flecha indigo */
}

.hero-cta__arrow-icon {
  width: 15px;
  height: 15px;
  transition: transform 250ms ease;
}

.hero-cta:hover {
  background: var(--action-primary-bg-hover); /* indigo más oscuro */
}

/* ↗ (45°) → → (horizontal): misma rotación que el nav-cta */
.hero-cta:hover .hero-cta__arrow-icon {
  transform: rotate(45deg);
}

.hero-cta:active {
  transform: scale(0.98);
}

.hero-cta:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(var(--content-on-dark-rgb), 0.5);  /* anillo claro sobre el hero oscuro */
}

@media (prefers-reduced-motion: reduce) {
  .hero-cta__arrow-icon { transition: none; }
  .hero-cta:hover .hero-cta__arrow-icon { transform: none; }
}

@media (min-width: 768px) {
  .hero-clean__inner { padding: 0 1.5rem; }
}
@media (min-width: 1280px) {
  .hero-clean__inner { padding: 0 2rem; }
}

/* ====== 8. VALUE PROPOSITION ====== */

.value-section {
  background-color: var(--surface-warm);
  border-bottom: 1px solid var(--border-subtle);
}

.value-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}

/* .value-card y sus children → design-system.css */

/* ====== 9. SERVICES GRID ====== */

/* ════════════════════════════════════════════════════════════════════
   SECCIONES — tonal elevation automática
   Cada sección override --card-bg y --card-text según su propio fondo.
   ════════════════════════════════════════════════════════════════════ */

/* Sobre fondo muted (gris) → cards en blanco para destacar */
.services-section,
.process-section {
  --card-bg:   var(--card-bg-default);
  --card-text: var(--card-text-default);
}

/* Sobre fondo page (blanco) → cards en gris elevated para destacar */
.value-section,
.industries-section,
.why-section,
.about-section,
.sustainability-section {
  --card-bg:   var(--card-bg-elevated);
  --card-text: var(--card-text-default);
}

/* Sobre fondo dark → cards en variante dark */
[data-nav-theme="dark"] {
  --card-bg:   var(--card-bg-dark);
  --card-text: var(--card-text-on-dark);
}

.services-section {
  background-color: var(--surface-page);
}

.services-grid {
  display: grid;
  grid-template-columns: 1fr;
  grid-auto-rows: 1fr;
  gap: 1.5rem;
}

/* .service-card y sus children → design-system.css */

/* ====== 10. INDUSTRIES ====== */

.industries-section {
  background-color: var(--surface-warm);
}

.industries-grid {
  display: grid;
  grid-template-columns: 1fr;
  grid-auto-rows: 1fr;
  gap: 1.5rem;
}

.industry-card {
  position: relative;
  display: flex;
  align-items: center; /* centra icon+body cuando la row es más alta por otra card */
  gap: 1.25rem;
  /* Top padding deja respiro entre el .industry-card__tag (pill absoluto)
     y el contenido sin sobredimensionar la card. */
  padding: 3.75rem 1.75rem 1.75rem 1.75rem;
  background: var(--card-bg);
  color: var(--card-text);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-section);
  box-shadow: var(--shadow-card);
  height: 100%;
  transition: transform var(--transition-base),
              border-color var(--transition-base),
              box-shadow var(--transition-base),
              background-color var(--transition-base),
              color var(--transition-base);
}

.industry-card__icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: var(--brand-accent-soft);
  border-radius: var(--radius-sm);
  color: var(--brand-accent);
  transition: background-color var(--transition-base),
              color var(--transition-base);
}

.industry-card__icon .icon {
  width: 22px;
  height: 22px;
}

.industry-card__body {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  flex: 1;
  min-width: 0;
}



.industry-card__title {
  font-family: var(--font-heading);
  font-size: var(--text-h3);
  font-weight: var(--font-weight-medium);
  letter-spacing: -0.01em;
  color: var(--content-heading);
  line-height: var(--lh-h3);
  margin: 0 0 0.5rem 0;
  transition: color var(--transition-base);
}

.industry-card__desc {
  font-size: var(--text-body-lg);   /* 16px — era --text-h4 (14px) */
  color: var(--content-body);
  line-height: 1.5;                 /* era 1.6 */
  margin: 0;
  transition: color var(--transition-base);
}

/* ====== 11. PROCESS TIMELINE (Editorial Flow) ====== */

.process-section {
  background-color: var(--surface-page);
}

/* --- Timeline container --- */
.timeline {
  position: relative;
  max-width: 1000px;
  margin: 0 auto;
}

/* .timeline__line (mobile + desktop) → design-system.css */

/* --- Each row (mobile: vertical stack) --- */
.timeline__row {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1.25rem;
  position: relative;
  padding-left: 4.5rem;
  padding-bottom: 3.5rem;
}

.timeline__row--last {
  padding-bottom: 0;
}

/* --- Mobile: vertical connector --- */
.timeline__row::before {
  content: '';
  position: absolute;
  left: 27px;
  top: 56px;
  bottom: 0;
  width: 2px;
  background-image: repeating-linear-gradient(
    to bottom,
    var(--brand-accent) 0,
    var(--brand-accent) 8px,
    transparent 8px,
    transparent 18px
  );
}

.timeline__row--last::before {
  display: none;
}

/* --- Marker (numbered circle) --- */
.timeline__marker {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 2;
}

/* .timeline__number (marker visual) → design-system.css */

/* --- Content block --- */
.timeline__content {
  order: 1;
}

/* Voz Luxury — pill bronce mono caps (alineado al lenguaje del flow) */
.timeline__badge {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-heading);
  font-size: var(--text-eyebrow);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brand-accent-deep);
  background: rgba(200, 164, 93, 0.14);
  border: 1px solid rgba(var(--brand-accent-rgb), 0.24);
  padding: 4px 12px;
  border-radius: 9999px;
  margin-bottom: 0.875rem;
  font-variant-numeric: tabular-nums;
}

.timeline__title {
  font-family: var(--font-heading);
  font-size: var(--text-h4);
  font-weight: var(--font-weight-semibold);
  letter-spacing: -0.01em;
  line-height: 1.2;
  color: var(--content-heading);
  margin-bottom: 0.5rem;
}

.timeline__desc {
  font-size: var(--text-base); /* 15px */
  color: var(--content-body);
  line-height: 1.6;
  max-width: 420px;
}

/* --- Image block --- */
.timeline__image-wrap {
  order: 2;
  width: 100%;
}

.timeline__image-container {
  background: var(--surface-card);
  padding: 0.375rem;
  border-radius: 0.75rem;
  overflow: hidden;
  aspect-ratio: 16 / 9;
}

.timeline__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0.5rem;
  filter: grayscale(100%);
  transition: filter 0.7s ease;
}

/* Hover (desktop con puntero): pasa a un tono cálido bronce Luxury
   en lugar del color original full saturation — sepia + hue-rotate
   da el patina dorado coherente con --brand-accent. */
.timeline__image:hover {
  filter: sepia(55%) saturate(1.25) hue-rotate(-12deg) brightness(0.95);
}

/* Mobile sin hover: aplicar tono bronce permanentemente para no
   dejarles solo el B&W (no pueden disparar el hover) */
@media (hover: none) {
  .timeline__image {
    filter: sepia(55%) saturate(1.25) hue-rotate(-12deg) brightness(0.95);
  }
}

/* --- CTA --- */
.process-cta {
  text-align: center;
  margin-top: 4rem;
}

.process-cta__microcopy {
  display: block;
  font-size: var(--text-small);
  color: var(--brand-primary);
  margin-top: 0.75rem;
}

/* ====== 12. WHY ASPHARMA ====== */

.why-section {
  background-color: var(--surface-warm);
}

/* .why-grid y .why-text eliminados a favor de .section-header */

.differentials-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-linear-24); /* 24px según escala Linear */
}

/* .differential-card y sus children → design-system.css */

/* ====== 13. SUSTAINABILITY ====== */

.sustainability-section {
  position: relative;
  background-color: var(--surface-navy-deep);
  color: #fff;
  overflow: hidden;
  padding-top: var(--section-py);
  padding-bottom: var(--section-py);
}

.sustainability-section::before {
  content: '';
  position: absolute;
  inset: 0;
  opacity: 0.04;
  background-image: repeating-linear-gradient(
    45deg,
    transparent,
    transparent 40px,
    rgba(var(--brand-accent-rgb),0.3) 40px,
    rgba(var(--brand-accent-rgb),0.3) 41px
  );
  pointer-events: none;
}

.sustainability-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  position: relative;
  z-index: 1;
}

/* Voz Luxury — pill bronce con tinte on-dark.
   La sección sustainability tiene data-nav-theme="dark" sobre la imagen
   de fondo, así que reutilizo el patrón de overrides on-dark. */
/* Patrón "H2 Split" sobre fondo oscuro — línea 1 de contexto (blanco 45%). */
.sustainability-eyebrow {
  display: block;
  font-family: var(--font-heading);
  font-size: var(--text-h2);              /* 38px (26 móvil) */
  font-weight: var(--font-weight-display); /* 300 */
  line-height: var(--lh-h2);              /* 1.10 */
  letter-spacing: var(--track-h2);        /* -0.04em */
  text-transform: none;
  color: rgba(255, 255, 255, 0.45);
  margin-bottom: 0;
}

.sustainability-title {
  color: #fff;
  margin-bottom: 1rem;
  font-weight: var(--font-weight-regular); /* 400 — main del split */
}

.sustainability-subtitle {
  font-size: clamp(1rem, 1.5vw, 1.0625rem);
  color: rgba(var(--content-on-dark-rgb),0.75);
  line-height: 1.7;
  margin-bottom: 2rem;
}

.sustainability-points {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 2rem;
}

/* Hairline bronze entre items — voz editorial.
   Reemplaza el gap por un separador sutil. */
.sustainability-point {
  display: flex;
  align-items: center;
  gap: 0.875rem;
  padding: 1rem 0;
}

.sustainability-point + .sustainability-point {
  border-top: 1px solid rgba(var(--palette-teal-400-rgb), 0.18);
}

/* Check bronze suave en lugar de verde — voz Luxury (mismo tonal que
   .faq-luxury__rich-list-check). */
.sustainability-point__icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  background: rgba(var(--palette-teal-400-rgb), 0.18);
  border-radius: 50%;
  color: rgb(var(--palette-teal-100-rgb));
}

.sustainability-point__icon .icon {
  width: 18px;
  height: 18px;
}

.sustainability-point__text {
  font-size: var(--text-base);
  color: rgba(var(--content-on-dark-rgb),0.9);
}

.sustainability-visual {
  display: none;
}

.sustainability-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius-section);
  display: block;
}

/* ====== 14. ABOUT US ====== */

.about-section {
  background-color: var(--surface-page);
}

.about-content {
  max-width: 56rem;
  margin: 0 auto;
  text-align: center;
}

.about-content__title {
  margin-bottom: 2rem;
}

.about-content__text {
  font-size: clamp(1rem, 1.5vw, 1.0625rem);
  color: var(--content-body);
  line-height: 1.8;
  margin-bottom: 1.25rem;
}

.about-content__text:last-of-type {
  margin-bottom: 0;
}

.stats-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  margin-top: 3rem;
}

/* Voz Luxury: editorial left-align con value XXL bronze + caption discreta
   (replica el .faq-bento__creds del FAQ Bento — tonal warm + hairline
   bronze + numerología grande con peso ligero). */
.stat-card {
  text-align: left;
  padding: 1.5rem 1.75rem 1.75rem;
  background: rgba(200, 164, 93, 0.05);
  border: 1px solid var(--border-subtle);
  border-radius: 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  height: 100%;
}

.stat-card__kpi {
  display: flex;
  align-items: baseline;
  justify-content: flex-start;
  gap: 0.25rem;
  margin-bottom: 0;
}

/* Variante con ícono — mismo alto que el KPI para uniformar la grid */
.stat-card__icon {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  height: 3rem;
  margin-bottom: 0;
  color: var(--brand-accent);
}

.stat-card__icon .icon {
  width: 2.5rem;
  height: 2.5rem;
}

.stat-card__value {
  font-family: var(--font-heading);
  font-size: var(--text-figure);
  font-weight: 300; /* peso ligero — voz editorial */
  color: var(--brand-accent-text-strong);   /* #8B6E2E — era --brand-accent (#C8A45D, 2.35:1) */
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.025em;
  line-height: 1;
}

.stat-card__unit {
  font-family: var(--font-heading);
  font-size: var(--text-eyebrow);
  font-weight: var(--font-weight-medium);
  color: var(--brand-accent-deep);   /* #6B5320 — era --brand-accent (2.35:1) */
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-variant-numeric: tabular-nums;
  line-height: 1.2;
  margin-left: 0.5rem;
}

.stat-card__title {
  font-family: var(--font-heading);
  font-size: var(--text-body-lg);
  font-weight: var(--font-weight-medium);
  letter-spacing: -0.005em;
  line-height: 1.35;
  color: var(--content-heading);
  margin-bottom: 0;
  padding-top: 0.25rem;
  border-top: 1px solid var(--border-subtle);
}

.stat-card__desc {
  font-size: var(--text-small);
  color: var(--content-muted);
  line-height: 1.55;
}

/* ====== 15. FAQ ACCORDION (Editorial Layout) ====== */

.bg-surface {
  background-color: var(--surface-card);
}

/* Two-column layout: editorial proportions (sidebar amplio + accordion empujado a la derecha) */
.faq-layout {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}

@media (min-width: 1024px) {
  .faq-layout {
    display: grid;
    /* Sidebar con ancho fijo, main toma el resto.
       Aumentando el gap el main se empuja a la derecha sin tocar el sidebar. */
    grid-template-columns: 28rem 1fr;
    gap: clamp(4rem, 10vw, 9rem);
  }
}

/* Left sidebar */
.faq-layout__sidebar {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

@media (min-width: 1024px) {
  .faq-layout__sidebar {
    position: sticky;
    top: 8rem;
    height: max-content;
  }
}

/* Right accordion column */
.faq-layout__main {
  display: flex;
  flex-direction: column;
  flex: 1;
}

/* Support badge */
.faq-support-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.375rem 0.875rem;
  border-radius: 9999px;
  background-color: var(--palette-gray-200);
  color: var(--brand-primary);
  font-family: var(--font-body);
  font-size: var(--text-caption);
  font-weight: var(--font-weight-subhead);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-bottom: 1rem;
  box-shadow: 0 1px 2px rgba(0,0,0,0.05);
  border: 1px solid var(--color-outline-variant);
}

/* Sidebar title */
.faq-header__title {
  font-family: var(--font-heading);
  font-size: clamp(1.75rem, 4vw, 2rem);  /* tope 32px — H2 Lubrizol */
  font-weight: var(--font-weight-display);
  color: var(--content-heading);
  line-height: var(--lh-heading);
  letter-spacing: var(--track-h2);
  margin-bottom: 0.75rem;
}

.faq-header__subtitle {
  font-family: var(--font-body);
  color: var(--content-muted);
  font-size: var(--text-small);
  line-height: var(--lh-body);
  max-width: 26rem;
  margin-bottom: 1.5rem;
}

/* CTA card in sidebar */
.faq-contact-card {
  background-color: var(--content-heading);
  padding: 1.25rem;
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-ambient);
  width: 100%;
  max-width: 24rem;
}

.faq-contact-card__title {
  font-family: var(--font-heading);
  font-weight: var(--font-weight-heading);
  font-size: var(--text-body-lg);
  color: #fff;
  margin-bottom: 0.375rem;
}

.faq-contact-card__text {
  font-family: var(--font-body);
  color: rgba(var(--content-on-dark-rgb),0.7);
  font-size: var(--text-small);
  margin-bottom: 1rem;
  line-height: 1.5;
}

.faq-contact-card__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  gap: 0.5rem;
  background-color: var(--action-primary-bg);
  color: var(--action-primary-text);
  border: none;
  font-family: var(--font-heading);
  font-weight: var(--font-weight-subhead);
  font-size: var(--text-body);
  padding: 0.625rem 1.25rem;
  transition: background-color var(--transition-base), transform var(--transition-base), box-shadow var(--transition-base);
  border-radius: 0.375rem;
  box-shadow: var(--shadow-cta);
}

.faq-contact-card__btn:hover {
  background-color: var(--action-primary-bg-hover);
  transform: translateY(-2px);
  box-shadow: 0 14px 30px -5px rgba(var(--action-primary-bg-rgb),0.4);
}

/* Accordion items as separated rows (editorial style — IOH-inspired) */
.faq-item {
  border-bottom: 1px solid var(--border-subtle);
  transition: background-color var(--transition-base);
  overflow: hidden;
}

.faq-item:first-child {
  border-top: 1px solid var(--border-subtle);
}

.faq-item:hover .faq-item__question {
  color: var(--brand-accent-hover);
  font-weight: var(--font-weight-subhead);
}

.faq-item:hover .faq-item__icon-wrap {
  border-color: var(--content-muted);
  color: var(--content-strong);
}

.faq-item__trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.25rem 0;
  text-align: left;
  background: transparent;
  cursor: pointer;
}

.faq-item__question {
  font-family: var(--font-heading);
  font-size: var(--text-body-lg);
  font-weight: var(--font-weight-medium);
  color: var(--content-heading);
  padding-right: 1rem;
  transition: color var(--transition-base);
}

.faq-item.is-active .faq-item__question {
  color: var(--brand-accent-hover);
}

/* +/- icon in (almost) square pill (IOH style) */
.faq-item__icon-wrap {
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  border-radius: var(--radius-xs);
  background-color: var(--surface-card);
  border: 1px solid var(--border-subtle);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--content-muted);
  transition: background-color var(--transition-base),
              border-color var(--transition-base),
              color var(--transition-base);
}

.faq-item.is-active .faq-item__icon-wrap {
  background-color: rgba(var(--brand-accent-rgb), 0.1);
  border-color: rgba(var(--brand-accent-rgb), 0.3);
  color: var(--brand-accent-hover);
}

.faq-item__icon-svg {
  transition: transform var(--transition-base);
}

.faq-item__line-vertical,
.faq-item__line-horizontal {
  transition: transform 250ms cubic-bezier(0.4, 0, 0.2, 1),
              opacity 250ms cubic-bezier(0.4, 0, 0.2, 1);
  transform-origin: center;
}

.faq-item.is-active .faq-item__line-vertical {
  transform: rotate(90deg);
  opacity: 0;
}

/* Panel — animación moderna con grid-template-rows (sin JS measure) */
.faq-item__panel {
  display: grid;
  grid-template-rows: 0fr;
  opacity: 0;
  transition: grid-template-rows 220ms cubic-bezier(0.4, 0, 0.2, 1),
              opacity 180ms cubic-bezier(0.4, 0, 0.2, 1);
}

.faq-item__panel.open {
  grid-template-rows: 1fr;
  opacity: 1;
}

.faq-item__content {
  min-height: 0;          /* requerido para que grid-template-rows colapse */
  overflow: hidden;       /* evita que el contenido se vea durante la animación */
  padding: 0 0 1.5rem 0;
  max-width: 48rem;
  transform: translateY(10px);
  transition: transform 320ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* Cuando está abierto: slide up + el padding bottom se anima */
.faq-item__panel.open .faq-item__content {
  transform: translateY(0);
}

.faq-item__panel:not(.open) .faq-item__content {
  padding-bottom: 0;
}

.faq-item__answer {
  font-size: var(--text-small);
  color: var(--content-body);
  line-height: var(--lh-body);
  margin-bottom: 0.5rem;
}

/* FAQ: Table */
.faq-table-wrap {
  margin-top: 0.75rem;
  overflow: hidden;
  border-radius: 0.5rem;
  border: 1px solid var(--border-subtle);
}

.faq-table-wrap .faq-table-scroll {
  overflow-x: auto;
}

.faq-table-wrap .data-table {
  width: 100%;
  min-width: 500px;
  border-collapse: collapse;
}

.data-table__head {
  background-color: var(--content-heading);
}

.data-table__head th {
  padding: 0.75rem 1rem;
  text-align: left;
  font-family: var(--font-heading);
  font-size: var(--text-small);
  font-weight: var(--font-weight-heading);
  color: #fff;
}

.data-table__head th.data-table__th--aspharma {
  color: #00BFAA;
  background-color: var(--content-strong);
}

.data-table__row {
  border-bottom: 1px solid var(--border-subtle);
  background-color: #fff;
}

.data-table__row--alt {
  background-color: var(--surface-muted);
}

.data-table__row:last-child {
  border-bottom: none;
}

.data-table__cell {
  padding: 0.75rem 1rem;
  font-size: var(--text-small);
  color: var(--content-body);
}

.data-table__cell--bold {
  font-weight: var(--font-weight-subhead);
  color: var(--content-heading);
}

.data-table__cell--teal {
  font-weight: var(--font-weight-heading);
  color: var(--brand-accent-hover);
}

/* FAQ: Pricing Card */
.pricing-card {
  margin-top: 0.75rem;
  padding: 0.875rem;
  background: rgba(var(--brand-accent-rgb), 0.05);
  border: 1px solid rgba(var(--brand-accent-rgb), 0.2);
  border-radius: var(--radius-card);
}

.pricing-card__title {
  font-size: var(--text-h4);
  font-weight: var(--font-weight-subhead);
  color: var(--content-heading);
  margin-bottom: 0.5rem;
}

.pricing-card__items {
  display: flex;
  flex-direction: column;
}

.pricing-card__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.375rem 0;
  border-bottom: 1px solid var(--border-subtle);
}

.pricing-card__row:last-child {
  border-bottom: none;
}

.pricing-card__label {
  font-size: var(--text-small);
  color: var(--content-body);
}

.pricing-card__range {
  font-size: var(--text-small);
  font-weight: var(--font-weight-heading);
  color: var(--brand-accent-hover);
}

.pricing-card__cta {
  margin-top: 0.75rem;
  font-size: var(--text-small);
  font-weight: var(--font-weight-subhead);
  color: var(--brand-primary);
}

/* FAQ: List */
.faq-list {
  margin-top: 0.75rem;
  padding: 0.875rem;
  background: rgba(34, 197, 94, 0.05);
  border: 1px solid rgba(34, 197, 94, 0.2);
  border-radius: 0.75rem;
}

.faq-list ul {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}

.faq-list__item {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  font-size: var(--text-small);
  color: var(--content-body);
}

.faq-list__icon {
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--state-success);
}

/* ====== 16. CONTACT FORM ====== */

/* ── Contact Section ── */
.contact-section {
  background: linear-gradient(135deg, var(--content-heading) 0%, var(--content-strong) 100%);
  padding: 2rem 0;
}

/* Success message */
.form-success {
  text-align: center;
  padding: 3rem 2rem;
  background: #fff;
  border-radius: 1rem;
  box-shadow: 0 4px 12px rgba(0,0,0,0.06), 0 12px 28px rgba(0,0,0,0.10);
  max-width: 480px;
  margin: 0 auto;
}

.form-success__icon {
  width: 56px;
  height: 56px;
  background: var(--brand-accent);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.25rem;
}

.form-success__title {
  font-family: var(--font-heading);
  font-size: var(--text-h3);
  font-weight: var(--font-weight-heading);
  color: var(--content-heading);
  line-height: 1.4;
}

/* Contact Layout: sidebar + card side by side */
.contact-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  align-items: start;
}

/* ── Sidebar (white text on dark bg, no card) ── */
.contact-sidebar {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  padding: 0.5rem 0;
}

.contact-sidebar__header {
  margin-bottom: 0.25rem;
}

.contact-sidebar__title {
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 3vw, 2rem);  /* tope 32px — H2 Lubrizol */
  font-weight: var(--font-weight-display);
  color: #fff;
  line-height: var(--lh-heading);
  letter-spacing: var(--track-h2);
  margin-bottom: 0.5rem;
}

.contact-sidebar__subtitle {
  font-size: var(--text-body-lg);
  color: rgba(var(--content-on-dark-rgb),0.75);
  line-height: 1.5;
}

.contact-sidebar__label {
  font-family: var(--font-heading);
  font-size: var(--text-eyebrow);
  font-weight: var(--font-weight-heading);
  color: rgba(var(--content-on-dark-rgb),0.5);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.sidebar-steps {
  display: flex;
  flex-direction: column;
}

.sidebar-step {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding-bottom: 1rem;
  margin-bottom: 1rem;
  border-bottom: 1px solid rgba(var(--content-on-dark-rgb),0.1);
}

.sidebar-step:last-child {
  padding-bottom: 0;
  margin-bottom: 0;
  border-bottom: none;
}

.sidebar-step__number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  min-width: 26px;
  background: rgba(var(--content-on-dark-rgb),0.1);
  color: #fff;
  border-radius: 0.5rem;
  font-family: var(--font-heading);
  font-size: var(--text-caption);
  font-weight: var(--font-weight-heading);
}

.sidebar-step__heading {
  font-family: var(--font-heading);
  font-size: var(--text-h4);
  font-weight: var(--font-weight-heading);
  color: #fff;
  margin-bottom: 0.125rem;
}

.sidebar-step__text {
  font-size: var(--text-small);
  color: rgba(var(--content-on-dark-rgb),0.65);
  line-height: 1.4;
}

/* Sidebar badges */
.sidebar-badges {
  display: flex;
  gap: 1.25rem;
  padding-top: 0.25rem;
}

.sidebar-badge {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  font-family: var(--font-heading);
  font-size: var(--text-caption);
  font-weight: var(--font-weight-subhead);
  color: rgba(var(--content-on-dark-rgb),0.85);
}

.sidebar-badge svg {
  flex-shrink: 0;
  color: var(--brand-accent);
}

/* ── Form Card (white, floating) ── */
.contact-card {
  background: #fff;
  border-radius: 1rem;
  box-shadow: 0 4px 12px rgba(0,0,0,0.06), 0 12px 28px rgba(0,0,0,0.10);
  padding: 2rem;
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

/* Form rows */
.form-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 0.1875rem;
  position: relative;
}

/* ── Floating label ── */
.form-label {
  position: absolute;
  top: 50%;
  left: 0.75rem;
  transform: translateY(-50%);
  padding: 0 4px;
  color: var(--brand-primary);
  pointer-events: none;
  transition: top 0.2s ease, font-size 0.2s ease, color 0.2s ease, background-color 0.2s ease;
  font-family: var(--font-body);
  font-size: var(--text-label);
  font-weight: var(--font-weight-medium);
  text-transform: none;
  letter-spacing: normal;
  z-index: 1;
  background: transparent;
}

/* Float up — CSS for inputs/textarea (input + label siblings) */
.form-input:focus + .form-label,
.form-input:not(:placeholder-shown) + .form-label,
/* Float up — JS for selects and general */
.form-group.is-focused > .form-label,
.form-group.has-value > .form-label {
  top: 0;
  font-size: var(--text-caption);
  font-weight: var(--font-weight-medium);
  background: #fff;
}

/* Focus color */
.form-input:focus + .form-label,
.form-group.is-focused > .form-label {
  color: var(--brand-accent-deep);   /* #6B5320 — era --brand-accent (el foco además se marca por borde 2px + label flotante) */
}

/* Filled, not focused */
.form-input:not(:focus):not(:placeholder-shown) + .form-label,
.form-group.has-value:not(.is-focused) > .form-label {
  color: var(--brand-primary);
}

/* Error state on label */
.form-input[aria-invalid="true"] + .form-label,
.form-group.has-error > .form-label {
  color: var(--state-error) !important;
}

/* Textarea: label aligns to first line, not center */
.form-group--textarea > .form-label {
  top: 1rem;
  transform: none;
}

.form-group--textarea.is-focused > .form-label,
.form-group--textarea.has-value > .form-label,
.form-group--textarea .form-input:focus + .form-label,
.form-group--textarea .form-input:not(:placeholder-shown) + .form-label {
  top: 0;
  transform: translateY(-50%);
}

/* Phone nested group */
.phone-input-group {
  flex: 1;
}

.form-label__required {
  color: var(--state-error);
}

/* ── Input base ── */
.form-input {
  width: 100%;
  padding: 0.75rem;
  font-size: var(--text-base);
  font-family: var(--font-body);
  background: #fff;
  border: 1px solid var(--border-subtle);
  border-radius: 0.25rem;
  color: var(--content-heading);
  min-height: 44px;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.form-input::placeholder {
  color: transparent;
}

/* Override browser autofill tint (yellow/lavender) so el bg del input se mantiene
   blanco y matchea el bg del floating label. */
.form-input:-webkit-autofill,
.form-input:-webkit-autofill:hover,
.form-input:-webkit-autofill:focus,
.form-input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 1000px #fff inset !important;
  -webkit-text-fill-color: var(--content-strong) !important;
  caret-color: var(--content-strong);
  transition: background-color 5000s ease-in-out 0s;
}

.form-input:focus-visible {
  outline: none;
  box-shadow: none;
  border-width: 2px;
  border-color: var(--brand-primary);
  padding: calc(0.75rem - 1px);         /* compensa +1px del border, evita layout shift */
}

.form-input[aria-invalid="true"] {
  border-width: 2px;
  border-color: var(--state-error);
  padding: calc(0.75rem - 1px);
}

/* Phone input split */
.phone-wrapper {
  display: flex;
  gap: 0.5rem;
}

.phone-code-wrapper {
  width: 105px;
  min-width: 105px;
}

.phone-code-wrapper .select-arrow {
  right: 0.375rem;
}

.phone-code {
  padding-right: 1.5rem !important;
  padding-left: 0.5rem !important;
  font-size: var(--text-body) !important;
  text-align: center;
}

.phone-number {
  flex: 1;
}

/* Select wrapper */
.select-wrapper {
  position: relative;
}

.form-select {
  appearance: none;
  padding-right: 2.5rem;
  cursor: pointer;
}

.select-arrow {
  position: absolute;
  right: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  color: var(--brand-primary);
  display: flex;
}

/* ── Custom Select (cs) ── */
.cs {
  position: relative;
  width: 100%;
}

.cs__trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem;
  font-size: var(--text-base);
  font-family: var(--font-body);
  background: #fff;
  border: 1px solid var(--border-subtle);
  border-radius: 0.25rem;
  color: var(--content-heading);
  min-height: 44px;
  cursor: pointer;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  text-align: left;
}

.cs__trigger:focus-visible {
  outline: none;
  box-shadow: none;
  border-width: 2px;
  border-color: var(--brand-primary);
  padding: calc(0.75rem - 1px);
}

.cs__value {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cs__value--empty {
  color: transparent;
}

.cs__arrow {
  flex-shrink: 0;
  color: var(--brand-primary);
  transition: transform 0.2s ease;
  display: flex;
}

.cs.is-open .cs__arrow {
  transform: rotate(180deg);
}

.cs__dropdown {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  background: #fff;
  border: 1px solid var(--border-subtle);
  border-radius: 0.5rem;
  box-shadow: 0 10px 30px -5px rgba(0,0,0,0.12), 0 4px 10px -5px rgba(0,0,0,0.06);
  z-index: 50;
  display: none;
  overflow: hidden;
}

.cs.is-open .cs__dropdown {
  display: block;
}

.cs__search {
  width: 100%;
  padding: 0.5rem 0.75rem;
  border: none;
  border-bottom: 1px solid var(--border-subtle);
  font-family: var(--font-body);
  font-size: var(--text-body);
  color: var(--content-heading);
  background: var(--surface-card);
}

.cs__search:focus-visible {
  outline: none;
  background: #fff;
  box-shadow: inset 0 -2px 0 0 var(--brand-primary);  /* underline halo dentro del dropdown */
}

.cs__list {
  list-style: none;
  margin: 0;
  padding: 0.25rem 0;
  max-height: 220px;
  overflow-y: auto;
  overscroll-behavior: contain;
}

.cs__option {
  padding: 0.5rem 0.75rem;
  cursor: pointer;
  font-size: var(--text-body);
  color: var(--brand-primary);
  transition: background-color 0.1s ease;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.cs__option:hover,
.cs__option--active {
  background-color: var(--surface-card);
}

.cs__option--selected {
  color: var(--brand-accent-hover);
  font-weight: var(--font-weight-subhead);
}

.cs__flag {
  font-size: var(--text-lead);
  line-height: 1;
  flex-shrink: 0;
}

.cs__country {
  flex: 1;
}

.cs__code {
  color: var(--brand-primary);
  font-size: var(--text-small);
}

/* Phone code compact trigger */
.cs--phone .cs__trigger {
  padding: 0.75rem 0.5rem;
  gap: 0.25rem;
  font-size: var(--text-body);
}

.cs--phone .cs__dropdown {
  min-width: 260px;
  right: auto;
}

/* Divider */
.form-divider {
  display: flex;
  align-items: center;
  gap: 0.875rem;
  margin: 0.25rem 0 0.125rem;
}

.form-divider__line {
  flex: 1;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--border-subtle) 25%, var(--border-subtle) 75%, transparent);
}

.form-divider__text {
  font-family: var(--font-heading);
  font-size: var(--text-small);
  font-weight: var(--font-weight-heading);
  color: var(--brand-accent-hover);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  white-space: nowrap;
}

/* Textarea */
.form-textarea {
  resize: vertical;
  min-height: 64px;
}

.form-counter {
  font-size: var(--text-caption);
  color: var(--brand-primary);
  text-align: right;
  margin-top: -0.125rem;
}

/* Errors */
.form-error {
  font-size: var(--text-caption);
  color: var(--state-error);
  margin: 0;
}

.form-error-msg {
  padding: 0.75rem 1rem;
  border-radius: 0.5rem;
  font-size: var(--text-body);
  background: rgba(239,68,68,0.08);
  color: var(--state-error);
  border: 1px solid rgba(239,68,68,0.15);
}

.form-error-msg p {
  margin: 0;
}

/* ====== Form confirmation dialog (WCAG 3.3.6) ====== */
.form-confirm-dialog {
  border: 0;
  border-radius: var(--radius-lg, 12px);
  padding: 2rem;
  max-width: 480px;
  width: calc(100% - 2rem);
  background: var(--surface-page);
  color: var(--content-strong);
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.25);
}

.form-confirm-dialog::backdrop {
  background: rgba(0, 0, 0, 0.5);
}

.form-confirm-dialog__title {
  margin: 0 0 0.5rem;
  font-family: var(--font-heading);
  font-size: var(--text-subhead);
  color: var(--content-heading);
}

.form-confirm-dialog__intro {
  margin: 0 0 1.25rem;
  font-size: var(--text-base);
  color: var(--content-muted);
}

.form-confirm-dialog__data {
  margin: 0 0 1.5rem;
  padding: 1rem 1.25rem;
  background: var(--surface-card);
  border-radius: var(--radius-md, 8px);
  display: grid;
  grid-template-columns: minmax(120px, auto) 1fr;
  column-gap: 1rem;
  row-gap: 0.5rem;
}

.form-confirm-dialog__data dt {
  font-weight: var(--font-weight-medium);
  font-size: var(--text-small);
  color: var(--content-muted);
  margin: 0;
}

.form-confirm-dialog__data dd {
  margin: 0;
  font-size: var(--text-base);
  color: var(--content-strong);
  word-break: break-word;
}

.form-confirm-dialog__actions {
  display: flex;
  gap: 0.75rem;
  justify-content: flex-end;
  flex-wrap: wrap;
}

@media (max-width: 480px) {
  .form-confirm-dialog__data {
    grid-template-columns: 1fr;
    row-gap: 0.25rem;
  }
  .form-confirm-dialog__data dt {
    margin-top: 0.5rem;
  }
  .form-confirm-dialog__data dt:first-child {
    margin-top: 0;
  }
}

/* Consent disclaimer */
.form-consent {
  font-size: var(--text-legal);
  color: var(--brand-primary);
  line-height: 1.5;
  text-align: center;
  margin: 0;
}

.form-consent a {
  color: var(--brand-accent-hover);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.form-consent a:hover {
  color: var(--brand-accent-deep);   /* #6B5320 — era --brand-accent (2.35:1) */
}

/* Submit button (full width) */
.btn--submit {
  width: 100%;
  justify-content: center;
  padding: 0.75rem 2rem;
  font-size: var(--text-base);
  gap: 0.5rem;
  border-radius: 0.25rem;
  margin-top: 0.25rem;
  min-height: 44px;
}

.btn--submit .spinner {
  animation: spin 1s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Trust indicators (centered below button) */
.trust-indicators {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.25rem;
}

.trust-indicator {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  font-size: var(--text-eyebrow);
  font-weight: var(--font-weight-subhead);
  color: var(--brand-primary);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.trust-indicator svg {
  color: var(--brand-primary);
  flex-shrink: 0;
}

/* ====== 16. FINAL CTA ====== */

.final-cta {
  position: relative;
  background: var(--surface-navy-deep);
  overflow: hidden;
}

.final-cta::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(var(--brand-accent-rgb),0.08) 0%, transparent 70%);
  pointer-events: none;
}

/* Voz Luxury — card editorial: navy deep base + accent bar bronce top
   (replica el .faq-luxury__cta del FAQ Luxury con el mismo lenguaje). */
.final-cta__inner {
  position: relative;
  z-index: 1;
  text-align: center;
  max-width: 720px;
  margin: 0 auto;
  padding: 3rem 2.5rem 2.5rem;
  background: linear-gradient(180deg,
              rgba(255, 255, 255, 0.04) 0%,
              rgba(255, 255, 255, 0.01) 100%);
  border: 1px solid rgba(var(--palette-teal-400-rgb), 0.18);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 18px 48px -24px rgba(0, 0, 0, 0.5);
}

.final-cta__accent-bar {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg,
              transparent 0%,
              rgb(var(--palette-teal-100-rgb)) 50%,
              transparent 100%);
  /* Matchear el border-radius del .final-cta__inner (16px) */
  border-top-left-radius: 16px;
  border-top-right-radius: 16px;
}

.final-cta__urgency {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 5px 14px;
  border-radius: 9999px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(var(--palette-teal-400-rgb), 0.28);
  font-family: var(--font-heading);
  font-size: var(--text-eyebrow);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgb(var(--palette-teal-100-rgb));
  font-variant-numeric: tabular-nums;
  margin-bottom: 1.5rem;
}

.final-cta__urgency-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgb(var(--palette-teal-100-rgb));
  flex-shrink: 0;
  box-shadow: 0 0 0 3px rgba(var(--palette-teal-400-rgb), 0.15);
}

.final-cta__title {
  color: #fff;
  margin-bottom: 1rem;
}

.final-cta__text {
  font-size: clamp(1rem, 1.5vw, 1.125rem);
  color: rgba(var(--content-on-dark-rgb),0.75);
  line-height: 1.7;
  margin-bottom: 2rem;
}

.final-cta__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
}

/* ====== 17. FOOTER ====== */

.footer {
  background-color: var(--content-heading);
  color: rgba(var(--content-on-dark-rgb),0.7);
  padding-top: var(--section-py);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid rgba(var(--content-on-dark-rgb),0.1);
}

.footer-brand__lockup {
  display: inline-flex;
  align-items: center;
  gap: 0.625rem;
  margin-bottom: 1rem;
  line-height: 1;
}

.footer-brand__logo {
  flex-shrink: 0;
  height: 32px;
  width: auto;
  display: block;
  margin: 0;
}

.footer-brand__name {
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.01em;
  color: rgba(255, 255, 255, 0.92);
  white-space: nowrap;
  line-height: 1;
}

.footer-brand__name-suffix {
  font-weight: 400;
  color: rgba(255, 255, 255, 0.6);
  letter-spacing: 0.04em;
}

.footer-brand__tagline {
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: var(--font-weight-subhead);
  color: rgba(var(--content-on-dark-rgb),0.9);
  margin-bottom: 0.75rem;
}

.footer-brand__desc {
  font-size: var(--text-body);
  line-height: 1.6;
  margin-bottom: 1.5rem;
}

.footer-social {
  display: flex;
  gap: 0.75rem;
}

/* Redes reubicadas al final de la columna de Contacto. */
.footer-social--contact {
  margin-top: 1.25rem;
}

.footer-social__link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: 1px solid rgba(var(--content-on-dark-rgb),0.15);
  border-radius: 0.5rem;
  color: rgba(var(--content-on-dark-rgb),0.7);
  transition: border-color var(--transition-fast),
              color var(--transition-fast),
              transform var(--transition-base);
}

.footer-social__link:hover {
  border-color: var(--brand-accent);
  color: var(--brand-accent);
  transform: translateY(-2px);
}

.footer-social__link .icon {
  width: 20px;
  height: 20px;
}

/* "Coming soon" — placeholders sin URL real (no clickeable, sin link roto). */
.footer-social__link--coming,
.footer-brand__privacy--coming {
  opacity: 0.45;
  cursor: default;
}

.footer-column__title {
  font-family: var(--font-heading);
  font-size: var(--text-h4);
  font-weight: var(--font-weight-heading);
  color: #fff;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-bottom: 1.25rem;
}

.footer-column__link {
  display: block;
  font-size: var(--text-body);
  padding: 0.25rem 0;
  transition: color var(--transition-fast);
  min-height: 44px;
  display: flex;
  align-items: center;
}

.footer-column__link:hover {
  color: var(--brand-accent);
}

.footer-contact__item {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  font-size: var(--text-body);
  margin-bottom: 0.75rem;
  line-height: 1.45;
}

.footer-contact__item .icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  color: var(--brand-accent);
  margin-top: 2px;
}

.footer-contact__item--link {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition-fast);
}

.footer-contact__item--link:hover,
.footer-contact__item--link:focus-visible {
  color: var(--brand-accent);
}

.footer-contact__item--link:hover .icon,
.footer-contact__item--link:focus-visible .icon {
  color: var(--brand-accent-vivid, var(--brand-accent));
}

.footer-contact__address {
  display: flex;
  flex-direction: column;
}

.footer-contact__address-line {
  display: block;
  white-space: nowrap;
}

.footer-bottom {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 0.25rem 1.5rem;
  padding: 1.5rem 0;
  font-size: var(--text-small);
}

.footer-bottom__copyright {
  white-space: nowrap; /* mantener "© 2026 ASPharma..." en una sola línea */
  overflow: hidden;
  text-overflow: ellipsis;
}

.footer-bottom__credit {
  opacity: 0.85;
  font-size: var(--text-legal);
}

.footer-bottom__credit-link {
  color: var(--brand-accent);
  font-weight: 500;
  text-decoration: none;
  border-bottom: 1px solid rgba(var(--brand-accent-rgb), 0.35);
  transition: color var(--transition-fast), border-color var(--transition-fast);
}

@media (hover: hover) {
  .footer-bottom__credit-link:hover {
    color: var(--palette-teal-400);
    border-bottom-color: rgba(var(--palette-teal-400-rgb), 0.7);
  }
}

.footer-bottom__credit-link:focus-visible {
  outline: 2px solid var(--palette-teal-400);
  outline-offset: 3px;
  border-radius: 2px;
}

/* Privacy link movido a la columna brand, debajo de social */
.footer-brand__privacy {
  display: inline-block;
  margin-top: 1rem;
  font-size: var(--text-small);
  transition: color var(--transition-fast);
}

.footer-brand__privacy:hover {
  color: var(--brand-accent);
}

/* ====== 17b. LEGAL PAGE (privacidad / privacy) ====== */
/* Página editorial sobria bajo identidad Luxury: cream paper, gold
   cálido para eyebrow/índices, navy deep para títulos. Columna única
   estrecha para lectura cómoda de texto legal. */
.legal {
  background: var(--surface-warm);
  /* nav-height = 4.5rem; cushion editorial 0.75-1.5rem encima.
     Total mobile 5.25rem (12px clearance) → desktop 6rem (24px clearance). */
  padding-top: clamp(5.25rem, 5vw, 6rem);
  padding-bottom: clamp(4rem, 8vw, 6.5rem);
}

.legal__container {
  max-width: 760px;
}

.legal__header {
  padding-bottom: 2rem;
  border-bottom: 1px solid rgba(var(--brand-accent-rgb), 0.22);
  margin-bottom: 2.75rem;
}

.legal__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: var(--text-legal);
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brand-accent-deep);
}

.legal__eyebrow-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--brand-accent);
}

.legal__title {
  font-family: var(--font-heading);
  font-weight: var(--font-weight-display);
  font-size: var(--text-legal-title);    /* 40px (28 móvil) — spec v2.0 */
  line-height: var(--lh-h2);              /* 1.10 */
  letter-spacing: var(--track-display);   /* -0.04em */
  color: var(--content-heading);
  margin: 0.75rem 0 0.5rem;
}

.legal__updated {
  font-size: var(--text-small);
  color: var(--content-muted);
  margin: 0;
}

.legal__intro {
  font-size: var(--text-lead);
  line-height: 1.7;
  color: var(--content-strong);
  margin: 0 0 2.5rem;
}

.legal__section {
  margin-bottom: 2.5rem;
}

.legal__heading {
  display: flex;
  align-items: baseline;
  gap: 0.625rem;
  font-family: var(--font-heading);
  font-weight: var(--font-weight-heading);
  font-size: var(--text-h3);
  line-height: 1.3;
  color: var(--content-heading);
  margin: 0 0 0.875rem;
}

.legal__heading-index {
  flex-shrink: 0;
  font-size: var(--text-figure-md);
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.01em;
  color: var(--content-muted);
  font-variant-numeric: tabular-nums;
}

.legal__p {
  font-size: var(--text-base);
  line-height: 1.75;
  color: var(--content-body);
  margin: 0 0 1rem;
}

.legal__list {
  list-style: none;
  margin: 0 0 1rem;
  padding: 0;
}

.legal__list-item {
  position: relative;
  padding-left: 1.5rem;
  font-size: var(--text-base);
  line-height: 1.7;
  color: var(--content-body);
  margin-bottom: 0.625rem;
}

.legal__list-item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.65em;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(var(--brand-accent-rgb), 0.65);
}

.legal__box {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  padding: 1.25rem 1.5rem;
  margin: 0 0 1rem;
  background: var(--palette-gray-0);
  border: 1px solid rgba(var(--brand-accent-rgb), 0.2);
  border-left: 3px solid var(--brand-accent);
  border-radius: var(--radius-sm);
}

.legal__box-line {
  font-size: var(--text-base);
  line-height: 1.55;
  color: var(--content-strong);
}

.legal__box-line:first-child {
  font-weight: 600;
  color: var(--content-heading);
}

/* Subsección dentro de una sección legal (3.1, 3.2, 8.1, etc.) */
.legal__h3 {
  margin: 1.5rem 0 0.625rem;
  font-size: var(--text-body-lg);
  font-weight: 600;
  color: var(--content-heading);
  letter-spacing: -0.005em;
}

/* Enlace dentro de un párrafo / lista legal */
.legal__link {
  color: var(--brand-accent-deep);   /* #6B5320 — era --brand-accent (2.35:1) */
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
  transition: color var(--transition-base);
}
.legal__link:hover,
.legal__link:focus-visible {
  color: var(--content-heading);
  text-decoration-color: currentColor;
}

/* Tabla key-value para la sección 1 (Responsable del tratamiento) */
.legal__kv {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  margin: 0 0 1rem;
  padding: 0;
  border: 1px solid rgba(var(--brand-accent-rgb), 0.2);
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: var(--palette-gray-0);
}
.legal__kv-row {
  display: grid;
  grid-template-columns: minmax(140px, 0.35fr) 1fr;
  align-items: baseline;
  gap: 1rem;
  padding: 0.75rem 1.125rem;
  border-bottom: 1px solid rgba(var(--brand-accent-rgb), 0.12);
}
.legal__kv-row:last-child { border-bottom: none; }
.legal__kv-key {
  margin: 0;
  font-size: var(--text-small);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--content-muted);
}
.legal__kv-value {
  margin: 0;
  font-size: var(--text-base);
  line-height: 1.5;
  color: var(--content-strong);
}
@media (max-width: 640px) {
  .legal__kv-row {
    grid-template-columns: 1fr;
    gap: 0.25rem;
  }
}

/* Tabla genérica con headers (bases de licitud, plazos de conservación) */
.legal__table-wrap {
  margin: 0 0 1rem;
  overflow-x: auto;
  border: 1px solid rgba(var(--brand-accent-rgb), 0.2);
  border-radius: var(--radius-sm);
}
.legal__table {
  width: 100%;
  border-collapse: collapse;
  background: var(--palette-gray-0);
  font-size: var(--text-base);
}
.legal__table thead {
  background: rgba(var(--brand-accent-rgb), 0.08);
}
.legal__table th {
  padding: 0.75rem 1rem;
  text-align: left;
  font-size: var(--text-small);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--content-heading);
  border-bottom: 1px solid rgba(var(--brand-accent-rgb), 0.2);
}
.legal__table td {
  padding: 0.75rem 1rem;
  vertical-align: top;
  color: var(--content-strong);
  border-bottom: 1px solid rgba(var(--brand-accent-rgb), 0.12);
  line-height: 1.5;
}
.legal__table tbody tr:last-child td { border-bottom: none; }

/* ====== 18. FORM STATES ====== */


:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: var(--focus-ring-offset);
}

button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: var(--focus-ring-offset);
}

/* Sobre superficies oscuras el deep gold se pierde; usar gold claro
   palette-teal-400 (#D4B779, 8.6:1 sobre navy = AAA). */
[data-nav-theme="dark"] :focus-visible,
.surface-navy-deep :focus-visible,
.hero :focus-visible {
  outline-color: rgb(var(--palette-teal-400-rgb));
}

/* Loading spinner */
.btn--loading {
  position: relative;
  pointer-events: none;
  opacity: 0.8;
}

.btn--loading .btn__text {
  visibility: hidden;
}

.btn--loading::after {
  content: '';
  position: absolute;
  width: 20px;
  height: 20px;
  border: 2px solid rgba(var(--content-on-dark-rgb),0.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
}

/* ====== 19. KEYFRAMES ====== */

@keyframes spin {
  to { transform: rotate(360deg); }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes scaleIn {
  from {
    opacity: 0;
    transform: scale(0.95);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

/* ====== 20. SCROLL REVEAL ====== */

.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s cubic-bezier(0.4,0,0.2,1),
              transform 0.6s cubic-bezier(0.4,0,0.2,1);
}

.reveal.revealed {
  opacity: 1;
  transform: translateY(0);
}

/* Stagger children */
.reveal-stagger > .reveal:nth-child(1) { transition-delay: 0ms; }
.reveal-stagger > .reveal:nth-child(2) { transition-delay: 80ms; }
.reveal-stagger > .reveal:nth-child(3) { transition-delay: 160ms; }
.reveal-stagger > .reveal:nth-child(4) { transition-delay: 240ms; }
.reveal-stagger > .reveal:nth-child(5) { transition-delay: 320ms; }
.reveal-stagger > .reveal:nth-child(6) { transition-delay: 400ms; }

/* ====== 21. ACCESSIBILITY ====== */

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

  .reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }

  /* En reduced-motion no ocultamos el <video>: el browser respeta el
     atributo autoplay según preferencia, y queda el poster (hero-bg.svg)
     visible como imagen estática. Ocultarlo dejaba el hero plano sobre
     el overlay navy sin imagen detrás. */
  .hero__video {
    animation: none;
  }
}

/* ====== 22. MEDIA QUERIES ====== */

/* sm — 640px */
@media (min-width: 640px) {
  .section-container {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }

  .nav__inner,
  .stats-bar__container,
  .logos-bar__container {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }

  .value-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .services-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .industries-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .stats-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .form-row--2col {
    grid-template-columns: repeat(2, 1fr);
  }

  .phone-wrapper {
    grid-template-columns: 60px 1fr;
  }

  .differentials-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .footer-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* md — 768px */
@media (min-width: 768px) {
  .hero__content {
    padding: 0 1.5rem;
  }

  .contact-layout {
    grid-template-columns: 280px 1fr;
    gap: 2.5rem;
  }

  .sustainability-grid {
    /* Texto domina (1.15) sobre la imagen (0.85) — antes 1:1 dejaba a
       la imagen con demasiado peso visual sobre el texto editorial. */
    grid-template-columns: 1.15fr 0.85fr;
    align-items: stretch;
    gap: 3rem;
  }

  .sustainability-visual {
    display: flex;
    align-items: stretch;
    min-height: 100%;
    max-height: 520px;
  }
}

/* lg — 1024px */
@media (min-width: 1024px) {
  .nav__links {
    display: flex;
    margin-left: auto; /* empuja a la derecha */
    padding-right: 1rem; /* espacio antes del separador (era 1.5rem) */
    position: relative;
  }

  .nav__links::after {
    content: '';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: 16px;
    background-color: rgba(var(--content-on-dark-rgb), 0.72); /* mismo color que las letras del menú (.nav__link) */
  }

  .nav__actions {
    margin-left: 0; /* en desktop el auto pasa a los links */
  }

  .nav__cta {
    display: inline-flex;
  }

  .hamburger {
    display: none;
  }

  .value-grid {
    grid-template-columns: repeat(3, 1fr);
  }

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

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

  .contact-layout {
    grid-template-columns: 300px 1fr;
    gap: 3rem;
  }

  .contact-card {
    padding: 2.5rem;
  }

  /* Grid 2×2 en desktop — 4 cards horizontales se ven apretadas con
     value-card icon-left + body-right */
  .differentials-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--sp-linear-32);
  }

  /* --- Timeline: Editorial Flow alternating layout --- */
  .timeline__line {
    display: block;
    position: absolute;
    left: 50%;
    top: 0;
    bottom: 0;
    width: 2px;
    transform: translateX(-50%);
    background-image: repeating-linear-gradient(
      to bottom,
      var(--brand-accent) 0,
      var(--brand-accent) 8px,
      transparent 8px,
      transparent 18px
    );
    z-index: 0;
  }

  .timeline__row {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 3rem;
    padding-left: 0;
    padding-bottom: 0;
    margin-bottom: 5rem;
    position: relative;
    z-index: 1;
  }

  .timeline__row--last {
    margin-bottom: 0;
  }

  .timeline__row::before {
    display: none;
  }

  .timeline__marker {
    position: relative;
    flex-shrink: 0;
    z-index: 2;
  }

  .timeline__number {
    width: 64px;
    height: 64px;
    font-size: var(--text-figure-md);
  }

  .timeline__content {
    flex: 1;
    order: unset;
  }

  .timeline__image-wrap {
    flex: 1;
    order: unset;
  }

  .timeline__title {
    font-size: var(--text-h3-lg);
    margin-bottom: 0.75rem;
  }

  .timeline__desc {
    max-width: 100%;
  }

  /* LEFT rows: content (right-aligned) | marker | image */
  .timeline__row--left {
    flex-direction: row;
  }

  .timeline__row--left .timeline__content {
    order: 1;
    text-align: right;
  }

  .timeline__row--left .timeline__content .timeline__desc {
    margin-left: auto;
  }

  .timeline__row--left .timeline__marker {
    order: 2;
  }

  .timeline__row--left .timeline__image-wrap {
    order: 3;
  }

  /* RIGHT rows: image | marker | content (left-aligned) */
  .timeline__row--right {
    flex-direction: row;
  }

  .timeline__row--right .timeline__image-wrap {
    order: 1;
  }

  .timeline__row--right .timeline__marker {
    order: 2;
  }

  .timeline__row--right .timeline__content {
    order: 3;
    text-align: left;
  }

  .hero__content {
    padding: 0 2rem;
  }

  .footer-grid {
    grid-template-columns: 1.5fr 1fr 1fr 1fr;
  }
}

/* xl — 1280px */
@media (min-width: 1280px) {
  .section-container {
    padding-left: 2rem;
    padding-right: 2rem;
  }

  .nav__inner,
  .stats-bar__container,
  .logos-bar__container {
    padding-left: 2rem;
    padding-right: 2rem;
  }

  .contact-card {
    padding: 3rem;
  }
}

/* ====================================================================
   FASE 1 — UX/UI UPGRADE
   Stats Bar · Trust Badges · CTA Wrapper · Navbar Scroll-aware
   Regla: aditivo. No sobreescribir clases existentes.
   ==================================================================== */

/* ─── Stats Bar ─────────────────────────────────────────── */
.stats-bar {
  background: var(--surface-warm);
  border-top: 1px solid var(--border-subtle);
  border-bottom: 1px solid var(--border-subtle);
  padding: var(--sp-8) 0;
}

.stats-bar__container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-6);
  flex-wrap: wrap;
}

/* .stats-bar__item, __number, __plus, __label, __divider y su @media → design-system.css */

@media (max-width: 640px) {
  .stats-bar__container { gap: var(--sp-4); }
}

/* ─── Trust Badges ──────────────────────────────────────── */
.trust-badges {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--sp-2) var(--sp-4);
  margin-top: var(--sp-4);
  margin-bottom: var(--sp-6);
}

.trust-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--text-small);
  color: rgba(var(--content-on-dark-rgb), 0.75);
  font-weight: var(--font-weight-medium);
}

.trust-badge__icon {
  width: 14px;
  height: 14px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.5;
  flex-shrink: 0;
}

.trust-badge__sep {
  color: rgba(var(--content-on-dark-rgb), 0.3);
}

/* Variante para secciones de fondo claro */
.trust-badges--light .trust-badge {
  color: var(--content-muted);
  background: var(--surface-muted);
  border: 1px solid var(--border-subtle);
  padding: 4px 10px;
  border-radius: var(--radius-full);
}

.trust-badges--light .trust-badge__sep {
  color: var(--content-muted);
}

/* ─── CTA Wrapper + Microcopy ───────────────────────────── */
.cta-wrapper {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-2);
}

/* Variante para botones full-width (form submit) */
.cta-wrapper--block {
  display: flex;
  width: 100%;
}

.cta-wrapper--block .btn {
  width: 100%;
}

.cta-microcopy {
  font-size: var(--text-small);
  color: rgba(var(--content-on-dark-rgb), 0.65);
  font-weight: var(--font-weight-body);
  text-align: center;
  margin: 0;
}

/* Variante sobre fondos claros */
.cta-microcopy--dark {
  color: var(--content-muted);
}

/* ─── Navbar Scroll-aware (FASE 1) ───────────────────────
   Coexiste con .nav.scrolled / .nav--on-dark ya presentes.
   Se aplican como clases toggle adicionales por main.js.     */
.nav.navbar--transparent {
  background-color: transparent;
  box-shadow: none;
}

.nav.navbar--solid {
  background-color: rgba(var(--palette-azure-700-rgb), 0.88);
  box-shadow: 0 2px 20px rgba(0, 0, 0, 0.18);
}

/* Mismo color que navbar--solid — no diferenciamos por contexto. */
.nav.nav--on-dark.navbar--solid {
  background-color: rgba(var(--palette-azure-700-rgb), 0.88);
}

/* FASE 2 — Hover accent en cards → design-system.css */

/* ═══════════════════════════════════════════════════════════
   FASE 3 — Secciones nuevas de conversión
   1) Logos / certifications marquee
   2) Process timeline progress bar
   ═══════════════════════════════════════════════════════════ */

/* ─── 1) Logos marquee ─────────────────────────────────── */
.logos-bar {
  padding: var(--sp-8) 0;
  background: var(--surface-navy-deep);
  color: var(--content-on-brand);
  overflow: hidden;
}

.logos-bar__container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 1rem;
}

.logos-bar__eyebrow {
  text-align: center;
  font-size: var(--text-label);
  font-weight: var(--font-weight-subhead);
  color: rgba(var(--content-on-brand-rgb), 0.75);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--sp-6);
}

.logos-bar__track-wrapper {
  overflow: hidden;
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
          mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
}

.logos-bar__track {
  display: flex;
  align-items: center;
  gap: var(--sp-8);
  width: max-content;
  animation: marquee-scroll 30s linear infinite;
}

.logos-bar__track:hover {
  animation-play-state: paused;
}

/* FIX-6 (WCAG 2.2.2): pausa explícita disparada por el control del hero. */
.logos-bar__track.is-paused {
  animation-play-state: paused;
}

.logos-bar__item {
  font-size: var(--text-body);
  font-weight: var(--font-weight-heading);
  color: var(--content-on-brand);
  letter-spacing: 0.02em;
  white-space: nowrap;
  opacity: 0.8;
  transition: opacity var(--t-fast);
}

.logos-bar__item:hover {
  opacity: 1;
}

/* Variante con icono SVG: logo ARRIBA, palabra DEBAJO (badge vertical), en
   celdas separadas por un divisor sutil — estilo muro de certificaciones.
   Si no hay archivo en assets/images/certs/, aspharma_cert_icon() devuelve
   null y cae a solo texto en línea con los puntos separadores. */
.logos-bar__item--icon {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  padding: 0 1.75rem;
  text-align: center;
  font-size: var(--text-caption);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-left: 1px solid rgba(var(--content-on-brand-rgb), 0.16);
}

/* Caja apaisada: los logos de certificación reales son horizontales (FDA, NSF,
   ISO…); object-fit:contain los encaja sin deformar. */
.logos-bar__icon {
  width: 5.5rem;
  height: 3.6rem;
  flex: none;
  object-fit: contain;
  /* Monocromo uniforme sobre navy: brightness(0) aplana cualquier color (teal,
     negro de los íconos currentColor, etc.) a negro, e invert(1) lo lleva a
     blanco. Unifica los 9 logos a silueta blanca conservando el detalle vectorial,
     sin importar el color con que vino cada SVG. */
  filter: brightness(0) invert(1);
  opacity: 0.9;
  transition: opacity var(--t-fast);
}

.logos-bar__item--icon:hover .logos-bar__icon {
  opacity: 1;
}

/* Con celdas + divisor border-left, el punto separador sobra. */
.logos-bar__item--icon + .logos-bar__dot {
  display: none;
}

@media (max-width: 640px) {
  .logos-bar__item--icon {
    padding: 0 1.1rem;
    font-size: var(--text-eyebrow);
  }
  .logos-bar__icon {
    width: 4.25rem;
    height: 2.8rem;
  }
}

.logos-bar__dot {
  color: rgba(var(--content-on-brand-rgb), 0.4);
  font-size: var(--text-figure-md);   /* 24px — era 1.5rem (M1) */
}

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

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

/* ─── 2) Process timeline progress bar ───────────────── */
.process-timeline {
  margin-bottom: var(--sp-12);
  margin-top: var(--sp-4);
}

/* Voz Luxury — gradient bronce deep → bronze-bright (replica el
   .fb-rich-timeline del FAQ Bento). */
.process-timeline__bar {
  height: 4px;
  background: var(--border-subtle);
  border-radius: var(--radius-full);
  position: relative;
  margin: 0 2.5%;
  overflow: hidden;
}

.process-timeline__fill {
  height: 100%;
  width: 0;
  background: linear-gradient(90deg,
              rgb(var(--palette-teal-800-rgb)),
              rgb(var(--palette-teal-500-rgb)),
              rgb(var(--palette-teal-100-rgb)));
  border-radius: var(--radius-full);
  transition: width 1.5s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Trigger fill animation cuando el IntersectionObserver añade .revealed */
.process-timeline.revealed .process-timeline__fill {
  width: 100%;
}

.process-timeline__steps {
  display: flex;
  justify-content: space-between;
  margin-top: -10px;
  padding: 0 2%;
}

.process-timeline__step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-1);
  flex: 1;
  min-width: 0;
}

.process-timeline__dot {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--surface-page);
  border: 2px solid var(--border-subtle);
  transition: border-color var(--t-normal), background var(--t-normal);
  position: relative;
  z-index: 1;
}

.process-timeline__dot.active,
.process-timeline.revealed .process-timeline__dot {
  border-color: var(--brand-accent);
  background: var(--brand-accent);
}

/* Voz Luxury — labels mono caps tracking ancho */
.process-timeline__label {
  font-size: var(--text-eyebrow);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.10em;
  color: var(--content-heading);
  text-align: center;
  margin-top: var(--sp-2);
}

.process-timeline__week {
  font-size: var(--text-eyebrow);
  letter-spacing: 0.08em;
  color: var(--brand-accent-deep);
  text-align: center;
  font-variant-numeric: tabular-nums;
}

.process-timeline__total {
  text-align: center;
  margin-top: var(--sp-6);
  font-size: var(--text-eyebrow);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--content-muted);
  font-variant-numeric: tabular-nums;
}

.process-timeline__total strong {
  color: var(--brand-accent-deep);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.05em;
}

@media (max-width: 640px) {
  /* Convertir bar + steps en carrusel horizontal swipeable.
     El __total queda fuera del scroll, abajo. */
  .process-timeline {
    margin-left: calc(-1 * var(--sp-6));
    margin-right: calc(-1 * var(--sp-6));
  }

  .process-timeline__scroll {
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -ms-overflow-style: none;
    /* padding-top crea espacio para que los dots (que tienen margin-top: -10px
       sobre la bar) no queden recortados por el overflow del scroll wrapper */
    padding: 14px var(--sp-6) var(--sp-2);
    -webkit-overflow-scrolling: touch;
  }

  .process-timeline__scroll::-webkit-scrollbar { display: none; }

  .process-timeline__bar {
    min-width: 550px;
    margin: 0;
  }

  .process-timeline__steps {
    min-width: 550px;
    padding: 0;
  }

  .process-timeline__step {
    scroll-snap-align: center;
    min-width: 100px;
  }

  .process-timeline__label { font-size: var(--text-eyebrow); }
  .process-timeline__week  { display: inline; }

  /* Fade hint en bordes — sugerencia visual de "hay más" */
  .process-timeline {
    position: relative;
  }

  .process-timeline::before,
  .process-timeline::after {
    content: '';
    position: absolute;
    top: 0;
    width: var(--sp-6);
    height: calc(100% - 2rem);
    pointer-events: none;
    z-index: 2;
  }

  .process-timeline::before {
    left: 0;
    background: linear-gradient(to right, var(--surface-page), transparent);
  }

  .process-timeline::after {
    right: 0;
    background: linear-gradient(to left, var(--surface-page), transparent);
  }

  .process-timeline__total {
    margin-left: var(--sp-6);
    margin-right: var(--sp-6);
  }
}

/* ═══════════════════════════════════════════════════════════
   FASE 4 — Formulario multi-step
   Aditivo: coexiste con .contact-form, .form-group (floating),
   .select-wrapper, custom-select (.cs) ya existentes.
   ═══════════════════════════════════════════════════════════ */

/* ─── Success body paragraph ─────────────────────────── */
.form-success__body {
  font-size: var(--text-base);
  color: var(--content-body);
  line-height: 1.5;
  margin-top: 0.75rem;
  max-width: 360px;
  margin-left: auto;
  margin-right: auto;
}

/* ─── Progress bar ───────────────────────────────────── */
.form-progress {
  margin-bottom: 1rem;
}

.form-progress__bar {
  height: 4px;
  background: var(--border-subtle);
  border-radius: var(--radius-full);
  margin-bottom: 0.625rem;
  overflow: hidden;
}

.form-progress__fill {
  height: 100%;
  background: var(--brand-accent);
  border-radius: var(--radius-full);
  width: 50%;
  transition: width 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.form-progress__labels {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
}

.form-progress__label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: var(--text-small);
  color: var(--content-muted);
  font-weight: var(--font-weight-medium);
  transition: color var(--t-fast);
}

.form-progress__label.is-active {
  color: var(--brand-accent-deep);   /* #6B5320 — era --brand-accent (2.35:1) */
  font-weight: var(--font-weight-subhead);
}

.form-progress__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--border-subtle);
  border: 2px solid var(--border-subtle);
  transition: background var(--t-fast), border-color var(--t-fast);
}

.form-progress__label.is-active .form-progress__dot {
  background: var(--brand-accent);
  border-color: var(--brand-accent);
}

/* ─── Form steps (show/hide) ─────────────────────────── */
.form-step[hidden] { display: none; }
.form-step {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  animation: form-step-in 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

@keyframes form-step-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

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

/* ─── Step actions (back + submit, or single next) ── */
.form-step__actions {
  display: flex;
  gap: 0.75rem;
  align-items: stretch;
  justify-content: space-between;
  margin-top: 0.25rem;
}

.form-step__actions .btn--primary {
  flex: 1;
  justify-content: center;
}

.form-step__actions .btn--ghost {
  flex: 0 0 auto;
}

.form-step__actions--single {
  justify-content: stretch;
}

.form-step__actions--single .btn--next {
  width: 100%;
  justify-content: center;
}

/* Back button — ghost on light card */
.btn--back {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.75rem 1.125rem;
  border-radius: 0.5rem;
  background: transparent;
  color: var(--content-body);
  border: 1.5px solid var(--border-subtle);
  font-weight: var(--font-weight-subhead);
  font-size: var(--text-base);
  cursor: pointer;
  transition: border-color var(--t-fast), color var(--t-fast), background var(--t-fast);
}

.btn--back:hover {
  border-color: var(--content-body);
  color: var(--content-heading);
  background: rgba(0, 0, 0, 0.02);
}

/* Microcopy — block variant (centered under action) */
.cta-microcopy--block {
  display: block;
  text-align: center;
  margin-top: 0.75rem;
}

/* ─── Chips (radio group for tipo_proyecto) ─────────── */
.form-group--chips {
  /* spacing handled by .form-step gap */
}

.form-label--static {
  display: block;
  font-size: var(--text-small);
  font-weight: var(--font-weight-subhead);
  color: var(--brand-primary);
  margin-bottom: 0.625rem;
  letter-spacing: 0.01em;
}

.form-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.form-chip {
  display: inline-flex;
  position: relative;
  cursor: pointer;
  user-select: none;
}

.form-chip input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}

.form-chip > span {
  display: inline-block;
  padding: 0.5rem 1rem;
  border: 1.5px solid var(--border-subtle);
  border-radius: var(--radius-full);
  font-size: var(--text-body);
  font-weight: var(--font-weight-medium);
  color: var(--brand-primary);
  background: #fff;
  transition: border-color var(--t-fast), color var(--t-fast), background-color var(--t-fast);
  line-height: 1.2;
}

.form-chip:hover > span {
  border-color: var(--brand-accent);
  color: var(--brand-accent-hover);
}

.form-chip input[type="radio"]:checked + span {
  background: var(--brand-accent-soft);
  border-color: var(--brand-accent);
  color: var(--brand-accent-hover);
  font-weight: var(--font-weight-subhead);
}

.form-chip input[type="radio"]:focus-visible + span {
  outline: 2px solid var(--focus-ring);
  outline-offset: var(--focus-ring-offset);
}

/* Error state for chip group */
.form-group--chips.has-error .form-chip > span {
  border-color: rgba(229, 62, 62, 0.4);
}

.form-group--chips.has-error .form-label--static {
  color: #C53030;
}

/* ─── Inline validation — valid/invalid states ──────── */
.form-input.is-valid,
.form-group.is-valid .form-input {
  border-color: var(--brand-accent);
}

.form-input.is-invalid,
.form-group.has-error .form-input {
  border-color: #E53E3E;
}

/* ─── Responsive ─────────────────────────────────────── */
@media (max-width: 640px) {
  .form-progress__labels {
    font-size: var(--text-caption);
  }
  .form-step__actions {
    flex-direction: column-reverse;
  }
  .form-step__actions .btn--ghost,
  .form-step__actions .btn--primary {
    width: 100%;
  }
}

/* ====== 17c. LANDING PAGES (servicios / industrias — P1-1) ======
   Reutilizan el wrapper .legal (cream paper). Aquí: breadcrumb, lead,
   subtítulos h2, bloque CTA y enlaces relacionados. */
.landing-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
  font-size: var(--text-small);
  color: var(--content-body);
}
.landing-breadcrumb__link {
  color: var(--brand-accent-deep);
  text-decoration: none;
  transition: color var(--transition-fast);
}
.landing-breadcrumb__link:hover { color: var(--brand-primary); }
.landing-breadcrumb__sep { color: rgba(var(--brand-accent-rgb), 0.5); }
.landing-breadcrumb__current { color: var(--content-heading); font-weight: 500; }

.landing-page__lead {
  font-size: clamp(1.0625rem, 1.6vw, 1.25rem);
  line-height: 1.55;
  color: var(--content-body);
  margin: 0.75rem 0 0;
}

/* Señal de frescura (P2-2). */
.landing-page__updated {
  margin: 1.25rem 0 0;
  font-size: var(--text-small);
  color: var(--content-body);
  opacity: 0.65;
}
.landing-page__updated time { font-weight: 500; }

/* Trust strip de autoridad (P1-2): certs de la red de partners + datos. */
.landing-trust {
  margin-top: 2.5rem;
  padding: 1.5rem clamp(1.25rem, 3vw, 2rem);
  border: 1px solid rgba(var(--brand-accent-rgb), 0.22);
  border-radius: var(--radius-card);
  background: rgba(var(--brand-accent-rgb), 0.045);
}
.landing-trust__label {
  margin: 0 0 0.85rem;
  font-size: var(--text-caption);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brand-accent-deep);
}
.landing-trust__certs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  list-style: none;
  margin: 0 0 1.4rem;
  padding: 0;
}
.landing-trust__cert {
  font-size: var(--text-caption);
  font-weight: 500;
  color: var(--content-strong);
  background: var(--surface-page);
  border: 1px solid rgba(var(--brand-accent-rgb), 0.2);
  padding: 0.25rem 0.6rem;
  border-radius: var(--radius-pill);
}
/* Pill con icono SVG (fallback a solo texto si no hay archivo). Va sobre
   superficie clara, así que admite SVG a color institucional. */
.landing-trust__cert--icon {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding-left: 0.45rem;
}
.landing-trust__cert-icon {
  width: 1.25rem;
  height: 1.25rem;
  flex: none;
  object-fit: contain;
  /* Trust strip va sobre superficie clara: aquí el monocromo va en oscuro
     (brightness(0) aplana todo a negro, sin invert), atenuado para integrarse
     con el texto de la pill. */
  filter: brightness(0);
  opacity: 0.55;
}
.landing-trust__facts {
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem 2.25rem;
  list-style: none;
  margin: 0;
  padding: 0;
}
.landing-trust__fact {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}
.landing-trust__fact-v {
  font-family: var(--font-heading);
  font-size: var(--text-figure-md);
  font-weight: var(--font-weight-heading);
  color: var(--content-heading);
  line-height: 1.05;
}
.landing-trust__fact-l {
  font-size: var(--text-caption);
  color: var(--content-body);
  opacity: 0.72;
}
@media (max-width: 560px) {
  .landing-trust__facts { gap: 1rem 1.5rem; }
  .landing-trust__fact-v { font-size: var(--text-subhead); }
}

.landing-page__h2 {
  font-family: var(--font-heading);
  font-weight: var(--font-weight-display);
  font-size: clamp(1.375rem, 2.4vw, 1.625rem);
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--content-heading);
  margin: 2.5rem 0 1rem;
}

.landing-cta {
  margin-top: 3rem;
  padding: clamp(1.75rem, 4vw, 2.5rem);
  background: var(--surface-navy-deep);
  border-radius: var(--radius-card);
  text-align: center;
}
.landing-cta__title {
  font-family: var(--font-heading);
  font-weight: var(--font-weight-display);
  font-size: clamp(1.375rem, 2.6vw, 1.75rem);
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: #fff;
  margin: 0 0 0.5rem;
}
.landing-cta__text {
  font-size: var(--text-base);
  line-height: 1.55;
  color: rgba(var(--content-on-dark-rgb), 0.78);
  margin: 0 auto 1.5rem;
  max-width: 46ch;
}

.landing-related {
  margin-top: 2.5rem;
  padding-top: 1.75rem;
  border-top: 1px solid rgba(var(--brand-accent-rgb), 0.22);
}
.landing-related__label {
  display: block;
  font-size: var(--text-caption);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brand-accent-deep);
  margin-bottom: 0.75rem;
}
.landing-related__list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1.5rem;
  list-style: none;
  padding: 0;
  margin: 0;
}
.landing-related__link {
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--brand-primary);
  text-decoration: none;
  transition: color var(--transition-fast);
}
.landing-related__link:hover { color: var(--brand-primary-hover); }

/* Enlace "Conocer más" en las cards del hub que tienen página dedicada. */
.service-card__link,
.industry-card__link {
  position: relative;
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  gap: 0.3rem;
  /* auto empuja el link al fondo del body (flex column) → todos los "Conocer
     más" quedan alineados en la misma línea visual entre cards. El gap:0.5rem
     del __body mantiene un mínimo de aire cuando la descripción es larga. */
  margin-top: auto;
  padding-top: 0.75rem;
  padding-bottom: 0.2rem; /* sitio para el subrayado */
  font-size: var(--text-small);
  font-weight: 500;
  color: var(--brand-primary);
  text-decoration: none;
  transition: color var(--transition-fast);
}

/* Subrayado gradiente (oro→indigo) que crece desde la izquierda en hover/focus.
   El oro hace eco del borde dorado que la card adopta al elevarse → cohesión. */
.service-card__link::after,
.industry-card__link::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1.5px;
  background: linear-gradient(90deg, rgba(156, 140, 63, 0.9), var(--brand-primary));
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform var(--transition-base);
}

/* La flecha (span) desliza a la derecha; transform no reflowea, así el subrayado
   se mantiene estable bajo el texto. */
.service-card__link > span,
.industry-card__link > span {
  transition: transform var(--transition-fast);
}

/* Estado activo por teclado (a11y) — válido sin importar el tipo de puntero. */
.service-card__link:focus-visible,
.industry-card__link:focus-visible {
  color: var(--brand-primary-hover);
}
.service-card__link:focus-visible::after,
.industry-card__link:focus-visible::after {
  transform: scaleX(1);
}
.service-card__link:focus-visible > span,
.industry-card__link:focus-visible > span {
  transform: translateX(3px);
}

/* Hover solo en punteros finos (norma del proyecto). */
@media (hover: hover) {
  .service-card__link:hover,
  .industry-card__link:hover {
    color: var(--brand-primary-hover);
  }
  .service-card__link:hover::after,
  .industry-card__link:hover::after {
    transform: scaleX(1);
  }
  .service-card__link:hover > span,
  .industry-card__link:hover > span {
    transform: translateX(3px);
  }
}

/* Sin movimiento: el estado se conserva, pero sin animar crecimiento/slide. */
@media (prefers-reduced-motion: reduce) {
  .service-card__link::after,
  .industry-card__link::after,
  .service-card__link > span,
  .industry-card__link > span {
    transition: none;
  }
}

/* Fondo difuminado opcional (industrias): imagen muy suave confinada al
   header, fundida en el cream con máscara. El contenido va por encima. */
.landing-page--has-bg {
  position: relative;
  overflow: hidden;
}
.landing-page__bg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: clamp(340px, 46vh, 560px);
  z-index: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.12);          /* evita bordes vacíos del blur */
  filter: blur(12px) saturate(1.12);
  opacity: 0.6;
  pointer-events: none;
  -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,1) 0%, rgba(0,0,0,0.7) 55%, transparent 100%);
  mask-image: linear-gradient(to bottom, rgba(0,0,0,1) 0%, rgba(0,0,0,0.7) 55%, transparent 100%);
}
.landing-page--has-bg .legal__container {
  position: relative;
  z-index: 1;
}
@media (prefers-reduced-motion: reduce) {
  .landing-page__bg { transform: none; }
}

