/* productos.css — Landing genérico de productos (hub multimarca) Accredian
   Construido sobre main.css + insize.css. Solo estilos específicos de esta página. */
:root {
  --prod-navy: #003177;
  --prod-cyan: #0095D9;
}

/* [1] Hero superior */
.prod-hero { background: var(--prod-navy); color: #fff; padding: 96px 0 80px; text-align: center; }
.prod-hero-inner { max-width: 820px; margin: 0 auto; }
.prod-hero .hero-eyebrow { color: var(--prod-cyan); font-weight: 600; letter-spacing: .04em; text-transform: uppercase; font-size: .82rem; display: block; margin-bottom: 18px; }
.prod-hero .hero-title { font-family: 'Montserrat', sans-serif; font-weight: 800; font-size: clamp(2rem, 4vw, 3.1rem); line-height: 1.1; margin: 0 0 18px; color: #fff; }
.prod-hero .hero-subtitle { font-size: 1.12rem; color: #d6e2f2; max-width: 640px; margin: 0 auto 30px; }
.prod-hero .hero-cta-group { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.prod-hero .hero-response-note { margin-top: 18px; font-size: .9rem; color: #9fb6d6; }

/* Botones del hero/full-bleed — insize.css los scopea a .insize-hero, aquí los definimos para .prod-hero y .prod-fullbleed */
.prod-hero .btn-hero-primary, .prod-fullbleed .btn-hero-primary {
  display: inline-flex; align-items: center; gap: 8px; font-family: 'Poppins', sans-serif;
  font-size: 15px; font-weight: 600; padding: 14px 32px; border-radius: 50px;
  background-color: var(--prod-cyan); color: #fff; border: none; text-decoration: none;
  transition: transform .2s, box-shadow .2s; cursor: pointer;
}
.prod-hero .btn-hero-primary:hover, .prod-fullbleed .btn-hero-primary:hover {
  transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,.25); color: #fff; text-decoration: none;
}
.prod-hero .btn-hero-secondary {
  display: inline-flex; align-items: center; gap: 8px; font-family: 'Poppins', sans-serif;
  font-size: 15px; font-weight: 600; padding: 14px 32px; border-radius: 50px;
  background-color: transparent; color: #fff; border: 1.5px solid rgba(255,255,255,.35);
  text-decoration: none; transition: background-color .2s; cursor: pointer;
}
.prod-hero .btn-hero-secondary:hover { background-color: rgba(255,255,255,.08); color: #fff; text-decoration: none; }

/* [3] Franja de marcas (marquee-ready) */
.prod-brands { padding: 64px 0; background: #fff; }
/* section-label de insize.css está scopeado; aquí lo igualamos al overline cyan del resto */
.prod-brands .section-label { display: block; color: var(--prod-cyan); text-transform: uppercase; letter-spacing: 3px; font-weight: 700; font-size: 12px; margin-bottom: 28px; }
.brands-track { display: flex; align-items: center; justify-content: center; gap: 56px; flex-wrap: wrap; margin: 28px 0 10px; }
.brand-logo img { max-height: 56px; width: auto; filter: grayscale(100%); opacity: .75; transition: filter .25s, opacity .25s; }
.brand-logo:hover img { filter: none; opacity: 1; }
.brand-divider { width: 1px; height: 42px; background: #e2e6ee; }
.brands-note { color: #8a93a6; font-style: italic; font-size: .95rem; margin-top: 8px; }
/* Para activar marquee con 5+ logos: envolver en overflow:hidden y aplicar
   @keyframes prod-marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }
   .brands-track { animation: prod-marquee 22s linear infinite; }  (duplicar el set de logos) */
@media (max-width: 600px) { .brands-track { gap: 32px; } .brand-divider { display: none; } }

/* [6] Banner INSIZE */
.prod-insize-banner { padding: 72px 0; background: #f8f9fa; }
.insize-banner-card { display: grid; grid-template-columns: 1.1fr .9fr; align-items: center; gap: 0; background: var(--prod-navy); border-radius: 16px; overflow: hidden; box-shadow: 0 18px 50px rgba(0,49,119,.18); }
.insize-banner-text { padding: 48px 44px; color: #fff; }
.insize-banner-logo { height: 34px; filter: brightness(10); margin-bottom: 16px; }
.insize-banner-eyebrow { display: inline-block; background: var(--prod-cyan); color: #fff; font-size: .72rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; padding: 4px 12px; border-radius: 20px; margin-bottom: 14px; }
.insize-banner-title { font-family: 'Montserrat', sans-serif; font-weight: 800; font-size: clamp(1.7rem, 3vw, 2.4rem); margin: 0 0 12px; color: #fff; }
.insize-banner-sub { color: #d6e2f2; font-size: 1.05rem; margin: 0 0 26px; max-width: 460px; }
.btn-insize-banner { display: inline-flex; align-items: center; gap: 10px; background: var(--prod-cyan); color: #fff; font-weight: 700; padding: 14px 32px; border-radius: 50px; text-decoration: none; transition: transform .2s, background .2s; }
.btn-insize-banner:hover { background: #007cb8; transform: translateX(3px); color: #fff; }
.insize-banner-media { align-self: stretch; }
.insize-banner-media img { width: 100%; height: 100%; min-height: 280px; object-fit: cover; display: block; }

/* [8] Formulario — override: sin video, fondo navy directo */
.insize-quote { background: var(--prod-navy); }

/* [7] Franja imagen full-bleed */
.prod-fullbleed { position: relative; background: url('../img/insize/industries/metalmecanica.jpg') center/cover no-repeat; padding: 110px 0; text-align: center; color: #fff; }
.prod-fullbleed-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,49,119,.78), rgba(0,49,119,.86)); }
.prod-fullbleed-content { position: relative; max-width: 720px; }
.prod-fullbleed-content h2 { font-family: 'Montserrat', sans-serif; font-weight: 800; font-size: clamp(1.8rem, 3.4vw, 2.6rem); margin: 0 0 16px; color: #fff; }
.prod-fullbleed-content p { font-size: 1.12rem; color: #e6edf7; margin: 0 0 28px; }

@media (max-width: 768px) {
  .insize-banner-card { grid-template-columns: 1fr; }
  .insize-banner-text { padding: 36px 28px; }
  .insize-banner-media { order: -1; }
  .insize-banner-media img { min-height: 200px; }
}

/* [8] Form: hints opcionales + fallback de verificación */
.optional-hint { color: rgba(255,255,255,.5); font-weight: 400; font-size: .82em; }
.turnstile-fallback { margin: 10px 0 0; font-size: .9rem; color: #d6e2f2; }
.turnstile-fallback a { color: var(--prod-cyan); font-weight: 600; text-decoration: underline; }

/* WhatsApp flotante — bottom-left para no chocar con back-to-top (bottom-right) */
.wa-float {
  position: fixed; left: 20px; bottom: 22px; z-index: 1000;
  width: 56px; height: 56px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: #25D366; color: #fff; font-size: 26px;
  box-shadow: 0 6px 18px rgba(0,0,0,.28);
  transition: transform .2s, box-shadow .2s;
}
.wa-float:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(0,0,0,.34); color: #fff; }
@media (max-width: 480px) { .wa-float { width: 52px; height: 52px; font-size: 24px; left: 16px; bottom: 16px; } }

/* ════════════════════════════════════════════════════════════════
   ELEVACIÓN VISUAL — sistema "precisión de ingeniería" (estático)
   Distinción por jerarquía, escala y lenguaje gráfico de metrología.
   Fuentes bloqueadas (Montserrat/Poppins): el empuje es en tamaño,
   peso, hairlines, cotas y numeración técnica. Sin motion.
   ════════════════════════════════════════════════════════════════ */
:root {
  --prod-ink: #112243;        /* tinta navy para texto fuerte */
  --prod-line: rgba(0,49,119,.16);  /* hairline plano de ingeniería */
  --prod-surface: #f3f6fb;    /* neutro tintado (no gris puro) */
  --c-red: #c0392b; --c-amber: #d4891c; --c-green: #27764a; --c-blue: #1a6e9e;
}

/* — Retícula blueprint sutil en secciones navy (hero + formulario) — */
.prod-hero, .insize-quote { position: relative; isolation: isolate; }
.prod-hero::before, .insize-quote::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    repeating-linear-gradient(0deg, transparent 0 47px, rgba(255,255,255,.055) 47px 48px),
    repeating-linear-gradient(90deg, transparent 0 47px, rgba(255,255,255,.055) 47px 48px);
  -webkit-mask-image: radial-gradient(120% 90% at 50% 0%, #000 35%, transparent 78%);
          mask-image: radial-gradient(120% 90% at 50% 0%, #000 35%, transparent 78%);
}
.prod-hero > *, .insize-quote > * { position: relative; z-index: 1; }

/* — Header de sección como "línea de cota": etiqueta entre hairlines — */
.insize-model .section-label, .prod-brands .section-label {
  display: inline-flex; align-items: center; gap: 14px; color: var(--prod-cyan);
  text-transform: uppercase; letter-spacing: 3px; font-weight: 700; font-size: 12px; margin-bottom: 18px;
}
.insize-model .section-label::before, .insize-model .section-label::after,
.prod-brands .section-label::before, .prod-brands .section-label::after {
  content: ""; width: 36px; height: 1px; background: currentColor; opacity: .85;
}
.insize-triggers .section-label {
  display: inline-flex; align-items: center; gap: 12px; color: var(--prod-cyan);
}
.insize-triggers .section-label::before { content: ""; width: 28px; height: 2px; background: currentColor; }

/* — Tipografía: más escala y tracking apretado en los titulares — */
.prod-hero .hero-title { font-size: clamp(2.4rem, 5vw, 3.8rem); letter-spacing: -0.02em; line-height: 1.04; text-wrap: balance; }
.prod-hero .hero-eyebrow { color: #6fd0ff; }
.insize-model .section-title, .insize-triggers .section-title {
  font-size: clamp(2rem, 3.4vw, 2.7rem); font-weight: 800; letter-spacing: -0.015em; color: var(--prod-ink); line-height: 1.12;
}

/* — Trust bar como panel de instrumento: rules + divisores hairline — */
.insize-trust { background: #fff; border-top: 1px solid var(--prod-line); border-bottom: 1px solid var(--prod-line); }
.insize-trust .trust-bar { padding: 6px 0; }
.insize-trust .trust-item { position: relative; }
.insize-trust .trust-item + .trust-item::before {
  content: ""; position: absolute; left: -18px; top: 50%; transform: translateY(-50%);
  width: 1px; height: 36px; background: var(--prod-line);
}
.insize-trust .trust-item strong { font-variant-numeric: tabular-nums; letter-spacing: .01em; color: var(--prod-ink); }
.insize-trust .trust-item a:hover span { color: var(--prod-cyan); text-decoration: underline; }

/* — Franja de marcas: placa con hairline, logos a color y plenos — */
.prod-brands .brands-track {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center;
  gap: 22px 34px; max-width: 740px; margin: 32px auto 16px;
  border: none; background: transparent; overflow: visible;
}
.prod-brands .brand-logo {
  flex: 0 0 auto; width: 150px; height: 54px; min-width: 0; padding: 0;
  display: flex; align-items: center; justify-content: center;
}
.prod-brands .brand-logo img {
  max-height: 40px; max-width: 140px; width: auto; height: auto;
  filter: none; opacity: 1; transition: opacity .25s;
}
.prod-brands .brand-logo:hover img { opacity: .82; }
.prod-brands .brand-divider { display: none; }
.prod-brands .brands-note { color: #6b7689; margin-top: 6px; }

/* — Modelo Accredian → riel dimensionado con nodos numerados — */
.insize-model .cycle-row {
  position: relative; justify-content: space-between; gap: 0; max-width: 880px;
  margin: 12px auto 0; counter-reset: cyc;
}
.insize-model .cycle-arrow { display: none; }
.insize-model .cycle-row::before {
  content: ""; position: absolute; left: 9%; right: 9%; top: 31px; height: 1px;
  background: repeating-linear-gradient(90deg, var(--prod-cyan) 0 7px, transparent 7px 14px);
  opacity: .55; z-index: 0;
}
.insize-model .cycle-step { counter-increment: cyc; position: relative; z-index: 1; max-width: 190px; }
.insize-model .cycle-icon {
  background: var(--prod-navy); border: 6px solid #fff; box-shadow: 0 0 0 1px var(--prod-line);
  position: relative;
}
.insize-model .cycle-icon::after {
  content: "0" counter(cyc); position: absolute; top: -8px; right: -12px;
  width: 24px; height: 24px; border-radius: 50%; background: var(--prod-cyan); color: #fff;
  border: 3px solid #fff; display: flex; align-items: center; justify-content: center;
  font-family: 'Montserrat', sans-serif; font-weight: 800; font-size: 11px;
}
.insize-model .cycle-step-label { font-size: 14px; color: var(--prod-ink); }

/* — Situaciones → tarjetas tipo "reporte de inspección" numeradas — */
.insize-triggers .trigger-grid { counter-reset: trig; }
.insize-triggers .trigger-card {
  counter-increment: trig; background: #fff !important; border: 1px solid var(--prod-line);
  border-radius: 0; box-shadow: inset 0 3px 0 var(--cardc, var(--prod-navy)); padding: 26px 24px 24px;
}
.insize-triggers .trigger-card.trigger-red { --cardc: var(--c-red); }
.insize-triggers .trigger-card.trigger-yellow { --cardc: var(--c-amber); }
.insize-triggers .trigger-card.trigger-green { --cardc: var(--c-green); }
.insize-triggers .trigger-card.trigger-blue { --cardc: var(--c-blue); }
.insize-triggers .trigger-card::before {
  content: "0" counter(trig); font-family: 'Montserrat', sans-serif; font-weight: 800;
  font-size: 12px; letter-spacing: .12em; color: var(--cardc); display: block; margin-bottom: 10px;
}
.insize-triggers .trigger-card .trigger-icon {
  border-radius: 4px; background: color-mix(in srgb, var(--cardc) 12%, #fff) !important; color: var(--cardc) !important;
}
.insize-triggers .trigger-card h3 { color: var(--prod-ink); font-size: 17px; }

/* — Franja full-bleed: marco de cotas (esquinas) sobre el contenido — */
.prod-fullbleed-content { padding: 26px 4px; }
.prod-fullbleed-content::before, .prod-fullbleed-content::after {
  content: ""; position: absolute; width: 22px; height: 22px; pointer-events: none;
  border: 1px solid rgba(255,255,255,.55);
}
.prod-fullbleed-content::before { top: 0; left: 0; border-right: 0; border-bottom: 0; }
.prod-fullbleed-content::after { bottom: 0; right: 0; border-left: 0; border-top: 0; }

/* — Catálogos: placa con hairline en vez de strip plano — */
.insize-catalog .catalog-strip { border: 1px solid var(--prod-line); border-radius: 4px; }

/* — Banner INSIZE: blueprint sutil dentro de la placa navy — */
.insize-banner-card { position: relative; }
.insize-banner-text { position: relative; }
.insize-banner-text::before {
  content: ""; position: absolute; inset: 0; pointer-events: none; opacity: .5;
  background-image:
    repeating-linear-gradient(0deg, transparent 0 31px, rgba(255,255,255,.05) 31px 32px),
    repeating-linear-gradient(90deg, transparent 0 31px, rgba(255,255,255,.05) 31px 32px);
  -webkit-mask-image: linear-gradient(180deg, #000, transparent 80%);
          mask-image: linear-gradient(180deg, #000, transparent 80%);
}
.insize-banner-text > * { position: relative; }

/* — Responsive: neutralizar líneas que solo aplican en horizontal — */
@media (max-width: 992px) { .insize-trust .trust-item + .trust-item::before { display: none; } }
@media (max-width: 768px) {
  .insize-model .cycle-row::before { display: none; }
  .insize-model .cycle-row { justify-content: center; }
  .prod-brands .brands-track { max-width: 360px; }
}

/* ════════════════════════════════════════════════════════════════
   POLISH — detalle final (flagship): foco accesible, contraste AA,
   estados de interacción, touch targets. Por sección, en orden.
   ════════════════════════════════════════════════════════════════ */

/* [a11y] Foco de teclado visible en links y botones.
   main.css tiene `outline:0 !important`, por eso este va con !important.
   (Los inputs/selects ya traen foco propio en insize.css: borde cyan + glow.) */
.prod-hero a:focus-visible, .prod-hero button:focus-visible,
.prod-brands a:focus-visible, .insize-trust a:focus-visible,
.insize-triggers a:focus-visible, .prod-insize-banner a:focus-visible,
.prod-fullbleed a:focus-visible, .insize-catalog a:focus-visible,
.insize-quote a:focus-visible, .btn-submit:focus-visible,
.form-privacy input:focus-visible, .wa-float:focus-visible, #backToTop:focus-visible {
  outline: 2px solid var(--prod-cyan) !important; outline-offset: 3px !important; border-radius: 6px;
}
/* En secciones navy, ring claro para contraste del foco */
.prod-hero a:focus-visible, .insize-quote a:focus-visible, .form-privacy input:focus-visible,
.prod-insize-banner a:focus-visible, .prod-fullbleed a:focus-visible, .btn-submit:focus-visible {
  outline-color: #7cd4ff !important;
}

/* [1 Hero / 2 Trust / 9 Catálogos] Contraste de textos a AA */
.insize-model .cycle-step-desc { color: #5f6b80; }   /* era #888 = 3.54 → ~5.4 */
.prod-brands .brands-note { color: #5f6b80; }         /* 4.59 → ~5.4 */

/* [3 Marcas / 5 Situaciones / 9 Catálogos] Estados hover que faltaban */
.prod-brands .brand-logo { transition: transform .2s ease; }
.prod-brands .brand-logo:hover { transform: translateY(-2px); }
.insize-catalog .btn-catalog-download { transition: transform .2s ease, box-shadow .2s ease; }
.insize-catalog .btn-catalog-download:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(0,49,119,.14); }
.insize-triggers .trigger-card { transition: transform .2s ease, box-shadow .2s ease; }
.insize-triggers .trigger-card:hover { transform: translateY(-3px); box-shadow: inset 0 3px 0 var(--cardc, var(--prod-navy)), 0 12px 28px rgba(0,49,119,.10); }

/* [8 Formulario] Touch target cómodo en la casilla de privacidad */
.insize-quote .form-privacy { min-height: 44px; }
.insize-quote .form-privacy input { width: 18px; height: 18px; flex-shrink: 0; }

/* ════════════════════════════════════════════════════════════════
   REWORK EDITORIAL — Hero split + Showcase de productos + cierre
   ════════════════════════════════════════════════════════════════ */

/* [1] Hero → split: texto en .container (alineado al sitio) + foto a sangre derecha.
   Altura controlada, contenido centrado vertical, ritmo interno definido. */
.prod-hero { position: relative; overflow: hidden; background: var(--prod-navy); padding: 0; text-align: left;
  min-height: clamp(500px, 68vh, 660px); display: flex; align-items: center; }
.prod-hero-photo { position: absolute; top: 0; right: 0; bottom: 0; width: 50%; }
.prod-hero-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.prod-hero-photo::after { content: ""; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(90deg, var(--prod-navy) 0%, rgba(0,49,119,.55) 26%, transparent 60%); }
.prod-hero .container { position: relative; z-index: 1; }
.prod-hero-text { max-width: 580px; margin: 0; padding: 64px 0; }
.prod-hero-text .hero-eyebrow { display: block; color: #6fd0ff; margin: 0 0 16px; }
.prod-hero-text .hero-title { font-size: clamp(1.85rem, 3vw, 2.5rem); letter-spacing: -0.02em; line-height: 1.06; margin: 0 0 18px; text-wrap: balance; }
.prod-hero-text .hero-subtitle { color: #d6e2f2; font-size: 1.1rem; line-height: 1.6; margin: 0 0 30px; max-width: 440px; }
.prod-hero-text .hero-cta-group { display: flex; gap: 14px; flex-wrap: wrap; justify-content: flex-start; margin: 0 0 18px; }
.prod-hero-text .hero-response-note { margin: 0; color: #9fb6d6; font-size: .9rem; }

/* [3.5] Showcase de productos (reusa .insize-products de insize.css) */
.insize-products { background: var(--prod-surface); }
.insize-products .section-label { display: inline-flex; align-items: center; gap: 14px; color: var(--prod-cyan); }
.insize-products .section-label::before, .insize-products .section-label::after {
  content: ""; width: 36px; height: 1px; background: currentColor; opacity: .85; }
.insize-products .section-title { font-size: clamp(2rem, 3.4vw, 2.7rem); font-weight: 800; letter-spacing: -0.015em; color: var(--prod-ink); line-height: 1.12; }
.insize-products .product-card { border: 1px solid var(--prod-line); border-radius: 6px; background: #fff; }
.prod-showcase-cta { display: flex; align-items: center; justify-content: center; gap: 14px; flex-wrap: wrap; margin-top: 40px; }
.prod-showcase-cta-label { font-family: 'Poppins', sans-serif; font-weight: 600; color: var(--prod-ink); font-size: 14px; }

/* [9] Cierre (tagline de marca) */
.prod-closing { background: #fff; padding: 34px 0; text-align: center; border-top: 1px solid var(--prod-line); }
.prod-closing .catalog-tagline { margin: 0; color: var(--prod-ink); font-weight: 600; letter-spacing: .01em; }

/* Responsive: hero apila texto sobre foto */
@media (max-width: 860px) {
  .prod-hero { min-height: 0; flex-direction: column; align-items: stretch; }
  .prod-hero .container { order: 1; }
  .prod-hero-photo { position: relative; width: 100%; height: 230px; order: 2; }
  .prod-hero-photo::after { background: linear-gradient(0deg, transparent 50%, rgba(0,49,119,.45)); }
  .prod-hero-text { max-width: none; padding: 48px 0 34px; text-align: center; }
  .prod-hero-text .hero-title { max-width: 18ch; margin-left: auto; margin-right: auto; }
  .prod-hero-text .hero-subtitle { margin-left: auto; margin-right: auto; }
  .prod-hero-text .hero-cta-group { justify-content: center; }
}

/* ════════════════════════════════════════════════════════════════
   SISTEMA TIPOGRAFÍA + LAYOUT — todas las secciones
   Una escala de titulares (2 líneas máx), ritmo vertical parejo,
   encabezados centrados consistentes, texto claro compensado.
   ════════════════════════════════════════════════════════════════ */
:root {
  --t-title: clamp(2rem, 3.3vw, 2.7rem);   /* titular de sección */
  --t-lead: clamp(1.02rem, 1.4vw, 1.15rem); /* subtítulo/lead */
  --space-section: clamp(72px, 8vw, 112px); /* separación entre secciones */
  --measure-title: 26ch;                    /* medida del titular → ~2 líneas */
}

/* Ritmo vertical uniforme */
.prod-brands, .insize-products, .insize-model, .insize-triggers, .prod-insize-banner {
  padding-top: var(--space-section); padding-bottom: var(--space-section);
}
.insize-trust { padding: 16px 0; }

/* Titulares de sección: una sola escala + medida controlada */
.insize-model .section-title, .insize-products .section-title, .insize-triggers .section-title {
  font-size: var(--t-title); font-weight: 800; letter-spacing: -0.015em; line-height: 1.12;
  color: var(--prod-ink); text-wrap: balance; max-width: var(--measure-title);
  margin-left: auto; margin-right: auto;
}

/* Subtítulos/lead: un solo tamaño, medida cómoda */
.insize-model .section-subtitle, .insize-products .section-subtitle, .insize-triggers .section-subtitle {
  font-size: var(--t-lead); line-height: 1.6; color: #5a6577; max-width: 56ch;
  margin-left: auto; margin-right: auto;
}

/* Situaciones: encabezado centrado a todo el ancho (no columna estrecha) → título 2 líneas */
.insize-triggers .triggers-layout { display: block; }
.insize-triggers .triggers-header { position: static; text-align: center; max-width: 760px; margin: 0 auto 44px; }
.insize-triggers .section-label { justify-content: center; }
.insize-triggers .section-label::after { content: ""; width: 28px; height: 2px; background: currentColor; }
.insize-triggers .trigger-grid { max-width: 940px; margin: 0 auto; }

/* Compensación de texto claro sobre fondo oscuro (hero, banner, form, full-bleed) */
.prod-hero .hero-subtitle, .insize-quote .quote-subtitle, .prod-fullbleed-content p, .insize-banner-sub {
  line-height: 1.66; letter-spacing: .005em;
}
.insize-quote .quote-title, .prod-fullbleed-content h2 { letter-spacing: -0.015em; }

/* ════════════════════════════════════════════════════════════════
   [7+8] Cotización — split: aside (contexto + foto) / formulario.
   Fusiona el antiguo banner CTA con el formulario en una sola sección.
   ════════════════════════════════════════════════════════════════ */
.prod-quote { padding-top: var(--space-section); padding-bottom: var(--space-section); }
.prod-quote .container { position: relative; z-index: 1; }
.prod-quote-grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(24px, 4vw, 52px); align-items: stretch; }
.prod-quote-aside { position: relative; overflow: hidden; border-radius: 8px; padding: clamp(34px, 4vw, 52px);
  display: flex; flex-direction: column; justify-content: center; color: #fff; }
.prod-quote-aside::before { content: ""; position: absolute; inset: 0; z-index: 0;
  background: url('../img/insize/industries/metalmecanica.jpg') center/cover no-repeat; }
.prod-quote-aside::after { content: ""; position: absolute; inset: 0; z-index: 0;
  background: linear-gradient(155deg, rgba(0,28,74,.85), rgba(0,16,48,.93)); }
.prod-quote-aside > * { position: relative; z-index: 1; }
.prod-quote-aside .quote-eyebrow { color: var(--prod-cyan); text-align: left; }
.prod-quote-aside .quote-title { font-family: 'Montserrat', sans-serif; font-size: clamp(1.6rem, 2.5vw, 2.1rem);
  font-weight: 800; letter-spacing: -0.015em; line-height: 1.14; color: #fff; margin: 10px 0 14px; text-wrap: balance; }
.prod-quote-aside .quote-subtitle { color: #d6e2f2; font-size: 1.02rem; line-height: 1.62; margin: 0 0 22px; max-width: 42ch; }
.prod-quote-points { list-style: none; padding: 0; margin: 0 0 26px; display: grid; gap: 12px; }
.prod-quote-points li { display: flex; gap: 10px; align-items: flex-start; color: #eaf1fb; font-size: .98rem; line-height: 1.4; }
.prod-quote-points i { color: var(--prod-cyan); margin-top: 3px; flex-shrink: 0; }
.prod-quote-aside .quote-contact-strip { margin-top: auto; display: flex; flex-wrap: wrap; gap: 8px 18px; justify-content: flex-start; }
.prod-quote-aside .quote-contact-strip a { color: #d6e2f2; text-decoration: none; }
.prod-quote-aside .quote-contact-strip a:hover { color: #fff; }
.prod-quote-main { display: flex; align-items: center; min-width: 0; }
.prod-quote-main .quote-form-card { width: 100%; margin: 0; }

@media (max-width: 860px) {
  .prod-quote-grid { grid-template-columns: 1fr; }
  .prod-quote-aside { padding: 36px 28px; }
}

/* ════════════════════════════════════════════════════════════════
   FIX line-height de titulares — main.css fuerza `h1..h6 { line-height:
   1.5 !important }` globalmente, lo que abre demasiado los titulares a
   2 líneas. Lo corregimos (con !important para ganarle) por titular.
   ════════════════════════════════════════════════════════════════ */
.prod-hero .hero-title { line-height: 1.02 !important; }
.insize-model .section-title, .insize-products .section-title,
.insize-triggers .section-title, .prod-quote-aside .quote-title { line-height: 1.14 !important; }
.insize-banner-title { line-height: 1.12 !important; }
.insize-triggers .trigger-card h3,
.insize-products .product-card .card-body h3,
.insize-banner-title + .insize-banner-sub { line-height: 1.25 !important; }
