/* ============================================================
   TERRAMAR AGRÍCOLA · site.css  (Capa 3 — patrones de página)
   El look del prototipo Stitch, pero apoyado en el DESIGN SYSTEM:
   - Átomos (botón, card, chip, input, eyebrow) = componentes .ds-*
     (en components.css), repintados por terramar-brand.css.
   - Aquí SOLO viven layout + patrones de sección (hero, sectores,
     método, testimonios, etc.) y el puente de tokens hacia el DS.
   Orden de carga: tokens → terramar-brand → components → site
   ============================================================ */

/* ============================================================
   1 · PUENTE DE TOKENS (todo sale del DS; nada de hex sueltos de marca)
   ============================================================ */
:root {
  --c-primary:    var(--palette-primary-main);    /* #145B2A */
  --c-primary-dk: var(--palette-primary-dark);
  --c-secondary:  var(--palette-primary-light);   /* olivo #6F982F (acento del diseño) */
  --c-lime:       var(--brand-lime);              /* #C3F27D */
  --c-mar:        var(--palette-secondary-main);  /* azul mar #1F82C5 — acento "Mar" */
  --c-azul-soft:  var(--brand-bg-azul-soft);      /* celeste suave #EAF4FB (fondo) */
  --c-crema:      #F6F1E8;                         /* crema cálida (tinte marrón tierra) */
  --c-graphite:   #34383D;                         /* grafito sólido — franja utilitaria (carácter B2B) */
  --c-bg:         var(--bg-default);
  --c-surface:    var(--brand-surface);
  --c-surface-low:var(--brand-surface-low);
  --c-surface-ct: var(--brand-surface-cont);
  --c-white:      var(--bg-paper);
  --c-ink:        var(--text-primary);
  --c-ink-soft:   var(--text-secondary);
  --c-outline:    var(--divider);

  --font-display: var(--font-secondary);          /* Source Serif 4 (alias de página) */
  --font-body:    var(--font-primary);            /* Hanken Grotesk (alias de página) */

  /* La escala tipográfica (--fs-*, --lh-*) y los pesos (--fw-*) viven en la capa
     de marca / DS (terramar-brand.css + tokens.css). Aquí solo se consumen. */

  /* Ritmo de página */
  --sp-xl: clamp(3.5rem, 2rem + 6vw, 5rem);
  --sp-lg: 3rem;
  --sp-md: 1.5rem;
  --sp-gutter: 1.5rem;
  --sp-sm: 0.75rem;
  --r: 8px; --r-lg: 12px; --r-pill: 9999px;
  --sh-md: 0 4px 14px rgba(25,29,24,.08);
  --sh-lg: 0 12px 32px rgba(25,29,24,.12);
  --sh-xl: 0 24px 60px rgba(25,29,24,.18);
  --container: 1440px;
  --gutter-x: clamp(1rem, 4vw, 4rem);
}

/* ============================================================
   2 · RESET + BASE  (no se carga main.css en el home nuevo)
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  color: var(--c-ink);
  background: var(--c-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img, svg, video { display: block; max-width: 100%; height: auto; }
ul { list-style: none; padding: 0; }
a { text-decoration: none; color: inherit; }
h1, h2, h3, h4, h5 { font-family: var(--font-display); line-height: var(--lh-tight); font-weight: var(--fw-semiBold); }
::selection { background: var(--c-lime); color: var(--c-primary-dk); }

/* ---- Accesibilidad: foco por teclado, skip-link, sr-only ------------- */
:focus-visible { outline: 3px solid var(--c-mar); outline-offset: 2px; border-radius: 3px; }
/* Skip-link: oculto por recorte (a prueba de balas — no depende de top/posición)
   y SOLO visible al recibir foco con teclado. Invisible para usuarios con mouse. */
.skip-link {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0 0 0 0); clip-path: inset(50%);
  white-space: nowrap; border: 0;
}
.skip-link:focus {
  position: fixed; top: 8px; left: 8px;
  width: auto; height: auto; margin: 0; overflow: visible;
  clip: auto; clip-path: none; z-index: 2000;
  background: var(--c-primary); color: #fff; padding: .65rem 1.1rem;
  border-radius: 8px; font-weight: 600; box-shadow: var(--sh-md);
}
.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;
}

/* Iconos Material Symbols */
.micon {
  font-family: 'Material Symbols Outlined'; font-weight: normal; font-style: normal;
  line-height: 1; white-space: nowrap; direction: ltr; -webkit-font-smoothing: antialiased;
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24; user-select: none;
}
.micon--fill { font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 24; }

/* Eyebrow del DS → en TerraMar va OLIVO (acento del diseño) */
.ds-eyebrow { --ds-eyebrow-main: var(--c-secondary); }

/* Reveal on-scroll (solo se oculta si hay JS) */
.reveal { transition: opacity .7s cubic-bezier(.4,0,.2,1), transform .7s cubic-bezier(.4,0,.2,1); }
.js .reveal { opacity: 0; transform: translateY(24px); }
.js .reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .js .reveal { opacity: 1 !important; transform: none !important; }
  html { scroll-behavior: auto; }
}

/* ============================================================
   3 · LAYOUT
   ============================================================ */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter-x); }
.section { padding-block: var(--sp-xl); }
.section--surface     { background: var(--c-surface); }
.section--surface-low { background: var(--c-surface-low); }
.section--white       { background: var(--c-white); }
.section--lowest      { background: var(--c-white); }
.section--celeste     { background: var(--c-azul-soft); }  /* celeste suave (Mar) */
.section--crema       { background: var(--c-crema); }      /* crema cálida (tierra) */
.scroll-anchor { scroll-margin-top: 100px; }

.section__head { max-width: 48rem; }
.section__head--center { margin-inline: auto; text-align: center; }
.section__title { font-size: var(--fs-h-lg); color: var(--c-primary); margin-top: var(--sp-md); }
.section__lead { font-size: 1rem; color: var(--c-ink-soft); margin-top: var(--sp-sm); }
.u-center { text-align: center; }

