/* =========================================================================
   FINSECTO — Landing DEFINITIVA
   Base de craft: Dirección A "Autoridad local & confianza" (papel cálido,
   verdes de marca, hairlines editoriales, stats sobre fondo oscuro, sin ámbar).
   Injerto de conversión: Dirección B (hero 100svh con CTAs above-the-fold,
   sticky-cta en toda la página <860px, botón Llamar verde casi negro,
   dimensionado generoso de botones, breakpoints mobile-first).
   CSS self-contained, escrito a mano. Sin Tailwind/SASS/Bootstrap/build.
   Pairing tipográfico: Barlow Condensed (display/datos) + Inter (texto).
   ========================================================================= */

:root {
    /* Verdes de marca + paleta cohesiva (sin ámbar) */
    --green-900: #123e1d;
    --green-800: #185025;   /* primario oscuro de marca */
    --green-700: #1d6230;
    --green-600: #26793a;   /* verde medio de marca */
    --green-500: #2f8f47;
    --green-100: #e3ede4;
    --green-050: #f1f6f0;

    /* CTAs de conversión */
    --call:      #143b1d;   /* "Llamar": verde casi negro, máximo contraste sobre foto */
    --call-hover:#0f2e16;
    --wa:        #1faf54;   /* WhatsApp de marca (sólo en botones de WhatsApp) */
    --wa-dark:   #138a40;

    /* Neutros cálidos */
    --ink:       #1c1d19;   /* texto principal, casi negro cálido */
    --ink-soft:  #4a4d44;   /* texto secundario */
    --ink-faint: #8a8d80;   /* metadatos, captions */
    --line:      #d9d8cf;   /* hairlines */
    --line-soft: #e8e7df;
    --paper:     #f6f4ec;   /* fondo cálido de la página */
    --paper-2:   #fbfaf4;   /* fondo de tarjetas / secciones claras */
    --white:     #ffffff;

    /* Estructura */
    --maxw: 1180px;
    --gutter: clamp(1.25rem, 4vw, 3rem);
    --topbar-h: 38px;
    --nav-h: 60px;
    --sticky-h: 66px;

    --display: "Barlow Condensed", "Arial Narrow", system-ui, sans-serif;
    --sans:    "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}

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

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

body {
    margin: 0;
    font-family: var(--sans);
    font-size: 17px;
    line-height: 1.65;
    color: var(--ink);
    background: var(--paper);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    /* Espacio para topbar + navbar fijos arriba y sticky-cta abajo (mobile) */
    padding-top: calc(var(--topbar-h) + var(--nav-h));
    padding-bottom: calc(var(--sticky-h) + env(safe-area-inset-bottom, 0px));
}

img { max-width: 100%; display: block; }
a { color: inherit; }

h1, h2, h3 {
    margin: 0;
    font-family: var(--display);
    font-weight: 600;
    line-height: 1.03;
    letter-spacing: 0;
}

p { margin: 0 0 1rem; }

.ico { flex: none; fill: currentColor; }
.nav__chev { fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

::selection { background: var(--green-600); color: #fff; }

:focus-visible {
    outline: 2px solid var(--green-600);
    outline-offset: 3px;
    border-radius: 2px;
}

/* ------------------------------------------------------------------ layout */
.container {
    width: 100%;
    max-width: var(--maxw);
    margin-inline: auto;
    padding-inline: var(--gutter);
}

/* No-op de grilla Bootstrap para las páginas legales que comparten el layout */
.row { display: block; }
.col-12, .col-sm-12, .col-md-12, .col-lg-12,
.col, .col-sm, .col-md, .col-lg,
[class*="col-"] { width: 100%; max-width: 100%; }

/* ============================================================== TOPBAR */
.topbar {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 60;
    height: var(--topbar-h);
    background: var(--green-900);
    color: #eaf1e6;
    font-size: 0.82rem;
}
.topbar__inner {
    max-width: var(--maxw);
    margin-inline: auto;
    height: 100%;
    padding-inline: var(--gutter);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}
.topbar__hours {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: #cfe0c5;
    letter-spacing: 0.01em;
    white-space: nowrap;
}
.topbar__hours .ico { color: var(--green-500); }
.topbar__phone {
    text-decoration: none;
    font-weight: 600;
    color: #fff;
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
}
.topbar__phone .ico { color: var(--green-500); }
.topbar__phone:hover { color: #eaf1e6; }

@media (max-width: 430px) {
    .topbar { font-size: 0.78rem; }
    .topbar__hours .ico { display: none; }
}

/* ============================================================== NAVBAR */
.site-header {
    position: fixed;
    top: var(--topbar-h); left: 0; right: 0;
    z-index: 55;
    height: var(--nav-h);
    background: rgba(246, 244, 236, 0.92);
    -webkit-backdrop-filter: saturate(140%) blur(8px);
    backdrop-filter: saturate(140%) blur(8px);
    border-bottom: 1px solid var(--line);
}
.nav {
    max-width: var(--maxw);
    margin-inline: auto;
    height: 100%;
    padding-inline: var(--gutter);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}
.nav__brand { display: inline-flex; align-items: center; }
.nav__brand img { height: 30px; width: auto; }

.nav__list {
    list-style: none;
    margin: 0; padding: 0;
    display: flex;
    align-items: center;
    gap: clamp(0.5rem, 1.7vw, 1.5rem);
}
.nav__link {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    font-size: 0.92rem;
    font-weight: 500;
    color: var(--ink-soft);
    padding: 0.4rem 0;
    letter-spacing: 0.01em;
    transition: color 0.18s ease;
}
.nav__link:hover { color: var(--green-700); }

/* botón "Llamar" de la navbar (CTA integrada) — verde casi negro de marca */
.nav__cta-li { display: flex; }
.nav__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    text-decoration: none;
    font-size: 0.9rem;
    font-weight: 700;
    color: #fff;
    background: var(--call);
    border: 1px solid var(--call);
    border-radius: 999px;
    padding: 0.55rem 1.1rem;
    transition: background 0.18s ease, border-color 0.18s ease;
}
.nav__cta:hover { background: var(--call-hover); border-color: var(--call-hover); }

/* dropdown de zonas con <details> (sin JS de framework) */
.nav__zones details { position: relative; }
.nav__summary {
    list-style: none;
    cursor: pointer;
    user-select: none;
    gap: 0.35rem;
}
.nav__summary::-webkit-details-marker { display: none; }
.nav__chev { transition: transform 0.2s ease; }
.nav__zones details[open] .nav__chev { transform: rotate(180deg); }

.nav__dropdown {
    position: absolute;
    top: calc(100% + 0.85rem);
    right: 0;
    width: 460px;
    max-width: 80vw;
    background: var(--white);
    border: 1px solid var(--line);
    box-shadow: 0 22px 50px -24px rgba(18, 62, 29, 0.4);
    padding: 0.5rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1px 0;
}
.nav__dropdown a {
    text-decoration: none;
    font-size: 0.88rem;
    color: var(--ink-soft);
    padding: 0.5rem 0.75rem;
    border-radius: 4px;
    transition: background 0.15s ease, color 0.15s ease;
}
.nav__dropdown a:hover { background: var(--green-050); color: var(--green-800); }

/* hamburguesa (botón accesible) */
.nav__burger {
    display: none;
    appearance: none;
    -webkit-appearance: none;
    padding: 0;
    font: inherit;
    color: inherit;
}

/* ============================================================== BOTONES */
/* Dimensionado generoso (injerto de conversión): táctil, legible, sin sombras gigantes */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.7rem;
    text-decoration: none;
    font-family: var(--sans);
    font-weight: 700;
    font-size: 1.0625rem;        /* ~17px */
    line-height: 1.1;
    padding: 1rem 1.4rem;        /* ~16px 22px */
    border-radius: 13px;
    border: 1px solid transparent;
    transition: transform 0.12s ease, background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn .ico { flex: none; }
.btn__txt { display: flex; flex-direction: column; align-items: flex-start; line-height: 1.15; }
.btn__txt small {
    font-weight: 500;
    font-size: 0.75rem;
    opacity: 0.85;
    margin-top: 1px;
    font-variant-numeric: tabular-nums;
}

.btn--call {
    background: var(--call);
    color: #fff;
    border-color: var(--call);
}
.btn--call:hover { background: var(--call-hover); border-color: var(--call-hover); }

.btn--wa {
    background: var(--wa);
    color: #fff;
    border-color: var(--wa);
}
.btn--wa:hover { background: var(--wa-dark); border-color: var(--wa-dark); }

.btn--sm {
    padding: 0.7rem 1.1rem;
    font-size: 0.95rem;
    border-radius: 11px;
    gap: 0.5rem;
}
.btn--sm .btn__txt { flex-direction: row; }

/* ============================================================== TIPOGRAFÍA DE SECCIÓN */
.section-head { max-width: 100%; margin-bottom: clamp(2.2rem, 4.5vw, 3.5rem); }
.section-head__title { max-width: 22ch; }
@media (min-width: 860px) { .section-head__title { max-width: none; } }
.section-head__kicker {
    display: inline-block;
    margin-bottom: 0.9rem;
    padding-left: 28px;
    position: relative;
    font-family: var(--sans);
    font-size: 0.74rem;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--green-700);
}
.section-head__kicker::before {
    content: "";
    position: absolute;
    left: 0; top: 50%;
    width: 20px; height: 2px;
    background: var(--green-700);
}
.section-head__title {
    font-size: clamp(2.1rem, 1rem + 3.6vw, 3.5rem);
    line-height: 1.04;
    color: var(--ink);
    text-wrap: balance;
}

/* ============================================================== HERO (editorial) */
/* Composición editorial sobre el verde de marca: copy a la izquierda, panel de
   credenciales a la derecha en desktop. Sin foto de stock ni scrim opaco de parche;
   cuando llegue la foto real del técnico se reemplaza .hero__panel por <img>. */
.hero {
    position: relative;
    isolation: isolate;
    background-color: var(--green-900);
    background-image: url('/header.jpg');
    background-size: cover;
    background-position: center right;
    color: #fff;
    overflow: hidden;
}
/* Overlay verde de marca sobre la imagen del header: oscurece lo justo para que
   el texto blanco quede legible (AA) sin tapar el motivo de la foto. */
.hero::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    background:
        linear-gradient(95deg, rgba(18, 62, 29, 0.92) 0%, rgba(18, 62, 29, 0.82) 42%, rgba(18, 62, 29, 0.55) 100%),
        linear-gradient(0deg, rgba(18, 62, 29, 0.45) 0%, rgba(18, 62, 29, 0) 40%);
    pointer-events: none;
}
.hero__inner {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: var(--maxw);
    margin-inline: auto;
    padding: clamp(2rem, 6vw, 4.5rem) var(--gutter) clamp(2.25rem, 6vw, 5rem);
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(2rem, 5vw, 3.5rem);
    align-items: center;
}
.hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    margin: 0 0 1.2rem;
    font-size: 0.82rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    color: #cfe0c5;
}
.hero__pill {
    display: inline-block;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.28);
    color: #fff;
    font-weight: 600;
    font-size: 0.72rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 0.3rem 0.7rem;
    border-radius: 999px;
}
.hero__title {
    max-width: 18ch;
    font-size: clamp(2.5rem, 1rem + 6vw, 4.4rem);
    line-height: 0.98;
    font-weight: 700;
    letter-spacing: -0.01em;
    text-wrap: balance;
}
.hero__lead {
    max-width: 48ch;
    margin-top: 1.3rem;
    font-size: clamp(1.02rem, 0.95rem + 0.4vw, 1.2rem);
    color: #e8efe3;
}
.hero__zone {
    display: block;
    margin-top: 0.5rem;
    color: #bcd2b4;
    font-size: 0.98rem;
}
.hero__cta {
    margin-top: 1.6rem;
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.75rem;
    max-width: 480px;
}
.hero__cta .btn { width: 100%; }
.hero__trust {
    list-style: none;
    margin: 1.8rem 0 0;
    padding: 1.2rem 0 0;
    border-top: 1px solid rgba(255, 255, 255, 0.18);
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem 1.6rem;
    font-size: 0.88rem;
    color: #cbddc3;
}
.hero__trust li { display: inline-flex; align-items: center; gap: 0.5rem; }
.hero__trust li::before {
    content: "";
    width: 7px; height: 7px;
    border-radius: 50%;
    background: var(--green-500);
    box-shadow: 0 0 0 3px rgba(47, 143, 71, 0.25);
}