/* ============================================================
   4 · HEADER / NAVBAR (estilo styleguide §08) — barra blanca sticky
   ============================================================ */
/* Franja utilitaria — gris grafito sólido. NO sticky: se va al hacer scroll y
   deja el stack gris → blanco (header) → verde (hero) en el primer pintado. */
.tm-utilitybar { background: var(--c-graphite); color: #fff; }
.tm-utilitybar__inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; min-height: 40px; padding-block: .45rem; font-size: var(--fs-label-sm); }
.tm-utilitybar__tag { display: inline-flex; align-items: center; gap: .5rem; color: rgba(255,255,255,.82); letter-spacing: .02em; }
.tm-utilitybar__links { display: flex; align-items: center; gap: 1.75rem; }
.tm-utilitybar__links a { display: inline-flex; align-items: center; gap: .4rem; color: rgba(255,255,255,.9); font-weight: 500; transition: color .2s ease; }
.tm-utilitybar__links a:hover { color: #fff; }
.tm-utilitybar .micon { font-size: 1.05rem; color: var(--c-lime); }

.tm-header {
  position: sticky; top: 0; z-index: 50;
  background: var(--c-white);
  border-bottom: 1px solid var(--c-outline);
  transition: box-shadow .3s ease;
}
.tm-header.is-scrolled { box-shadow: var(--sh-md); }
.tm-topbar { display: flex; align-items: center; gap: 1rem; padding-block: .55rem; }
.tm-topbar__logo { display: inline-flex; align-items: center; }
/* Excepción pedida por Caleb: menos techo/piso para dar más presencia al logo.
   La altura total de la barra (~76px) se mantiene cercana a 93px del calc del hero. */
.tm-topbar__logo img { height: 76px; width: auto; }
.tm-topbar__nav { display: flex; align-items: center; gap: .25rem; margin-left: auto; }
.tm-topbar__link { padding: .5rem .75rem; border-radius: 6px; color: var(--c-ink-soft); font-weight: 500; font-size: 0.95rem; transition: color .2s ease, background-color .2s ease; }
.tm-topbar__link:hover { color: var(--c-primary); background: color-mix(in srgb, var(--c-primary) 7%, transparent); }
.tm-topbar__link.is-active { color: var(--c-primary); font-weight: 600; }
.tm-topbar__cta { margin-left: .75rem; }
.tm-navtoggle { display: none; flex-direction: column; gap: 5px; width: 44px; height: 44px; padding: 11px; border: 1px solid var(--c-outline); border-radius: 6px; background: transparent; cursor: pointer; margin-left: auto; }
.tm-navtoggle span { display: block; height: 2px; width: 100%; background: var(--c-primary); border-radius: 2px; }

/* ============================================================
   5 · HERO
   ============================================================ */
.hero { position: relative; min-height: calc(100svh - 93px); display: flex; align-items: center; overflow: hidden; }
.hero__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.hero__overlay { position: absolute; inset: 0; z-index: 1; background: linear-gradient(to right, rgba(20,91,42,.92), rgba(20,91,42,.45) 55%, rgba(20,91,42,.05)); }
.hero__inner { position: relative; z-index: 2; color: #fff; padding-block: 4rem; }
.hero__copy { max-width: 46rem; }
.hero__title { font-size: var(--fs-display); font-weight: 700; letter-spacing: -0.02em; line-height: 1.08; color: #fff; margin-top: 1rem; }
.hero__lead { font-size: var(--fs-body-lg); margin-top: 1.5rem; max-width: 40rem; color: rgba(255,255,255,.9); }
.hero__actions { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2.5rem; }
.hero__trust { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-md); margin-top: 3rem; padding-top: 2rem; border-top: 1px solid rgba(255,255,255,.2); }
.trust-item { display: flex; align-items: center; gap: .75rem; }
.trust-item .micon { color: var(--c-lime); font-size: 1.75rem; }
.trust-item span:last-child { font-size: var(--fs-label); font-weight: 600; text-transform: uppercase; letter-spacing: .06em; }

/* ============================================================
   6 · SOBRE
   ============================================================ */
.about { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-xl); align-items: center; }
.about__media { position: relative; }
.about__img { width: 100%; aspect-ratio: 4/5; object-fit: cover; border-radius: var(--r-lg); box-shadow: var(--sh-xl); }
.about__badge { position: absolute; bottom: -2rem; right: -2rem; width: 15rem; height: 15rem; background: var(--c-primary); color: #fff; padding: var(--sp-md); border-radius: var(--r-lg); box-shadow: var(--sh-lg); display: flex; flex-direction: column; justify-content: center; }
.about__badge-num { font-family: var(--font-display); font-size: var(--fs-display); font-weight: 700; }
.about__badge-txt { font-family: var(--font-display); font-size: var(--fs-h-md); line-height: 1.25; margin-top: .25rem; }
.about__content h2 { font-size: var(--fs-h-lg); color: var(--c-primary); margin: 1rem 0 1.5rem; }
.about__content p { font-size: var(--fs-body-lg); color: var(--c-ink-soft); margin-bottom: 1.25rem; line-height: 1.7; }
.about__features { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-md); margin-top: 1.5rem; }
.feature-item { border-left: 4px solid var(--c-secondary); padding-left: 1rem; }
.feature-item:nth-child(2) { border-left-color: var(--c-primary); }
.feature-item h3 { font-size: var(--fs-h-md); color: var(--c-primary); margin-bottom: .25rem; }
.feature-item p { font-size: var(--fs-label-sm); color: var(--c-ink-soft); }

/* ============================================================
   7 · LÍNEAS — tarjetas .ds-card + patrón de ícono (efecto que gusta)
   ============================================================ */
.lines-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-gutter); margin-top: var(--sp-xl); }
.tm-line .ds-card__body { padding: var(--sp-lg); gap: 0; }
.tm-line__icon { width: 4rem; height: 4rem; border-radius: var(--r-pill); display: flex; align-items: center; justify-content: center; background: color-mix(in srgb, var(--c-primary) 10%, transparent); margin-bottom: 1.5rem; transition: background .25s ease; }
.tm-line__icon .micon { color: var(--c-primary); font-size: 2rem; transition: color .25s ease; }
.tm-line:hover .tm-line__icon { background: var(--c-primary); }
.tm-line:hover .tm-line__icon .micon { color: #fff; }
.tm-line--alt .tm-line__icon { background: color-mix(in srgb, var(--c-secondary) 12%, transparent); }
.tm-line--alt .tm-line__icon .micon { color: var(--c-secondary); }
.tm-line--alt:hover .tm-line__icon { background: var(--c-secondary); }
.tm-line .ds-card__title { margin-bottom: 1rem; }
.tm-line__desc { color: var(--c-ink-soft); margin-bottom: 1.5rem; }
.tm-line__list { display: grid; gap: .75rem; font-size: var(--fs-label); }
.tm-line__list li { display: flex; align-items: center; gap: .5rem; }
.tm-line__list .micon { color: var(--c-secondary); font-size: 1.125rem; }

/* ============================================================
   8 · TILE de imagen — patrón COMPARTIDO (sectores + portafolio)
   ============================================================ */
.tm-tile { position: relative; display: block; overflow: hidden; border-radius: var(--r); }
.tm-tile img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s ease; }
.tm-tile:hover img { transform: scale(1.08); }
.tm-tile::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(20,91,42,.92), rgba(20,91,42,.12) 55%, transparent); }
.tm-tile__body { position: absolute; inset: auto 0 0 0; z-index: 1; padding: 1.25rem; color: #fff; }
.tm-tile__title { color: #fff; font-size: 1.125rem; margin-top: .15rem; }
.tm-tile__chip { position: absolute; top: 1rem; left: 1rem; z-index: 2; }
.tm-tile__cat { display: block; font-size: var(--fs-label-sm); font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--c-lime); }
.tm-tile__more { display: inline-flex; align-items: center; gap: .35rem; margin-top: .6rem; font-size: var(--fs-label-sm); font-weight: 700; color: #fff; opacity: 0; transform: translateY(6px); transition: opacity .25s ease, transform .25s ease; }
.tm-tile:hover .tm-tile__more { opacity: 1; transform: none; }

/* Sectores: tiles altos solo con título */
.sectors-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: .5rem; margin-top: var(--sp-xl); }
.sectors-grid .tm-tile { height: 24rem; }

/* Portafolio: tiles 3/4 con categoría + título (imagen protagonista) */
.catalog__head { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: flex-end; gap: 1rem; }
.catalog__head .section__head { margin: 0; }
.tm-link-arrow { display: inline-flex; align-items: center; gap: .5rem; color: var(--c-primary); font-weight: 700; border-bottom: 2px solid var(--c-primary); padding-bottom: 2px; transition: color .2s ease, border-color .2s ease; }
.tm-link-arrow:hover { color: var(--c-secondary); border-color: var(--c-secondary); }
.catalog-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-gutter); margin-top: var(--sp-xl); }
.catalog-grid .tm-tile { aspect-ratio: 3/4; }
.catalog__loading { grid-column: 1/-1; color: var(--c-ink-soft); }

/* ============================================================
   9 · BENEFICIOS (sección celeste suave + cards blancas — sin glass)
   El verde oscuro ya no se usa como fondo: solo entinta los títulos.
   ============================================================ */
.benefits-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-gutter); margin-top: var(--sp-xl); }
.benefit-card { padding: 2rem; border-radius: var(--r-lg); background: var(--c-white); border: 1px solid var(--c-outline); transition: box-shadow .25s ease, transform .25s ease; }
.benefit-card:hover { box-shadow: var(--sh-lg); transform: translateY(-3px); }
.benefit-card .micon { color: var(--c-primary); font-size: 2.25rem; margin-bottom: 1.5rem; }
.benefit-card h3 { font-size: var(--fs-h-md); margin-bottom: .75rem; color: var(--c-primary); }
.benefit-card p { font-size: var(--fs-label); color: var(--c-ink-soft); }

/* ============================================================
   10 · MÉTODO
   ============================================================ */
.method-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-md); margin-top: var(--sp-xl); }
.method-step { text-align: center; }
.method-step__circle { width: 5rem; height: 5rem; border-radius: var(--r-pill); background: var(--c-surface-ct); display: flex; align-items: center; justify-content: center; margin: 0 auto 1.5rem; position: relative; transition: background .25s ease; }
.method-step:hover .method-step__circle { background: var(--c-primary); }
.method-step__circle .micon { color: var(--c-primary); font-size: 2rem; transition: color .25s ease; }
.method-step:hover .method-step__circle .micon { color: #fff; }
.method-step__num { position: absolute; top: -.75rem; left: -.75rem; font-family: var(--font-display); font-size: 2.5rem; font-weight: 700; color: var(--c-secondary); opacity: .25; }
.method-step h3 { font-size: var(--fs-h-md); color: var(--c-primary); margin-bottom: .5rem; }
.method-step p { font-size: var(--fs-label); color: var(--c-ink-soft); padding-inline: 1rem; }

/* ============================================================
   11 · TESTIMONIOS — sobre .ds-card
   ============================================================ */
.testi-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-gutter); margin-top: var(--sp-xl); }
.testi-card { flex-direction: row; gap: 1.5rem; padding: var(--sp-lg); }
.testi-card__media { flex: 0 0 32%; }
.testi-card__img { aspect-ratio: 1; width: 100%; object-fit: cover; border-radius: var(--r); margin-bottom: 1rem; }
.testi-card__stat { background: color-mix(in srgb, var(--c-lime) 35%, transparent); padding: .75rem; border-radius: var(--r); text-align: center; }
.testi-card__stat-num { font-family: var(--font-display); font-size: var(--fs-h-md); color: var(--c-primary); font-weight: 700; }
.testi-card__stat-lbl { font-size: 10px; text-transform: uppercase; font-weight: 700; color: var(--c-secondary); }
.testi-card__body { display: flex; flex-direction: column; justify-content: center; }
.testi-card__body .micon { color: var(--c-secondary); font-size: 2.25rem; margin-bottom: 1rem; }
.testi-card__quote { font-style: italic; font-size: var(--fs-body-lg); color: var(--c-ink); margin-bottom: 1.5rem; line-height: 1.6; }
.testi-card__name { font-weight: 700; color: var(--c-primary); }
.testi-card__role { font-size: var(--fs-label-sm); color: var(--c-ink-soft); }