/* Panel de credenciales del hero (placeholder honesto hasta tener foto propia) */
.hero__panel {
    margin: 0;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 4px;
    padding: clamp(1.4rem, 4vw, 2rem);
}
.hero__panel-kicker {
    margin: 0 0 1.1rem;
    font-family: var(--sans);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #bcd2b4;
}
.hero__panel-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 1rem; }
.hero__panel-list li {
    display: grid;
    grid-template-columns: 22px 1fr;
    align-items: start;
    gap: 0.85rem;
    font-size: 0.95rem;
    line-height: 1.45;
    color: #e2ecdc;
}
.hero__panel-list li + li { padding-top: 1rem; border-top: 1px solid rgba(255, 255, 255, 0.12); }
.hero__panel-list .ico { color: var(--green-500); margin-top: 1px; }
.hero__panel-list strong { color: #fff; font-weight: 600; }
.hero__panel-note {
    margin: 1.2rem 0 0;
    padding-top: 1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
    font-size: 0.82rem;
    line-height: 1.5;
    color: #aac4a1;
}

/* ============================================================== STATS */
/* Franja sobre fondo oscuro --ink (más premium que verde plano);
   números en blanco/Barlow Condensed con tabular-nums (sin ámbar). */
.stats {
    background: var(--ink);
    color: #ecede5;
    border-bottom: 1px solid #2a2c24;
}
.stats__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    padding-block: 0;
}
.stat {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    padding: clamp(1.6rem, 4vw, 2.4rem) clamp(1rem, 3vw, 2rem);
    border-bottom: 1px solid #2f3129;
}
.stat:nth-child(odd) { border-right: 1px solid #2f3129; }
.stat__num {
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(2rem, 1rem + 3vw, 2.9rem);
    line-height: 1;
    color: #fff;
    font-variant-numeric: tabular-nums;
}
.stat__label { font-size: 0.86rem; color: #a7a99c; max-width: 22ch; }

@media (min-width: 760px) {
    .stats__grid { grid-template-columns: repeat(4, 1fr); }
    .stat { border-bottom: none; }
    .stat:nth-child(odd) { border-right: 1px solid #2f3129; }
    .stat:not(:last-child) { border-right: 1px solid #2f3129; }
    .stat:last-child { border-right: none; }
}

/* ============================================================== VALUES */
/* Estilo editorial: SIN border+sombra de tarjeta; separadores hairline. */
.values { padding-block: clamp(3.5rem, 8vw, 7rem); }
.values__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    border-top: 1px solid var(--line);
}
.value {
    padding-block: clamp(1.8rem, 4vw, 2.6rem);
    border-bottom: 1px solid var(--line);
}
/* Íconos de línea monocromos (stroke), coherentes con los SVG inline de la página */
.value__ico {
    width: 40px; height: 40px;
    margin-bottom: 1.1rem;
    color: var(--green-700);
}
.value__title { font-size: 1.9rem; margin-bottom: 0.5rem; color: var(--ink); }
.value__text { color: var(--ink-soft); max-width: 50ch; margin: 0; }

@media (min-width: 860px) {
    .values__grid { grid-template-columns: repeat(3, 1fr); }
    .value {
        padding: clamp(1.8rem, 3vw, 2.6rem) clamp(1.5rem, 2.5vw, 2.2rem) 2.4rem;
        border-bottom: none;
        border-right: 1px solid var(--line);
    }
    .value:first-child { padding-left: 0; }
    .value:last-child { border-right: none; padding-right: 0; }
    .value__ico { width: 44px; height: 44px; }
}

/* ============================================================== SERVICES */
.services { padding-bottom: clamp(3.5rem, 8vw, 6rem); }
.service {
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(1.5rem, 4vw, 3rem);
    align-items: center;
    padding-block: clamp(2.5rem, 5vw, 4rem);
    border-top: 1px solid var(--ink);
}
.service + .service { border-top: 1px solid var(--line); }
.service__media { margin: 0; position: relative; }
.service__media img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 3px;
    filter: saturate(1.03) contrast(1.02);
}
/* Sello de estudio: barra verde 64x4 en la esquina inferior de la foto */
.service__media::after {
    content: "";
    position: absolute;
    left: 0; bottom: 0;
    width: 64px; height: 4px;
    background: var(--green-600);
}
/* Panel de ilustración de línea para el servicio que aún no tiene foto propia.
   Honesto (es un dibujo, no una foto fingida) y coherente con el set monocromo;
   mismo formato 1:1 que las fotos. Reemplazar por foto real cuando la haya. */
.service__media--art {
    aspect-ratio: 1 / 1;
    border-radius: 3px;
    overflow: hidden;
    background:
        radial-gradient(120% 120% at 18% 14%, rgba(255, 255, 255, 0.05) 0%, rgba(255, 255, 255, 0) 46%),
        linear-gradient(150deg, var(--green-800) 0%, var(--green-900) 100%);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 0.9rem;
    padding: clamp(1.5rem, 5vw, 3rem);
}
.service__art {
    width: clamp(84px, 26%, 120px);
    height: auto;
    color: #d7e6ce;
}
.service__media--art .service__art-cap {
    font-family: var(--display);
    font-weight: 600;
    font-size: clamp(1.6rem, 1rem + 2.2vw, 2.3rem);
    line-height: 1.02;
    color: #fff;
    letter-spacing: 0.01em;
}
.service__media--art .service__art-sub {
    font-size: 0.78rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #bcd2b4;
}

.service__tag {
    display: inline-block;
    font-size: 0.76rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--green-700);
    font-weight: 600;
    margin-bottom: 0.6rem;
}
.service__title { font-size: clamp(2.1rem, 1rem + 2.8vw, 3rem); margin-bottom: 0.8rem; color: var(--ink); }
.service__text { color: var(--ink-soft); max-width: 52ch; }
.service__cta { display: flex; flex-wrap: wrap; gap: 0.7rem; margin-top: 1.4rem; }

@media (min-width: 820px) {
    .service { grid-template-columns: 0.92fr 1.08fr; gap: clamp(2.5rem, 5vw, 4.5rem); }
    .service--reverse .service__media { order: 2; }
    .service--reverse .service__body { order: 1; }
}

/* ============================================================== PRUEBA SOCIAL */
/* Reseñas + rubros: lo que más humaniza un negocio de servicios. Tarjetas con
   hairline editorial (sin sombra de plantilla), estrellas en verde de marca. */
.proof {
    background: var(--paper-2);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    padding-block: clamp(3.5rem, 8vw, 6.5rem);
}
.proof__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1px;
    background: var(--line);
    border: 1px solid var(--line);
}
.review {
    margin: 0;
    background: var(--white);
    padding: clamp(1.5rem, 3vw, 2rem);
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}
.review__head { display: flex; align-items: center; justify-content: space-between; gap: 0.5rem; }
/* Estrellas en dorado Google (más auténtico para reseñas reales de Google) */
.review__stars { display: inline-flex; gap: 2px; color: #f4b400; }
.review__stars svg { fill: currentColor; }
.review__g { flex: none; }
.review__text {
    margin: 0;
    font-size: 1.02rem;
    line-height: 1.55;
    color: var(--ink);
}
.review__by {
    margin-top: auto;
    padding-top: 0.4rem;
}
.review__name { display: block; font-size: 0.95rem; font-weight: 600; color: var(--ink); }
.review__meta { display: block; font-size: 0.8rem; color: var(--ink-faint); margin-top: 2px; }

/* CTA: ver todas las reseñas en Google */
.proof__more { margin-top: clamp(1.6rem, 4vw, 2.4rem); display: flex; justify-content: center; }
.proof__more-link {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    text-decoration: none;
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--ink);
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 0.75rem 1.4rem;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.12s ease;
}
.proof__more-link:hover {
    border-color: var(--green-600);
    box-shadow: 0 12px 28px -18px rgba(18, 62, 29, 0.55);
    transform: translateY(-1px);
}