/* ============================================================
   12 · CTA FINAL
   ============================================================ */
.cta-final { position: relative; overflow: hidden; padding-block: var(--sp-xl); }
.cta-final__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.cta-final__overlay { position: absolute; inset: 0; background: rgba(20,91,42,.86); backdrop-filter: blur(2px); z-index: 1; }
.cta-final__inner { position: relative; z-index: 2; text-align: center; color: #fff; }
.cta-final h2 { font-size: var(--fs-display); margin-bottom: 1.5rem; color: #fff; }
.cta-final p { font-size: var(--fs-body-lg); max-width: 40rem; margin: 0 auto 2.5rem; color: rgba(255,255,255,.9); }
.cta-final__actions { display: flex; flex-wrap: wrap; justify-content: center; gap: 1rem; }

/* ============================================================
   12b · CONTACTO comercial — panel celeste + form (botones nivelados)
   ============================================================ */
.contact-wrap { background: var(--c-white); border: 1px solid var(--c-outline); border-radius: calc(var(--r-lg) + .25rem); overflow: hidden; box-shadow: var(--sh-xl); display: grid; grid-template-columns: 1fr 1fr; }
.contact-left { background: var(--c-azul-soft); color: var(--c-ink); padding: 2.75rem; display: flex; flex-direction: column; gap: 1.75rem; border-right: 1px solid var(--c-outline); }
.contact-left .ds-eyebrow { --ds-eyebrow-main: var(--c-mar); }
.contact-left h2 { font-size: var(--fs-h-lg); color: var(--c-primary); margin-top: .75rem; line-height: 1.15; }
.contact-left > div > p { color: var(--c-ink-soft); line-height: 1.7; margin-top: 1rem; }
.contact-info { display: flex; flex-direction: column; gap: 1.25rem; }
.contact-info-item { display: flex; align-items: center; gap: 1rem; }
/* Chip blanco flotante tras el ícono — acabado más premium sobre el celeste */
.contact-info-item .micon { font-size: 1.35rem; color: var(--c-primary); flex-shrink: 0; width: 2.75rem; height: 2.75rem; border-radius: 50%; background: var(--c-white); display: inline-flex; align-items: center; justify-content: center; box-shadow: var(--sh-md); }
.contact-info-item h3 { font-size: 1rem; font-weight: 700; margin-bottom: .15rem; color: var(--c-primary); }
.contact-info-item p, .contact-info-item a { color: var(--c-ink-soft); font-size: var(--fs-label); display: block; }
.contact-info-item a:hover { color: var(--c-mar); }
/* Botón WhatsApp anclado al fondo del panel para nivelar con "Enviar" del form */
.contact-wa-btn { margin-top: auto; align-self: stretch; justify-content: center; }

.contact-right { padding: 2.75rem; display: flex; flex-direction: column; }
.contact-right #contact-form { display: flex; flex-direction: column; flex: 1 1 auto; }
.contact-right h3 { font-family: var(--font-display); font-size: var(--fs-h-md); color: var(--c-primary); margin-bottom: 1.75rem; }
/* Reglas scopeadas a .contact-right para no chocar con el .form-group genérico
   del Libro de Reclamaciones (definido más abajo en este mismo archivo). */
.contact-right .form-group { display: block; margin-bottom: 1.25rem; }
.contact-right .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.contact-right .form-group label { display: block; font-size: var(--fs-label-sm); font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--c-ink-soft); margin-bottom: .5rem; margin-left: .2rem; }
.contact-right .form-group input, .contact-right .form-group textarea { width: 100%; padding: .9rem 1.1rem; border-radius: 12px; border: 1px solid var(--c-outline); background: var(--c-surface-low); color: var(--c-ink); font-family: inherit; font-size: var(--fs-label); outline: none; transition: border-color .2s ease, box-shadow .2s ease; }
.contact-right .form-group textarea { resize: vertical; min-height: 7rem; }
.contact-right .form-group input::placeholder, .contact-right .form-group textarea::placeholder { color: color-mix(in srgb, var(--c-ink-soft) 65%, transparent); }
.contact-right .form-group input:focus, .contact-right .form-group textarea:focus { border-color: var(--c-primary); box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-primary) 18%, transparent); background: var(--c-white); }
.contact-right .form-group input.is-invalid, .contact-right .form-group textarea.is-invalid { border-color: #ba1a1a; box-shadow: 0 0 0 3px rgba(186,26,26,.12); }
.contact-right .btn-submit { width: 100%; margin-top: auto; }
.contact-right .form-msg { display: none; padding: .8rem 1rem; border-radius: 10px; font-size: var(--fs-label); margin-top: 1rem; }
.contact-right .form-msg.success { display: block; background: color-mix(in srgb, var(--c-lime) 22%, transparent); color: var(--c-primary-dk); }
.contact-right .form-msg.error { display: block; background: rgba(186,26,26,.10); color: #ba1a1a; }

/* ============================================================
   13 · FOOTER (claro)
   ============================================================ */
.site-footer { background: var(--c-surface-low); border-top: 1px solid var(--c-outline); padding-block: var(--sp-xl); }
.site-footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1.2fr 1.2fr; gap: var(--sp-lg); }
/* Logo en card (100% de la columna): logo centrado + copy justificado */
.site-footer__card { background: var(--c-white); border: 1px solid var(--c-outline); border-radius: var(--r-lg); padding: 1.5rem; width: 100%; box-shadow: var(--sh-md); }
.site-footer__card img { display: block; height: 76px; width: auto; margin: 0 auto 1rem; }
.site-footer__card p { color: var(--c-ink-soft); line-height: 1.7; text-align: justify; }
/* Redes sociales (SVG) + botón compartir */
.site-footer__social { display: flex; flex-wrap: wrap; gap: .65rem; margin-top: 1.25rem; }
.site-footer__social a, .site-footer__share { width: 2.5rem; height: 2.5rem; border-radius: var(--r-pill); background: color-mix(in srgb, var(--c-primary) 7%, transparent); color: var(--c-primary); display: inline-flex; align-items: center; justify-content: center; border: 0; cursor: pointer; transition: background .2s ease, color .2s ease, transform .2s ease; }
.site-footer__social a:hover, .site-footer__share:hover { background: var(--c-primary); color: #fff; transform: translateY(-2px); }
.site-footer__social svg { width: 1.1rem; height: 1.1rem; }
.site-footer__col h3 { font-family: var(--font-display); font-size: var(--fs-h-md); color: var(--c-primary); margin-bottom: 1rem; }
.site-footer__col ul { display: grid; gap: .75rem; }
.site-footer__col a { color: var(--c-ink-soft); font-size: var(--fs-label); transition: color .2s ease; }
.site-footer__col a:hover { color: var(--c-secondary); }
.site-footer__contact li { display: flex; align-items: flex-start; gap: .75rem; color: var(--c-ink-soft); margin-bottom: .75rem; }
.site-footer__contact .micon { color: var(--c-secondary); font-size: 1.25rem; }
.site-footer__news p { color: var(--c-ink-soft); font-size: var(--fs-label-sm); margin-bottom: 1rem; }
.site-footer__news-form { display: flex; flex-direction: column; gap: .5rem; align-items: stretch; }
.site-footer__news-form .ds-text-field { min-width: 0; width: 100%; }
.site-footer__news-msg { margin: .6rem 0 0; min-height: 1.1em; font-size: var(--fs-label-sm); font-weight: 600; }
.site-footer__news-msg.success { color: var(--c-primary); }
.site-footer__news-msg.error { color: #ba1a1a; }

/* ============================================================
   PÁGINA 404 — bloque centrado de marca
   ============================================================ */
.notfound { display: flex; align-items: center; min-height: 62vh; padding-block: var(--sp-xl); }
.notfound .container { width: 100%; }
.notfound__inner { max-width: 40rem; margin-inline: auto; display: flex; flex-direction: column; align-items: center; text-align: center; gap: .85rem; }
.notfound__code { font-family: var(--font-display); font-weight: 600; font-size: clamp(5rem, 14vw, 9rem); line-height: 1; color: var(--c-primary); margin: .25rem 0; }
.notfound__title { font-size: var(--fs-h-lg); color: var(--c-ink); }
.notfound__text { color: var(--c-ink-soft); max-width: 34rem; }
.notfound__actions { display: flex; flex-wrap: wrap; gap: .75rem; justify-content: center; margin-top: 1.25rem; }
@media (max-width: 480px) {
  .notfound__actions { flex-direction: column; width: 100%; }
  .notfound__actions .ds-button { width: 100%; }
}
.site-footer__bottom { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 1rem; margin-top: var(--sp-xl); padding-top: .5rem; font-size: var(--fs-label-sm); color: var(--c-ink-soft); }
.site-footer__legal { display: flex; flex-wrap: wrap; gap: 1.25rem; }
.site-footer__legal a { display: inline-flex; align-items: center; gap: .35rem; color: var(--c-primary); font-weight: 600; }
.site-footer__legal a:hover { color: var(--c-secondary); }
.site-footer__legal .micon { font-size: 1.05rem; }
/* Crédito SISEG — fila centrada debajo */
.site-footer__credit { text-align: center; padding-top: 1rem; margin-top: 1rem; border-top: 1px solid var(--c-outline); font-size: var(--fs-label-sm); color: var(--c-ink-soft); }
.site-footer__credit a { color: var(--c-primary); font-weight: 600; }
.site-footer__credit a:hover { color: var(--c-secondary); }
/* Despeja la barra legal de los botones flotantes (esquina inferior derecha) */
@media (min-width: 901px) { .site-footer__bottom { padding-right: 5.5rem; } }

/* ============================================================
   14 · BOTONES FLOTANTES — WhatsApp (arriba) + scroll-top (debajo)
   ============================================================ */
.tm-fabs { position: fixed; right: clamp(16px,3vw,28px); bottom: clamp(16px,3vw,28px); z-index: 60; display: flex; flex-direction: column; align-items: center; gap: 12px; }
.tm-fabs > * { width: 58px; height: 58px; border-radius: var(--r-pill); display: inline-flex; align-items: center; justify-content: center; box-shadow: var(--sh-lg); transition: transform .2s ease, box-shadow .2s ease, opacity .25s ease, visibility .25s ease; }
.wa-float { background: #25D366; color: #fff; }
.wa-float:hover { transform: translateY(-3px); box-shadow: var(--sh-xl); color: #fff; }
/* Scroll-top: verde oscuro semi-transparente (color de paleta: primary-dark) */
.scrolltop { background: color-mix(in srgb, var(--palette-primary-dark) 50%, transparent); color: #fff; border: 0; cursor: pointer; backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px); opacity: 0; visibility: hidden; transform: translateY(8px); }
.scrolltop.is-visible { opacity: 1; visibility: visible; transform: none; }
.scrolltop:hover { background: var(--palette-primary-dark); transform: translateY(-3px); box-shadow: var(--sh-xl); }
.scrolltop .micon { font-size: 1.6rem; }

/* ============================================================
   15 · RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .sectors-grid { grid-template-columns: repeat(2, 1fr); }
  .lines-grid, .benefits-grid, .catalog-grid, .method-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 900px) {
  .tm-utilitybar__tag { display: none; }                 /* en mobile solo teléfono/correo */
  .tm-utilitybar__inner { justify-content: center; }
  .tm-utilitybar__links { gap: 1.25rem; }
  .tm-navtoggle { display: flex; }
  .tm-topbar__nav { position: absolute; inset: 100% 0 auto 0; flex-direction: column; align-items: stretch; background: var(--c-white); border-bottom: 1px solid var(--c-outline); box-shadow: var(--sh-md); padding: var(--sp-md) var(--gutter-x); gap: .5rem; display: none; margin-left: 0; }
  .tm-topbar__nav.is-open { display: flex; }
  .tm-topbar__link { padding: .6rem .25rem; }
  .tm-topbar__cta { margin-left: 0; margin-top: .25rem; text-align: center; }
  .about { grid-template-columns: 1fr; gap: var(--sp-lg); }
  .about__badge { position: static; width: auto; height: auto; margin-top: 1rem; }
  .testi-card { flex-direction: column; }
  .testi-card__media { flex-basis: auto; display: flex; gap: 1rem; align-items: center; }
  .testi-card__img { width: 6rem; margin-bottom: 0; }
  .contact-wrap { grid-template-columns: 1fr; }
  .contact-left, .contact-right { padding: 2.25rem; }
}
@media (max-width: 640px) {
  .tm-utilitybar__links a[href^="mailto"] { display: none; }  /* solo teléfono en móviles chicos */
  .lines-grid, .benefits-grid, .catalog-grid, .method-grid, .sectors-grid, .testi-grid, .about__features { grid-template-columns: 1fr; }
  .hero__trust { grid-template-columns: 1fr; gap: .75rem; }
  .hero__actions .ds-button, .cta-final__actions .ds-button { flex: 1 1 100%; }
  .site-footer__grid { grid-template-columns: 1fr; gap: var(--sp-lg); }
  .sectors-grid .tm-tile { height: 16rem; }
  .contact-right .form-row { grid-template-columns: 1fr; }
  .contact-left, .contact-right { padding: 1.75rem; }
}

/* ============================================================
   18 · PÁGINAS INTERNAS — Libro de Reclamaciones + Legal
   (patrón tomado de EcoCampo, repintado con tokens del DS)
   ============================================================ */
.page-section { background: var(--c-surface-low); padding-block: var(--sp-lg); min-height: 60vh; }
.page-wrap { max-width: 820px; margin-inline: auto; }
.breadcrumb { display: flex; align-items: center; gap: .5rem; font-size: var(--fs-label-sm); color: var(--c-ink-soft); margin-bottom: 1.5rem; }
.breadcrumb a { color: var(--c-primary); }
.breadcrumb a:hover { text-decoration: underline; }
.breadcrumb .micon { font-size: 1rem; }

/* --- Libro de Reclamaciones --- */
.reclamo-header { background: var(--c-primary); border-radius: var(--r-lg) var(--r-lg) 0 0; padding: 2rem; display: flex; gap: 1.25rem; align-items: flex-start; }
.reclamo-header__icon { width: 3rem; height: 3rem; background: rgba(255,255,255,.15); border-radius: var(--r); display: flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.reclamo-header__icon .micon { color: var(--c-lime); font-size: 1.5rem; }
.reclamo-header h1 { color: #fff; font-size: 1.5rem; margin-bottom: .25rem; }
.reclamo-header p { color: rgba(255,255,255,.75); font-size: var(--fs-label-sm); line-height: 1.5; }
.reclamo-notice { background: color-mix(in srgb, var(--c-lime) 18%, transparent); border-left: 3px solid var(--c-secondary); padding: .85rem 1.25rem; display: flex; gap: .75rem; font-size: var(--fs-label-sm); color: var(--c-ink-soft); line-height: 1.6; }
.reclamo-notice .micon { color: var(--c-primary); flex: 0 0 auto; }
.reclamo-body { background: var(--c-white); border-radius: 0 0 var(--r-lg) var(--r-lg); box-shadow: var(--sh-md); overflow: hidden; }
.reclamo-section { padding: 2rem; border-bottom: 1px solid var(--c-outline); }
.reclamo-section:last-of-type { border-bottom: none; }
.reclamo-section__title { display: flex; align-items: center; gap: .6rem; font-size: var(--fs-label); font-weight: 700; color: var(--c-primary); text-transform: uppercase; letter-spacing: .1em; margin-bottom: 1.5rem; }
.reclamo-section .form-group + .form-group { margin-top: 1.25rem; }
.field-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.field-full { grid-column: 1 / -1; }
.form-group { display: flex; flex-direction: column; }
.form-group label { font-size: var(--fs-label-sm); font-weight: 600; color: var(--c-ink-soft); margin-bottom: .4rem; }
.form-group .req { color: #ba1a1a; margin-left: .2rem; }
.form-group input, .form-group textarea, .form-group select { border-radius: var(--r); background: var(--c-surface-low); padding: .75rem 1rem; font-size: .95rem; font-family: inherit; color: var(--c-ink); border: 1.5px solid var(--c-outline); transition: border-color .2s, box-shadow .2s; }
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { outline: none; border-color: var(--c-primary); box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-primary) 14%, transparent); background: var(--c-white); }
.form-group input.is-invalid, .form-group textarea.is-invalid { border-color: #ba1a1a; }
.form-group textarea { resize: vertical; min-height: 110px; }
.tipo-options { display: flex; gap: .75rem; flex-wrap: wrap; }
.tipo-option { flex: 1; min-width: 140px; }
.tipo-option input { position: absolute; opacity: 0; pointer-events: none; }
.tipo-option label { display: flex; align-items: center; gap: .6rem; padding: .85rem 1.25rem; border-radius: var(--r); border: 1.5px solid var(--c-outline); background: var(--c-surface-low); cursor: pointer; font-weight: 600; color: var(--c-ink-soft); }
.tipo-option input:checked + label { border-color: var(--c-primary); background: color-mix(in srgb, var(--c-primary) 8%, transparent); color: var(--c-primary); }
.tipo-option label .micon { font-size: 1.1rem; }
.monto-wrap { position: relative; width: 100%; }
.monto-wrap__prefix { position: absolute; left: 1rem; top: 50%; transform: translateY(-50%); font-weight: 600; color: var(--c-ink-soft); pointer-events: none; }
.monto-wrap input { width: 100%; display: block; padding-left: 2.6rem; }
.reclamo-foot { padding: 1.75rem 2rem 2rem; background: var(--c-surface-low); border-top: 1px solid var(--c-outline); }
.reclamo-foot__note { font-size: var(--fs-label-sm); color: var(--c-ink-soft); margin-bottom: 1.25rem; line-height: 1.6; }
.reclamo-submit { width: 100%; }
.reclamo-result { display: none; margin-top: 1.25rem; padding: 1rem 1.25rem; border-radius: var(--r); font-size: .95rem; font-weight: 600; align-items: center; gap: .6rem; }
.reclamo-result.success { display: flex; background: color-mix(in srgb, var(--c-lime) 22%, transparent); border: 1px solid var(--c-primary); color: var(--c-primary); }
.reclamo-result.error { display: flex; background: rgba(186,26,26,.08); border: 1px solid #ba1a1a; color: #ba1a1a; }
.reclamo-num { text-align: right; font-size: var(--fs-label-sm); color: var(--c-ink-soft); margin-top: 1rem; }
@media (max-width: 640px) { .field-grid { grid-template-columns: 1fr; } .tipo-options { flex-direction: column; } .reclamo-section, .reclamo-header, .reclamo-foot { padding: 1.5rem; } }

/* --- Página legal (Política de Privacidad) --- */
.legal-back { display: inline-flex; align-items: center; gap: .4rem; color: var(--c-primary); font-weight: 600; margin-bottom: 1.5rem; }
.legal-header { margin-bottom: 1.5rem; }
.legal-header h1 { font-size: var(--fs-h-lg); color: var(--c-primary); margin-top: .5rem; }
.legal-updated { color: var(--c-ink-soft); font-size: var(--fs-label-sm); margin-top: .5rem; }
.legal-body { background: var(--c-white); border: 1px solid var(--c-outline); border-radius: var(--r-lg); padding: 2.5rem; box-shadow: var(--sh-md); }
.legal-body h2 { font-size: 1.3rem; color: var(--c-primary); margin: 2rem 0 .75rem; }
.legal-body h2:first-child { margin-top: 0; }
.legal-body p, .legal-body li { color: var(--c-ink-soft); line-height: 1.8; }
.legal-body ul { padding-left: 1.25rem; margin: .5rem 0; list-style: disc; }
.legal-body a { color: var(--c-primary); text-decoration: underline; }
.legal-data { margin-top: 2rem; padding: 1.25rem 1.5rem; background: var(--c-surface-low); border-radius: var(--r); border-left: 3px solid var(--c-secondary); line-height: 1.9; color: var(--c-ink); font-size: .95rem; }
@media (max-width: 640px) { .legal-body { padding: 1.5rem; } }

/* ============================================================
   19 · PÁGINAS INTERNAS — page-hero + catálogo + soluciones + nosotros
   ============================================================ */
.is-hidden { display: none !important; }

/* --- Page hero (banda de cabecera con foto + overlay verde = "peso") --- */
.page-hero { position: relative; overflow: hidden; display: flex; align-items: center; min-height: 340px; padding-block: clamp(3rem, 2rem + 4vw, 4.5rem); }
.page-hero__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.page-hero__overlay { position: absolute; inset: 0; z-index: 1; background: linear-gradient(to right, rgba(20,91,42,.93), rgba(20,91,42,.58) 58%, rgba(20,91,42,.32)); }
.page-hero__inner { position: relative; z-index: 2; color: #fff; }
.page-hero .breadcrumb { color: rgba(255,255,255,.82); margin-bottom: 1rem; }
.page-hero .breadcrumb a { color: #fff; }
.page-hero .breadcrumb a:hover { text-decoration: underline; }
.page-hero .breadcrumb .micon { color: rgba(255,255,255,.6); }
.page-hero .ds-eyebrow { --ds-eyebrow-main: #fff; }
.page-hero h1 { color: #fff; font-size: var(--fs-display); line-height: 1.08; max-width: 20ch; margin-top: .5rem; }
.page-hero p { color: rgba(255,255,255,.9); max-width: 54ch; margin-top: 1rem; font-size: var(--fs-body-lg); }

/* --- Toolbar de filtros (catálogo) --- */
.catalog-toolbar { display: flex; flex-wrap: wrap; gap: .6rem; align-items: center; margin-bottom: var(--sp-lg); }
.filter-chip { display: inline-flex; align-items: center; gap: .45rem; padding: .55rem 1.1rem; border-radius: var(--r-pill); border: 1.5px solid var(--c-outline); background: var(--c-white); color: var(--c-ink-soft); font-family: inherit; font-size: var(--fs-label); font-weight: 600; cursor: pointer; transition: border-color .2s, color .2s, background-color .2s; }
.filter-chip:hover { border-color: var(--c-primary); color: var(--c-primary); }
.filter-chip.is-active { background: var(--c-primary); border-color: var(--c-primary); color: #fff; }
.filter-chip .micon { font-size: 1.15rem; }

/* --- Tarjeta de producto (catálogo corporativo) --- */
.prod-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-gutter); }
.prod-card { background: var(--c-white); border: 1px solid var(--c-outline); border-radius: var(--r-lg); overflow: hidden; display: flex; flex-direction: column; transition: box-shadow .25s ease, transform .25s ease; }
.prod-card:hover { box-shadow: var(--sh-lg); transform: translateY(-3px); }
.prod-card__media { position: relative; aspect-ratio: 4 / 3; background: var(--c-surface-low); overflow: hidden; }
.prod-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.prod-card:hover .prod-card__media img { transform: scale(1.05); }
.prod-card__badge { position: absolute; top: .85rem; left: .85rem; z-index: 1; }
.prod-card__body { padding: 1.5rem; display: flex; flex-direction: column; gap: .55rem; flex: 1 1 auto; }
.prod-card__cat { font-size: var(--fs-label-sm); font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--c-secondary); }
.prod-card__name { font-family: var(--font-display); font-size: 1.3rem; color: var(--c-primary); line-height: 1.15; }
.prod-card__type { font-size: var(--fs-label); color: var(--c-ink-soft); }
.prod-card__ai { font-size: var(--fs-label-sm); color: var(--c-ink); background: var(--c-surface-low); border-radius: var(--r); padding: .5rem .75rem; }
.prod-card__ai strong { color: var(--c-primary); }
.prod-card__cultivos { display: flex; flex-wrap: wrap; gap: .35rem; margin-top: .15rem; }
.prod-card__cultivos span { font-size: var(--fs-label-sm); background: color-mix(in srgb, var(--c-secondary) 13%, transparent); color: var(--c-primary-dk); padding: .2rem .65rem; border-radius: var(--r-pill); }
.catalog-empty { grid-column: 1 / -1; text-align: center; color: var(--c-ink-soft); padding: var(--sp-lg); }
.catalog-note { margin-top: var(--sp-lg); font-size: var(--fs-label-sm); color: var(--c-ink-soft); text-align: center; }
.prod-card__foot { margin-top: auto; padding-top: 1rem; display: flex; align-items: center; justify-content: space-between; gap: .75rem; border-top: 1px solid var(--c-outline); }
.prod-card__pres { font-size: var(--fs-label-sm); color: var(--c-ink-soft); }
.prod-card__cta { display: inline-flex; align-items: center; gap: .35rem; font-size: var(--fs-label); font-weight: 700; color: var(--c-primary); }
.prod-card__cta .micon { font-size: 1.1rem; transition: transform .2s ease; }
.prod-card:hover .prod-card__cta .micon { transform: translateX(3px); }

/* --- Soluciones: bloque alterno texto/imagen --- */
.sol-block { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-xl); align-items: center; }
.sol-block + .sol-block { margin-top: var(--sp-xl); }
.sol-block__media { border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--sh-lg); aspect-ratio: 4 / 3; }
.sol-block__media img { width: 100%; height: 100%; object-fit: cover; }
.sol-block--rev .sol-block__media { order: 2; }
.sol-block__icon { width: 3.5rem; height: 3.5rem; border-radius: var(--r-pill); display: inline-flex; align-items: center; justify-content: center; background: color-mix(in srgb, var(--c-primary) 10%, transparent); margin-bottom: 1rem; }
.sol-block__icon .micon { color: var(--c-primary); font-size: 1.75rem; }
.sol-block h2 { font-size: var(--fs-h-lg); color: var(--c-primary); }
.sol-block__lead { color: var(--c-ink-soft); margin: 1rem 0 1.25rem; line-height: 1.7; }
.sol-list { display: flex; flex-direction: column; gap: .65rem; }
.sol-list li { display: flex; align-items: flex-start; gap: .6rem; color: var(--c-ink); }
.sol-list .micon { color: var(--c-secondary); font-size: 1.25rem; flex-shrink: 0; }
.sol-block .ds-button { margin-top: 1.5rem; align-self: flex-start; }

/* --- Nosotros: valores + cifras --- */
.values-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-gutter); margin-top: var(--sp-xl); }
.value-card { padding: 1.75rem; background: var(--c-white); border: 1px solid var(--c-outline); border-radius: var(--r-lg); text-align: center; transition: box-shadow .25s ease, transform .25s ease; }
.value-card:hover { box-shadow: var(--sh-md); transform: translateY(-3px); }
.value-card__icon { width: 3.5rem; height: 3.5rem; border-radius: var(--r-pill); display: inline-flex; align-items: center; justify-content: center; background: color-mix(in srgb, var(--c-primary) 10%, transparent); margin-bottom: 1rem; }
.value-card__icon .micon { color: var(--c-primary); font-size: 1.6rem; }
.value-card h3 { font-size: 1.0625rem; color: var(--c-primary); margin-bottom: .4rem; }
.value-card p { font-size: var(--fs-label); color: var(--c-ink-soft); }
.stats-band { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-gutter); }
.stat-item { text-align: center; }
.stat-item__num { font-family: var(--font-display); font-size: clamp(2.5rem, 1.8rem + 2vw, 3.25rem); font-weight: 700; color: var(--c-primary); line-height: 1; }
.stat-item__lbl { display: block; margin-top: .5rem; color: var(--c-ink-soft); font-size: var(--fs-label); }

/* --- Contacto (página): mapa + horario --- */
.contact-extra { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-gutter); margin-top: var(--sp-lg); }
.contact-map { border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--sh-md); border: 1px solid var(--c-outline); min-height: 260px; }
.contact-map iframe { width: 100%; height: 100%; min-height: 260px; border: 0; display: block; }
.contact-hours { background: var(--c-white); border: 1px solid var(--c-outline); border-radius: var(--r-lg); padding: 1.75rem; box-shadow: var(--sh-md); }
.contact-hours h3 { font-family: var(--font-display); color: var(--c-primary); font-size: var(--fs-h-md); margin-bottom: 1rem; }
.contact-hours ul { display: flex; flex-direction: column; gap: .65rem; }
.contact-hours li { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding-bottom: .65rem; border-bottom: 1px solid var(--c-outline); color: var(--c-ink); font-size: var(--fs-label); }
.contact-hours li:last-child { border-bottom: 0; padding-bottom: 0; }
.contact-hours li span:last-child { color: var(--c-ink-soft); }

@media (max-width: 1024px) {
  .prod-grid { grid-template-columns: 1fr 1fr; }
  .values-grid, .stats-band { grid-template-columns: 1fr 1fr; row-gap: var(--sp-lg); }
}
@media (max-width: 900px) {
  .sol-block { grid-template-columns: 1fr; gap: var(--sp-lg); }
  .sol-block--rev .sol-block__media { order: 0; }
  .contact-extra { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .prod-grid { grid-template-columns: 1fr; }
  .values-grid, .stats-band { grid-template-columns: 1fr; }
}