.proof__sectors {
    margin-top: clamp(2rem, 4vw, 2.8rem);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.6rem 0.7rem;
}
.proof__sectors-label {
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--green-700);
    margin-right: 0.4rem;
}
.proof__sectors-list {
    list-style: none;
    margin: 0; padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.proof__sectors-list li {
    font-size: 0.86rem;
    color: var(--ink-soft);
    background: var(--green-050);
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 0.35rem 0.85rem;
}

@media (min-width: 760px) {
    .proof__grid { grid-template-columns: repeat(3, 1fr); }
}

/* ============================================================== PESTS */
.pests { padding-block: clamp(3.5rem, 8vw, 7rem); border-top: 1px solid var(--line-soft); }
.pests__list {
    list-style: none;
    margin: 0; padding: 0;
    border-top: 1px solid var(--line);
}
.pests__list li {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.5rem 1.5rem;
    padding: 1.1rem 0.25rem;
    border-bottom: 1px solid var(--line);
    transition: padding-left 0.15s ease;
}
.pests__list li:hover { padding-left: 0.5rem; }
.pests__name {
    font-family: var(--display);
    font-size: 1.6rem;
    font-weight: 600;
    color: var(--ink);
    line-height: 1;
}
.pests__sol { font-size: 0.92rem; color: var(--ink-faint); }

@media (min-width: 720px) {
    .pests__list { columns: 2; column-gap: clamp(2.5rem, 6vw, 5rem); }
    .pests__list li { break-inside: avoid; }
}

/* ============================================================== CLOSER (CTA final) */
.closer {
    background: var(--green-900);
    color: #fff;
    padding-block: clamp(3.5rem, 8vw, 6rem);
}
.closer__inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(2rem, 5vw, 3.5rem);
    align-items: center;
}
.closer__title {
    font-size: clamp(2.1rem, 1rem + 3.8vw, 3.6rem);
    line-height: 1.04;
    max-width: 16ch;
    margin-bottom: 1rem;
}
.closer__text { color: #c6d6bf; max-width: 46ch; margin: 0; }
.closer__cta {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.75rem;
    max-width: 460px;
}
.closer__cta .btn { width: 100%; }

@media (min-width: 560px) {
    .closer__cta { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 860px) {
    .closer__inner { grid-template-columns: 1.25fr 0.75fr; }
    .closer__cta { align-self: center; }
}

/* ============================================================== FOOTER */
.site-footer {
    background: var(--ink);
    color: #d6d8cc;
    padding-block: clamp(3rem, 6vw, 4.5rem) 1.5rem;
}
.footer-grid {
    max-width: var(--maxw);
    margin-inline: auto;
    padding-inline: var(--gutter);
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
}
.footer-brand img { height: 32px; width: auto; }
.footer-brand__tag { margin-top: 1rem; max-width: 38ch; color: #a4a79a; font-size: 0.92rem; }
.footer-brand__contact { display: flex; flex-wrap: wrap; gap: 0.7rem; margin-top: 1.4rem; }
.footer-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    text-decoration: none;
    font-size: 0.9rem;
    font-weight: 700;
    padding: 0.6rem 1.1rem;
    border-radius: 999px;
    transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}
.footer-btn--call {
    color: #eef0e7;
    border: 1px solid #45473d;
    background: transparent;
}
.footer-btn--call:hover { background: #fff; color: var(--ink); border-color: #fff; }
.footer-btn--wa {
    color: #fff;
    background: var(--wa);
    border: 1px solid var(--wa);
}
.footer-btn--wa:hover { background: var(--wa-dark); border-color: var(--wa-dark); }

.footer-col__title {
    font-family: var(--sans);
    font-size: 0.74rem;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #8d9082;
    margin: 0 0 1rem;
}
.footer-list { list-style: none; margin: 0; padding: 0; }
.footer-list li { margin-bottom: 0.6rem; font-size: 0.92rem; color: #b6b9ac; }
.footer-list a { text-decoration: none; color: #e4e6db; transition: color 0.15s ease; }
.footer-list a:hover { color: #fff; text-decoration: underline; text-underline-offset: 3px; }

.footer-zones {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.55rem 1.2rem;
}
.footer-zones a {
    text-decoration: none;
    font-size: 0.92rem;
    color: #b6b9ac;
    transition: color 0.15s ease;
}
.footer-zones a:hover { color: #fff; }

.footer-bottom {
    max-width: var(--maxw);
    margin: clamp(2.5rem, 5vw, 3.5rem) auto 0;
    padding: 1.5rem var(--gutter) 0;
    border-top: 1px solid #34362e;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 0.75rem;
    font-size: 0.85rem;
    color: #8d9082;
}
.footer-bottom p { margin: 0; }
.footer-top-link { text-decoration: none; color: #b6b9ac; }
.footer-top-link:hover { color: #fff; }

@media (min-width: 720px) {
    .footer-grid { grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 2rem; }
}

/* ============================================================== STICKY CTA (mobile) */
/* Injerto de conversión: fija en TODA la página <860px, alineada al navbar
   (cero dead-zone); se oculta >=860px con body padding-bottom:0. */
.sticky-cta {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    z-index: 70;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    padding: 8px 10px calc(8px + env(safe-area-inset-bottom, 0px));
    background: rgba(246, 244, 236, 0.97);
    -webkit-backdrop-filter: blur(6px);
    backdrop-filter: blur(6px);
    border-top: 1px solid var(--line);
    box-shadow: 0 -8px 24px -16px rgba(0, 0, 0, 0.4);
}
.sticky-cta__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    height: 50px;
    border-radius: 12px;
    text-decoration: none;
    font-size: 0.95rem;
    font-weight: 700;
    color: #fff;
}
.sticky-cta__call { background: var(--call); }
.sticky-cta__call:hover, .sticky-cta__call:active { background: var(--call-hover); }
.sticky-cta__wa { background: var(--wa); }
.sticky-cta__wa:hover, .sticky-cta__wa:active { background: var(--wa-dark); }

/* ============================================================== RESPONSIVE NAV (mobile) */
@media (max-width: 859px) {
    /* `backdrop-filter` convierte al header en bloque contenedor de sus hijos
       `position: fixed`. Lo quitamos en mobile para que el panel del menú se
       posicione respecto al viewport (y no colapse sobre el header). */
    .site-header {
        -webkit-backdrop-filter: none;
        backdrop-filter: none;
        background: var(--paper);
    }

    .nav__burger {
        display: inline-flex;
        flex-direction: column;
        justify-content: center;
        gap: 5px;
        width: 44px; height: 44px;
        margin-right: -8px;
        cursor: pointer;
        background: none;
        border: none;
    }
    .nav__burger span {
        display: block;
        width: 24px; height: 2px;
        background: var(--ink);
        transition: transform 0.25s ease, opacity 0.2s ease;
    }
    .nav__burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    .nav__burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
    .nav__burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

    .nav__panel {
        position: fixed;
        top: calc(var(--topbar-h) + var(--nav-h));
        left: 0; right: 0;
        bottom: 0;
        background: var(--paper);
        border-top: 1px solid var(--line);
        padding: 1.5rem var(--gutter) 2.5rem;
        transform: translateY(-8px);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transition: opacity 0.22s ease, transform 0.22s ease, visibility 0s linear 0.22s;
        overflow-y: auto;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
    }
    .nav__burger[aria-expanded="true"] ~ .nav__panel {
        opacity: 1;
        visibility: visible;
        transform: none;
        pointer-events: auto;
        transition: opacity 0.22s ease, transform 0.22s ease;
    }

    /* Bloquea el scroll del fondo mientras el menú está abierto. */
    body.nav-open { overflow: hidden; }

    .nav__list { flex-direction: column; align-items: stretch; gap: 0; }
    .nav__list > li { border-bottom: 1px solid var(--line); }
    .nav__link { padding: 1rem 0; font-size: 1.05rem; }

    .nav__cta-li { padding-block: 1rem; border-bottom: none; }
    .nav__cta { width: 100%; justify-content: center; padding-block: 0.9rem; }

    .nav__summary {
        padding: 1rem 0;
        font-size: 1.05rem;
        color: var(--ink-soft);
        display: flex;
        align-items: center;
        justify-content: space-between;
    }
    .nav__dropdown {
        position: static;
        width: auto; max-width: none;
        box-shadow: none;
        border: none;
        border-top: 1px solid var(--line-soft);
        padding: 0.25rem 0 0.75rem;
        background: transparent;
    }
    .nav__dropdown a { padding: 0.6rem 0.5rem; }
}

/* ============================================================== RESPONSIVE — tablet / desktop */
@media (min-width: 560px) {
    .hero__cta { grid-template-columns: 1fr 1fr; max-width: 540px; }
}

@media (min-width: 860px) {
    :root { --nav-h: 66px; }

    /* La sticky-cta se oculta en desktop: hay CTA en navbar + por sección */
    .sticky-cta { display: none; }
    body { padding-bottom: 0; }

    .nav__burger { display: none; }

    /* Composición editorial: copy (1.25fr) + panel de credenciales (0.85fr) */
    .hero__inner {
        grid-template-columns: 1.25fr 0.85fr;
        padding-block: clamp(4rem, 7vw, 6rem);
    }
    .hero__cta { max-width: 560px; }
}

@media (min-width: 1024px) {
    .hero__title { font-size: clamp(3rem, 1rem + 3.4vw, 4.6rem); }
}

/* ============================================================== PÁGINAS LEGALES (layout compartido) */
/* El contenido legal trae su tarjeta blanca inline; sólo aseguramos ancho/aire.
   Las legales abren <div class="container" style="padding-top..."> */
main > .container { padding-block: clamp(1.5rem, 4vw, 3rem) clamp(3rem, 6vw, 5rem); }
main > .container h1 { font-family: var(--display); }
.container[style] { max-width: 860px; }

@media (prefers-reduced-motion: reduce) {
    * { scroll-behavior: auto !important; transition: none !important; }
}
