:root{
    --red:#c9192e; --red-dark:#8f1020; --red-bright:#e2253b; --red-soft:#fdeef0;
    --ink:#1d2125;        /* texto: negro suave */
    --graphite:#23282e;   /* secciones oscuras: grafito, no negro */
    --slate:#333a42;      /* gris pizarra */
    --muted:#697079;
    --line:#e5e8ec; --soft:#f5f7f9; --bone:#eceff2; --paper:#ffffff;
    --maxw:1240px;
    --font:"Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
    --r:16px;
    --shadow:0 22px 50px -30px rgba(29,33,37,.4);
  }
  *{box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--font);line-height:1.6;-webkit-font-smoothing:antialiased;}
  a{color:inherit;text-decoration:none;}
  img{display:block;max-width:100%;}
  h1,h2,h3,h4{margin:0;letter-spacing:-.022em;line-height:1.08;}
  p{margin:0;}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
  .kicker{display:inline-flex;align-items:center;gap:9px;font-size:.74rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--red);}
  .kicker::before{content:"";width:20px;height:2px;background:var(--red);}
  .btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:700;font-size:.96rem;padding:15px 26px;border-radius:999px;border:2px solid transparent;cursor:pointer;transition:.18s ease;white-space:nowrap;}
  .btn-red{background:var(--red);color:#fff;box-shadow:0 14px 26px -12px rgba(201,25,46,.6);}
  .btn-red:hover{background:var(--red-dark);transform:translateY(-2px);}
  .btn-ghost{background:#fff;border-color:var(--line);color:var(--ink);}
  .btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px);}
  .btn-light{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.4);color:#fff;}
  .btn-light:hover{background:#fff;color:var(--ink);}

  /* reveal */
  .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.16,.84,.44,1),transform .7s cubic-bezier(.16,.84,.44,1);}
  .reveal.in{opacity:1;transform:none;}
  .reveal.d1{transition-delay:.08s;}.reveal.d2{transition-delay:.16s;}.reveal.d3{transition-delay:.24s;}.reveal.d4{transition-delay:.32s;}
  @media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}}

  /* Topbar */
  .topbar{background:var(--graphite);color:#c4cad1;font-size:.82rem;font-weight:500;}
  .topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:40px;gap:16px;}
  .topbar .left{display:flex;gap:20px;align-items:center;}
  .topbar a:hover{color:#fff;}
  .topbar .pill{color:#fff;font-weight:700;}
  .topbar .pill b{color:var(--red-bright);}
  @media(max-width:760px){.topbar .hide{display:none;}}

  /* Barra superior horario */
  .topinfo{background:var(--soft);border-bottom:1px solid var(--line);color:var(--muted);font-size:.82rem;font-weight:600;text-align:center;}
  .topinfo .wrap{padding:8px 28px;}

  /* Header + menu */
  header.site{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);backdrop-filter:saturate(1.6) blur(8px);border-bottom:1px solid var(--line);transition:box-shadow .25s;}
  header.site.scrolled{box-shadow:0 12px 30px -22px rgba(29,33,37,.5);}
  header.site .wrap{display:flex;align-items:center;justify-content:space-between;height:74px;gap:22px;}
  .brand img{height:38px;width:auto;}
  nav.main{display:flex;align-items:center;gap:22px;}
  nav.main > a{font-weight:600;font-size:.94rem;color:var(--slate);position:relative;padding:4px 0;}
  nav.main > a::after{content:"";position:absolute;left:0;bottom:-3px;height:2px;width:0;background:var(--red);transition:width .25s;}
  nav.main > a:hover{color:var(--ink);}nav.main > a:hover::after{width:100%;}
  .nav-dd{position:relative;}
  .nav-dd > summary{display:flex;align-items:center;justify-content:space-between;gap:7px;list-style:none;cursor:pointer;font-weight:600;font-size:.94rem;color:var(--slate);padding:4px 0;}
  .nav-dd > summary::-webkit-details-marker{display:none;}
  .nav-dd > summary::after{content:"+";color:var(--red);font-weight:800;font-size:1.05rem;line-height:1;}
  .nav-dd[open] > summary,.nav-dd > summary:hover{color:var(--ink);}
  .nav-dd[open] > summary::after{content:"\2212";}
  .dd-panel{position:absolute;top:calc(100% + 16px);left:0;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:3px;min-width:440px;padding:14px;z-index:70;animation:pop .2s ease;}
  @keyframes pop{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}
  .dd-compact .dd-panel{grid-template-columns:1fr;min-width:260px;}
  .dd-panel.dd-mega{grid-template-columns:repeat(2,minmax(210px,1fr));min-width:min(680px,calc(100vw - 40px));}
  .dd-panel > a{color:var(--slate);padding:10px 12px;border-radius:9px;font-weight:600;font-size:.9rem;}
  .dd-panel > a:hover{background:var(--red);color:#fff;}
  .dd-label{grid-column:1/-1;color:var(--red);font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:8px 12px 2px;}
  .fam{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--soft);}
  .fam summary{display:flex;justify-content:space-between;align-items:center;list-style:none;cursor:pointer;font-weight:700;font-size:.9rem;color:var(--ink);padding:10px 12px;}
  .fam summary::-webkit-details-marker{display:none;}
  .fam summary::after{content:"+";color:var(--red);font-weight:800;}
  .fam[open] summary::after{content:"\2212";}
  .fam > div{background:#fff;border-top:1px solid var(--line);display:grid;gap:2px;padding:6px;}
  .fam a{padding:8px 10px;border-radius:7px;color:var(--slate);font-size:.88rem;font-weight:600;}
  .fam a:hover{background:var(--red);color:#fff;}
  .head-right{display:flex;align-items:center;gap:14px;}
  .head-phone{display:inline-flex;align-items:center;gap:7px;font-weight:800;font-size:.95rem;color:var(--ink);white-space:nowrap;}
  .head-phone svg{width:18px;height:18px;color:var(--red);}
  .head-phone:hover{color:var(--red-dark);}
  .head-cta{padding:9px 16px;font-size:.88rem;white-space:nowrap;}
  .dd-star{font-weight:800;color:var(--red-dark);}
  .dd-more{font-weight:700;color:var(--red);}
  .head-hours{display:grid;text-align:right;font-size:.76rem;font-weight:800;line-height:1.25;color:var(--muted);white-space:nowrap;}
  .menu-btn{display:none;background:none;border:0;flex-direction:column;gap:5px;cursor:pointer;padding:8px;}
  .menu-btn span{width:24px;height:2px;background:var(--ink);display:block;transition:.25s;}
  .menu-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .menu-btn.open span:nth-child(2){opacity:0;}
  .menu-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
  @media(max-width:1060px){nav.main,.head-phone,.head-cta{display:none;}.menu-btn{display:flex;}}
  @media(max-width:1060px){
    nav.main{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:#fff;border-top:1px solid var(--line);padding:8px 0;max-height:calc(100vh - 114px);overflow:auto;box-shadow:var(--shadow);}
    nav.main.open{display:flex;}
    nav.main > a,.nav-dd > summary{padding:14px 28px;border-bottom:1px solid var(--line);}
    .nav-dd{position:static;border-bottom:1px solid var(--line);}
    .dd-panel{position:static;box-shadow:none;border:0;border-radius:0;min-width:0;background:var(--soft);grid-template-columns:1fr 1fr;gap:0;padding:6px 16px 14px;animation:none;}
    .dd-panel.dd-mega{grid-template-columns:1fr;}
  }

  /* Hero */
  .hero{position:relative;background:linear-gradient(180deg,#fff 0%,var(--soft) 100%);overflow:hidden;}
  .hero .wrap{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;padding:74px 28px 80px;}
  .hero h1{font-size:clamp(2.5rem,5vw,4.1rem);font-weight:900;}
  .hero h1 em{font-style:normal;color:var(--red);}
  .hero .lead{color:var(--muted);font-size:1.16rem;margin-top:22px;max-width:520px;}
  .hero-cta{display:flex;gap:12px;margin-top:30px;flex-wrap:nowrap;}
  @media(max-width:520px){.hero-cta .btn,.vt .cta .btn{flex:1 1 0;padding-left:14px;padding-right:14px;font-size:.9rem;}}
  .hero-trust{margin-top:26px;display:flex;gap:22px;flex-wrap:wrap;align-items:center;}
  .hero-trust .t{display:flex;align-items:center;gap:9px;font-size:.9rem;font-weight:600;color:var(--slate);}
  .hero-trust .t b{font-weight:800;color:var(--ink);}
  .hero-trust .star{color:var(--red);}
  .hero-visual{position:relative;}
  .hero-visual .ph{position:relative;border-radius:22px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3.4;}
  .hero-visual .ph img{width:100%;height:100%;object-fit:cover;transition:transform 8s ease;}
  .hero-visual:hover .ph img{transform:scale(1.06);}
  .float-badge{position:absolute;left:14px;bottom:14px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:13px 16px;display:flex;align-items:center;gap:12px;}
  .float-badge .ic{width:42px;height:42px;border-radius:11px;background:var(--red);color:#fff;display:grid;place-items:center;}
  .float-badge b{display:block;font-size:1.15rem;font-weight:900;line-height:1;}
  .float-badge span{font-size:.78rem;color:var(--muted);font-weight:600;}
  .float-badge.top{left:auto;right:14px;bottom:auto;top:14px;}
  @media(max-width:920px){.hero .wrap{grid-template-columns:1fr;gap:36px;padding-top:54px;}.hero-visual{order:-1;}}
  @media(max-width:600px){
    .hero h1{font-size:2rem;line-height:1.1;}
    .hero .kicker{font-size:.62rem;letter-spacing:.06em;}
    .hero .lead{font-size:1.02rem;}
    .float-badge{padding:8px 11px;border-radius:11px;gap:8px;left:10px;bottom:10px;}
    .float-badge.top{right:10px;left:auto;top:10px;bottom:auto;}
    .float-badge .ic{width:32px;height:32px;border-radius:9px;}
    .float-badge b{font-size:.92rem;}
    .float-badge span{font-size:.66rem;}
  }

  /* ===== HERO A PANTALLA COMPLETA (imagen de lado a lado + menú/texto encima) ===== */
  .hero-cover{position:relative;display:flex;align-items:center;min-height:90vh;overflow:hidden;color:#fff;background:var(--graphite);}
  .hero-cover .cover-img{position:absolute;inset:0;z-index:0;}
  .hero-cover .cover-img img{width:100%;height:100%;object-fit:cover;}
  .hero-cover::after{content:"";position:absolute;inset:0;z-index:1;
    background:linear-gradient(180deg,rgba(13,15,18,.74) 0%,rgba(13,15,18,.32) 12%,rgba(13,15,18,0) 24%),
               linear-gradient(90deg,rgba(17,19,22,.9) 0%,rgba(17,19,22,.66) 40%,rgba(17,19,22,.3) 74%,rgba(17,19,22,.12) 100%),
               linear-gradient(0deg,rgba(17,19,22,.6) 0%,rgba(17,19,22,0) 42%);}
  .hero-cover .wrap{position:relative;z-index:2;padding-top:152px;padding-bottom:124px;width:100%;}
  .hero-cover .cover-text{max-width:660px;}
  .hero-cover .kicker{color:#fff;}
  .hero-cover .kicker::before{background:var(--red-bright);}
  .hero-cover h1{font-size:clamp(2.7rem,5.2vw,4.5rem);font-weight:900;text-shadow:0 2px 26px rgba(0,0,0,.45);}
  .hero-cover h1 em{font-style:normal;color:var(--red-bright);}
  .hero-cover .lead{color:rgba(255,255,255,.93);font-size:1.18rem;margin-top:22px;max-width:560px;text-shadow:0 1px 14px rgba(0,0,0,.5);}
  .hero-cover .hero-cta{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap;}
  .hero-cover .btn-ghost{background:rgba(255,255,255,.96);border-color:transparent;color:var(--ink);}
  .hero-cover .btn-ghost:hover{background:#fff;border-color:transparent;}
  /* insignias como chips en el flujo del texto (alineadas, nunca cortadas) */
  .hero-cover .hero-chips{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap;}
  .hero-cover .hero-chips .float-badge{position:static;left:auto;right:auto;top:auto;bottom:auto;padding:10px 16px;border-radius:13px;}
  .hero-cover .hero-chips .float-badge .ic{width:38px;height:38px;}
  /* En tablet y móvil (≤1060): el hero NO va a pantalla completa.
     Vuelve a imagen full-width arriba + texto debajo sobre blanco,
     y el menú deja de ser transparente (logo y enlaces oscuros). */
  @media(max-width:1060px){
    .hero-cover{display:flex;flex-direction:column;align-items:stretch;min-height:0;color:var(--ink);background:#fff;overflow:visible;}
    .hero-cover::after{display:none;}
    .hero-cover .cover-img{position:relative;inset:auto;width:100%;height:auto;aspect-ratio:16/10;}
    .hero-cover .cover-img img{height:100%;}
    .hero-cover .wrap{padding-top:30px;padding-bottom:30px;text-align:center;}
    .hero-cover .cover-text{max-width:680px;margin:0 auto;}
    .hero-cover .kicker{justify-content:center;color:var(--red);}
    .hero-cover .kicker::before{background:var(--red);}
    .hero-cover h1{color:var(--ink);text-shadow:none;font-size:clamp(2.1rem,6.4vw,3rem);}
    .hero-cover h1 em{color:var(--red);}
    .hero-cover .lead{color:var(--muted);text-shadow:none;margin:18px auto 0;}
    .hero-cover .hero-cta{justify-content:center;}
    .hero-cover .btn-ghost{background:#fff;border-color:var(--line);color:var(--ink);}
    .hero-cover .hero-chips{justify-content:center;}

    /* menú sólido en móvil/tablet (arregla enlaces invisibles) */
    header.site.over{position:sticky;background:rgba(255,255,255,.92);backdrop-filter:saturate(1.6) blur(8px);border-bottom-color:var(--line);box-shadow:none;}
    header.site.over .brand img{filter:none;}
    header.site.over .menu-btn span{background:var(--ink);}
    header.site.over nav.main > a,header.site.over .nav-dd > summary{color:var(--slate);}
    header.site.over nav.main > a::after{background:var(--red);}
    header.site.over .nav-dd > summary::after{color:var(--red);}
    header.site.over .head-phone{color:var(--ink);}
    header.site.over .head-phone svg{color:var(--red);}
    header.site.over .head-hours{color:var(--muted);}
  }
  @media(max-width:560px){
    .hero-cover .hero-cta{flex-direction:column;align-items:stretch;gap:10px;}
    .hero-cover .hero-cta .btn{width:100%;}
  }

  /* ===== ESCRITORIO: cabecera de DOS filas (logo · horario centrado · teléfono / menú seguido) ===== */
  @media(min-width:1061px){
    header.site .wrap{position:relative;flex-wrap:wrap;height:auto;min-height:0;padding-top:12px;padding-bottom:0;align-items:center;row-gap:0;}
    header.site .brand{order:1;}
    /* deshacemos el grupo derecho para colocar cada elemento en su sitio */
    header.site .head-right{display:contents;}
    header.site .head-cta{display:none;}                 /* fuera el botón "Pedir presupuesto" */
    header.site .head-phone{order:2;margin-left:auto;}   /* teléfono a la derecha */
    header.site .head-hours{position:absolute;left:50%;top:12px;transform:translateX(-50%);height:38px;display:flex;flex-direction:column;justify-content:center;text-align:center;} /* horario centrado en el eje */
    header.site nav.main{order:3;flex-basis:100%;width:100%;justify-content:center;gap:30px;margin-top:8px;border-top:1px solid var(--line);padding:9px 0 5px;}
  }

  /* ===== HEADER TRANSPARENTE SOBRE EL HERO — SOLO ESCRITORIO (>1060px) ===== */
  @media(min-width:1061px){
    /* Franja superior translúcida: el menú se ve como una barra y el logo/horario/enlaces
       quedan siempre legibles, esté la foto clara u oscura debajo. */
    header.site.over{position:fixed;top:0;left:0;right:0;background:linear-gradient(180deg,rgba(11,13,16,.62) 0%,rgba(11,13,16,.32) 62%,rgba(11,13,16,0) 100%);backdrop-filter:blur(2px);border-bottom-color:transparent;}
    header.site.over .wrap{gap:24px;}
    header.site.over nav.main{flex-wrap:nowrap;border-top-color:rgba(255,255,255,.22);}
    header.site.over nav.main > a,header.site.over .nav-dd > summary{white-space:nowrap;text-shadow:0 1px 6px rgba(0,0,0,.45);}
    header.site.over .brand img{filter:brightness(0) invert(1) drop-shadow(0 1px 4px rgba(0,0,0,.5));}
    header.site.over nav.main > a,header.site.over .nav-dd > summary{color:rgba(255,255,255,.94);}
    header.site.over nav.main > a:hover,header.site.over .nav-dd[open] > summary,header.site.over .nav-dd > summary:hover{color:#fff;}
    header.site.over nav.main > a::after{background:#fff;}
    header.site.over .nav-dd > summary::after{color:#fff;}
    header.site.over .head-hours{color:rgba(255,255,255,.9);text-shadow:0 1px 6px rgba(0,0,0,.5);}
    header.site.over .head-phone{color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.5);}
    header.site.over .head-phone svg{color:#fff;}
    header.site.over .menu-btn span{background:#fff;}
    /* al hacer scroll vuelve sólida y con texto oscuro */
    header.site.over.scrolled{background:rgba(255,255,255,.95);backdrop-filter:saturate(1.6) blur(8px);border-bottom-color:var(--line);box-shadow:0 12px 30px -22px rgba(29,33,37,.5);}
    header.site.over.scrolled .brand img{filter:none;}
    header.site.over.scrolled nav.main > a,header.site.over.scrolled .nav-dd > summary{color:var(--slate);}
    header.site.over.scrolled nav.main > a:hover,header.site.over.scrolled .nav-dd[open] > summary,header.site.over.scrolled .nav-dd > summary:hover{color:var(--ink);}
    header.site.over.scrolled nav.main > a::after{background:var(--red);}
    header.site.over.scrolled .nav-dd > summary::after{color:var(--red);}
    header.site.over.scrolled .head-hours{color:var(--muted);}
    header.site.over.scrolled .head-phone{color:var(--ink);}
    header.site.over.scrolled .head-phone svg{color:var(--red);}
    header.site.over.scrolled .menu-btn span{background:var(--ink);}
  }

  /* Marquee */
  .ticker{background:var(--graphite);color:#fff;overflow:hidden;white-space:nowrap;}
  .ticker-in{display:inline-flex;animation:scroll 32s linear infinite;}
  .ticker:hover .ticker-in{animation-play-state:paused;}
  .ticker-in span{font-weight:700;font-size:.92rem;text-transform:uppercase;letter-spacing:.04em;padding:13px 0;}
  .ticker-in i{font-style:normal;margin:0 22px;color:var(--red-bright);}
  @keyframes scroll{to{transform:translateX(-50%);}}

  /* value props */
  .props{padding:64px 0 10px;}
  .props-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
  .prop{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px 22px;transition:.25s;}
  .prop:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent;}
  .prop .ic{width:46px;height:46px;border-radius:12px;background:var(--red-soft);color:var(--red);display:grid;place-items:center;margin-bottom:16px;}
  .prop h3{font-size:1.06rem;font-weight:800;margin-bottom:8px;}
  .prop p{color:var(--muted);font-size:.93rem;}
  @media(max-width:880px){.props-grid{grid-template-columns:1fr 1fr;}}
  @media(max-width:520px){.props-grid{grid-template-columns:1fr;}}

  /* stats */
  .stats{margin:64px 0;}
  .stats-grid{display:grid;grid-template-columns:repeat(4,1fr);background:linear-gradient(120deg,var(--red),var(--red-dark));border-radius:20px;overflow:hidden;color:#fff;text-align:center;box-shadow:0 30px 60px -34px rgba(201,25,46,.6);}
  .stat{padding:38px 20px;border-right:1px solid rgba(255,255,255,.16);}
  .stat:last-child{border-right:0;}
  .stat b{display:block;font-size:clamp(2rem,4vw,2.9rem);font-weight:900;line-height:1;}
  .stat span{display:block;margin-top:8px;color:rgba(255,255,255,.85);font-size:.9rem;font-weight:600;}
  @media(max-width:820px){.stats-grid{grid-template-columns:1fr 1fr;}.stat:nth-child(2){border-right:0;}.stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid rgba(255,255,255,.16);}}

  /* section */
  section.block{padding:80px 0;}
  .sec-head{text-align:center;max-width:680px;margin:0 auto 48px;}
  .sec-head h2{font-size:clamp(1.9rem,3.4vw,2.7rem);font-weight:900;margin-top:14px;}
  .sec-head p{color:var(--muted);font-size:1.1rem;margin-top:14px;}
  .center-kicker{display:flex;justify-content:center;}

  /* services */
  .svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
  .svc{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px;transition:.25s;}
  .svc:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent;}
  .svc .n{display:none;}
  .svc h3{font-size:1.25rem;font-weight:800;margin:8px 0 10px;}
  .svc p{color:var(--muted);font-size:.95rem;}
  .svc .go{margin-top:16px;font-weight:700;font-size:.9rem;color:var(--red);display:inline-flex;gap:7px;}
  .svc:hover .go{gap:11px;}
  @media(max-width:880px){.svc-grid{grid-template-columns:1fr 1fr;}}
  @media(max-width:560px){.svc-grid{grid-template-columns:1fr;}}

  /* pests */
  .pest-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
  .pest{background:var(--soft);border:1px solid var(--line);border-radius:14px;padding:20px;transition:.25s;}
  .pest:hover{background:var(--graphite);transform:translateY(-5px);}
  .pest h3{font-size:1.05rem;font-weight:800;}
  .pest p{color:var(--muted);font-size:.86rem;margin-top:6px;}
  .pest:hover h3{color:#fff;}.pest:hover p{color:#aeb4bb;}
  @media(max-width:900px){.pest-grid{grid-template-columns:1fr 1fr;}}

  /* viviendas turísticas (destacado) */
  .vt{background:var(--graphite);color:#fff;}
  .vt .wrap{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;}
  .vt .ph{border-radius:20px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3;}
  .vt .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s;}
  .vt .ph:hover img{transform:scale(1.05);}
  .vt h2{font-size:clamp(1.8rem,3.2vw,2.6rem);font-weight:900;margin:14px 0 16px;}
  .vt .lead{color:#b9c0c8;font-size:1.08rem;}
  .vt ul{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:13px;}
  .vt li{display:flex;gap:12px;align-items:flex-start;color:#e4e7ea;font-weight:500;}
  .vt li::before{content:"";width:22px;height:22px;flex:0 0 auto;margin-top:1px;border-radius:6px;background:var(--red);clip-path:polygon(43% 73%,17% 47%,8% 56%,43% 91%,93% 28%,84% 21%);}
  .vt .cta{margin-top:28px;display:flex;gap:12px;flex-wrap:nowrap;}
  @media(max-width:880px){.vt .wrap{grid-template-columns:1fr;gap:32px;}.vt .ph{order:-1;}}

  /* method */
  .method{background:var(--soft);}
  .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:s;}
  .step{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;position:relative;transition:.25s;}
  .step:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
  .step .num{width:46px;height:46px;border-radius:50%;background:var(--red);color:#fff;font-weight:900;font-size:1.1rem;display:grid;place-items:center;margin-bottom:16px;}
  .step h3{font-size:1.1rem;font-weight:800;margin-bottom:8px;}
  .step p{color:var(--muted);font-size:.92rem;}
  @media(max-width:900px){.steps{grid-template-columns:1fr 1fr;}}
  @media(max-width:520px){.steps{grid-template-columns:1fr;}}

  /* guarantee */
  .guarantee .wrap{display:grid;grid-template-columns:.95fr 1.05fr;gap:48px;align-items:center;}
  .gdoc{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:30px;}
  .gdoc h4{font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;color:var(--red);margin-bottom:18px;}
  .gdoc ul{list-style:none;padding:0;margin:0;display:grid;gap:13px;}
  .gdoc li{display:flex;gap:12px;align-items:flex-start;font-weight:500;color:var(--slate);}
  .gdoc li::before{content:"";width:20px;height:20px;flex:0 0 auto;margin-top:2px;border-radius:6px;background:var(--red);clip-path:polygon(43% 73%,17% 47%,8% 56%,43% 91%,93% 28%,84% 21%);}
  .guarantee h2{font-size:clamp(1.8rem,3.2vw,2.5rem);font-weight:900;}
  .guarantee .lead{color:var(--muted);font-size:1.08rem;margin-top:16px;}
  @media(max-width:860px){.guarantee .wrap{grid-template-columns:1fr;gap:30px;}}

  /* cities */
  .city-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
  .city{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff;transition:.25s;}
  .city:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
  .city .ph{aspect-ratio:5/4;overflow:hidden;}
  .city .ph img{width:100%;height:100%;object-fit:cover;transition:transform .5s;}
  .city:hover .ph img{transform:scale(1.06);}
  .city .b{padding:20px;}
  .city h3{font-size:1.15rem;font-weight:800;}
  .city p{color:var(--muted);font-size:.88rem;margin-top:6px;}
  .city .go{margin-top:12px;color:var(--red);font-weight:700;font-size:.86rem;}
  @media(max-width:900px){.city-grid{grid-template-columns:1fr 1fr;}}

  /* reviews */
  .reviews{background:var(--graphite);color:#fff;}
  .reviews .wrap{display:grid;grid-template-columns:.7fr 1.3fr;gap:48px;align-items:center;}
  .rscore .big{font-size:4.6rem;font-weight:900;line-height:.9;}
  .rscore .stars{color:var(--red-bright);font-size:1.3rem;letter-spacing:2px;margin:8px 0;}
  .rscore p{color:#aeb4bb;font-size:.95rem;}
  .rstage{position:relative;min-height:170px;}
  .rslide{position:absolute;inset:0;opacity:0;transform:translateY(12px);transition:.5s;pointer-events:none;}
  .rslide.on{opacity:1;transform:none;position:relative;pointer-events:auto;}
  .rslide blockquote{font-size:clamp(1.2rem,2.2vw,1.7rem);font-weight:600;line-height:1.4;margin:0;}
  .rslide .by{margin-top:18px;color:#aeb4bb;font-weight:600;}
  .rnav{display:flex;gap:10px;margin-top:22px;align-items:center;}
  .rnav button{width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.4);background:transparent;color:#fff;font-size:1.2rem;cursor:pointer;transition:.15s;}
  .rnav button:hover{background:#fff;color:var(--graphite);}
  .rdots{display:inline-flex;gap:7px;margin-left:6px;}
  .rdots i{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;}
  .rdots i.on{background:var(--red-bright);transform:scale(1.3);}
  @media(max-width:760px){.reviews .wrap{grid-template-columns:1fr;gap:26px;}}

  /* faq */
  .faq .wrap{max-width:840px;}
  .faq-item{border:1px solid var(--line);border-radius:12px;margin-bottom:12px;overflow:hidden;background:#fff;transition:.2s;}
  .faq-item.open{box-shadow:var(--shadow);}
  .faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;font-family:inherit;padding:20px 22px;display:flex;justify-content:space-between;gap:16px;align-items:center;font-weight:700;font-size:1.04rem;color:var(--ink);}
  .faq-q .pl{position:relative;width:18px;height:18px;flex:0 0 auto;}
  .faq-q .pl::before,.faq-q .pl::after{content:"";position:absolute;background:var(--red);transition:.25s;}
  .faq-q .pl::before{top:8px;left:0;width:18px;height:2px;}
  .faq-q .pl::after{top:0;left:8px;width:2px;height:18px;}
  .faq-item.open .pl::after{transform:rotate(90deg);opacity:0;}
  .faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;}
  .faq-a p{color:var(--muted);padding:0 22px 20px;}

  /* contact */
  .contact{background:var(--soft);}
  .contact .wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
  .contact h2{font-size:clamp(1.9rem,3.2vw,2.6rem);font-weight:900;}
  .contact .lead{color:var(--muted);font-size:1.08rem;margin-top:16px;}
  .clist{list-style:none;padding:0;margin:26px 0 0;display:grid;gap:12px;}
  .clist li{display:flex;gap:12px;align-items:center;font-weight:500;color:var(--slate);}
  .clist li::before{content:"";width:20px;height:20px;flex:0 0 auto;border-radius:6px;background:var(--red);clip-path:polygon(43% 73%,17% 47%,8% 56%,43% 91%,93% 28%,84% 21%);}
  .phone-card{margin-top:26px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 20px;display:flex;align-items:center;gap:16px;}
  .phone-card .ic{width:48px;height:48px;border-radius:12px;background:var(--red);color:#fff;display:grid;place-items:center;}
  .phone-card small{display:block;color:var(--muted);font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;}
  .phone-card b{font-size:1.4rem;font-weight:900;}
  form.quote{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:30px;}
  form.quote h3{font-size:1.3rem;font-weight:800;margin-bottom:4px;}
  form.quote .sub{color:var(--muted);font-size:.92rem;margin-bottom:20px;}
  .quote .req{color:var(--red);font-weight:800;}
  form.quote label{display:block;font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--slate);margin-bottom:6px;}
  form.quote .field{margin-bottom:14px;}
  form.quote .two{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
  form.quote input:not([type="checkbox"]),form.quote select,form.quote textarea{width:100%;border:1.5px solid var(--bone);border-radius:10px;padding:13px 14px;font-family:inherit;font-size:.95rem;background:var(--soft);color:var(--ink);}
  form.quote input:focus,form.quote select:focus,form.quote textarea:focus{outline:none;border-color:var(--red);background:#fff;}
  form.quote button{width:100%;margin-top:6px;}
  .consent{font-size:.76rem;color:var(--muted);margin:12px 0 14px;display:flex;gap:8px;align-items:flex-start;line-height:1.45;}
  .consent input[type="checkbox"]{width:auto;flex:0 0 auto;margin:2px 0 0;accent-color:var(--red);}
  @media(max-width:860px){.contact .wrap{grid-template-columns:1fr;gap:32px;}form.quote .two{grid-template-columns:1fr;}}

  /* footer */
  footer.site{background:var(--graphite);color:#9aa1aa;padding:64px 0 110px;}
  .foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;}
  .foot-brand img{height:34px;margin-bottom:16px;}
  .foot-brand p{font-size:.92rem;max-width:300px;}
  .foot-brand .reg{margin-top:14px;font-size:.8rem;color:#727983;}
  .foot-col h4{color:#fff;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px;}
  .foot-col a{display:block;color:#9aa1aa;font-size:.92rem;padding:5px 0;transition:.15s;}
  .foot-col a:hover{color:#fff;padding-left:4px;}
  .foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:42px;padding-top:22px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.84rem;color:#727983;}
  @media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr;}}
  @media(max-width:480px){.foot-grid{grid-template-columns:1fr;}}

  /* Google reviews (estilo proyecto) */
  .greviews{background:var(--soft);border-top:1px solid var(--line);}
  .greviews .wrap{max-width:840px;text-align:center;}
  .gword{font-size:clamp(2.2rem,5vw,3rem);font-weight:800;letter-spacing:-.02em;margin:8px 0 6px;}
  .g-b{color:#4285F4;}.g-r{color:#EA4335;}.g-y{color:#FBBC05;}.g-g{color:#34A853;}
  .grating{font-size:1.05rem;font-weight:700;color:var(--ink);}
  .grating .st{color:#FBBC05;letter-spacing:2px;margin-right:6px;}
  .greviews .btn{margin-top:16px;}
  .greviews .rstage{position:relative;min-height:150px;margin-top:28px;}
  .greviews .rslide blockquote{color:var(--ink);font-size:clamp(1.1rem,2vw,1.5rem);font-weight:600;line-height:1.45;margin:0;}
  .greviews .rslide .by{color:var(--muted);margin-top:14px;font-weight:600;}
  .greviews .rnav{justify-content:center;}
  .greviews .rnav button{border-color:var(--line);color:var(--ink);}
  .greviews .rnav button:hover{background:var(--ink);color:#fff;}
  .greviews .rdots i{background:rgba(0,0,0,.18);}
  .greviews .rdots i.on{background:var(--red-bright);}

  /* floating + mobile bar */
  .wa{position:fixed;right:20px;bottom:20px;z-index:65;width:54px;height:54px;border-radius:50%;background:#25d366;display:grid;place-items:center;box-shadow:0 14px 30px -8px rgba(37,211,102,.6);transition:.2s;}
  .wa:hover{transform:scale(1.08);}.wa svg{width:28px;height:28px;fill:#fff;}
  .totop{position:fixed;left:20px;bottom:20px;z-index:64;width:44px;height:44px;border-radius:50%;background:var(--graphite);color:#fff;display:grid;place-items:center;border:0;cursor:pointer;opacity:0;pointer-events:none;transition:.3s;}
  .totop.show{opacity:1;pointer-events:auto;}.totop:hover{background:var(--red);}
  .mbar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:66;background:#fff;border-top:1px solid var(--line);box-shadow:0 -10px 30px -18px rgba(0,0,0,.3);}
  .mbar a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:9px 4px;color:var(--ink);font-size:.7rem;font-weight:700;}
  .mbar a svg{width:22px;height:22px;}
  .mbar a.m-wa svg{color:#25d366;}
  .mbar a.m-call svg{color:var(--ink);}
  .mbar a.m-quote svg{color:var(--red);}
  @media(max-width:680px){.mbar{display:flex;}footer.site{padding-bottom:88px;}.wa{bottom:78px;}.totop{display:none;}}

/* ===================== VARIANTE: TODO AL EJE CENTRAL ===================== */
.hero .wrap{grid-template-columns:1fr;text-align:center;max-width:980px;}
/* Evita el "blowout" de la rejilla: la imagen del hero no debe imponer su ancho
   intrínseco (1600px) como ancho mínimo de la columna en móvil. */
.hero .wrap{min-width:0;}
.hero .wrap > *{min-width:0;}
.hero-visual,.hero-visual .ph,.hero-visual .ph img{min-width:0;max-width:100%;}
.hero-visual{order:-1;max-width:640px;width:100%;margin:0 auto 18px;}
.hero .kicker{justify-content:center;}
.hero .lead{margin-left:auto;margin-right:auto;}
.hero-cta{justify-content:center;}
.hero-trust{justify-content:center;}
.vt .wrap{grid-template-columns:1fr;text-align:center;max-width:860px;margin:0 auto;}
.vt .kicker{justify-content:center;}
.vt .lead{margin-left:auto;margin-right:auto;}
.vt ul{max-width:560px;margin:24px auto 0;}
.vt li{justify-content:center;}
.vt .cta{justify-content:center;}
.vt .ph{order:-1;max-width:680px;margin:0 auto 8px;}
.guarantee .wrap{grid-template-columns:1fr;text-align:center;max-width:800px;margin:0 auto;}
.guarantee .kicker{justify-content:center;}
.guarantee .lead{margin-left:auto;margin-right:auto;}
.guarantee .gdoc{max-width:560px;margin:8px auto 0;}
.guarantee .gdoc li{justify-content:center;}
.contact .wrap{grid-template-columns:1fr;text-align:center;max-width:760px;}
.contact .kicker{justify-content:center;}
.contact .lead{margin-left:auto;margin-right:auto;}
.contact .clist{max-width:520px;margin:26px auto 0;}
.contact .clist li{justify-content:center;}
.contact .phone-card{max-width:440px;margin:26px auto 0;justify-content:center;}
.contact form.quote{text-align:center;}
.contact form.quote label{text-align:left;}
.contact form.quote .consent{text-align:left;justify-content:center;}
.prop,.svc,.pest,.step{text-align:center;}
.prop .ic,.step .num{margin-left:auto;margin-right:auto;}
.svc .go{justify-content:center;}
.city .b{text-align:center;}
.city .go{display:inline-block;}
.foot-grid{text-align:center;}
.foot-brand img{margin-left:auto;margin-right:auto;}
.foot-brand p{margin-left:auto;margin-right:auto;}
.foot-col a:hover{padding-left:0;}
.foot-bottom{justify-content:center;text-align:center;}
@media(max-width:680px){
  .hero h1,.hero .lead,.vt h2,.vt .lead,.guarantee h2,.guarantee .lead,.contact h2,.contact .lead{text-align:center;}
}

/* Pastillas de zonas (páginas locales) */
.pills{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;max-width:760px;margin:24px auto 0;}
.pills span{background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 14px;font-size:.85rem;font-weight:600;color:var(--slate);transition:.15s;}
.pills span:hover{border-color:var(--red);color:var(--red);transform:translateY(-2px);}

/* Reparación del corte: evitar desbordamiento horizontal SIN cambiar el modelo.
   La causa era el "kicker" (texto en mayúsculas con espaciado) que no partía y
   ensanchaba la página. Los recuadros del hero siguen sobre la imagen, como antes. */
html,body{overflow-x:clip;max-width:100%;}
.kicker{flex-wrap:wrap;max-width:100%;}
.hero .kicker,.center-kicker .kicker{justify-content:center;}
/* botones siempre en una línea: se encogen, no se apilan */
.hero-cta,.vt .cta{flex-wrap:nowrap;}
@media(max-width:680px){.hero-cta .btn,.vt .cta .btn{flex:1 1 0;min-width:0;padding-left:12px;padding-right:12px;}}

/* Banner ilustrado de las guías de plagas */
.guide-hero{background:radial-gradient(120% 130% at 50% 0%,var(--red-soft) 0%,transparent 52%),linear-gradient(180deg,#fff 0%,var(--soft) 100%);text-align:center;padding:60px 0 52px;}
.guide-hero .wrap{max-width:780px;}
.guide-illu{width:156px;height:156px;margin:0 auto 22px;border-radius:50%;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);display:grid;place-items:center;color:var(--ink);position:relative;}
.guide-illu::after{content:"";position:absolute;inset:-7px;border-radius:50%;border:2px solid var(--red);opacity:.18;}
.guide-illu svg{width:96px;height:96px;}
.guide-hero h1{font-size:clamp(2.1rem,4.4vw,3.2rem);font-weight:900;margin-top:10px;}
.guide-hero .lead{color:var(--muted);font-size:1.14rem;margin-top:16px;margin-left:auto;margin-right:auto;}
@media(max-width:520px){.guide-illu{width:128px;height:128px;}.guide-illu svg{width:78px;height:78px;}}

/* Banda con imagen difuminada (estilo hero del proyecto inicial) */
.blur-band{position:relative;min-height:360px;overflow:hidden;display:grid;place-items:center;text-align:center;color:#fff;}
.blur-band > img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:blur(5px) brightness(.62);transform:scale(1.08);}
.blur-band .ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(29,33,37,.35),rgba(29,33,37,.62));}
.blur-band .content{position:relative;z-index:2;max-width:660px;padding:50px 28px;}
.blur-band h2{font-size:clamp(1.7rem,3.4vw,2.5rem);font-weight:900;}
.blur-band p{margin-top:14px;color:rgba(255,255,255,.88);font-size:1.1rem;}
.blur-band .btn{margin-top:24px;}

/* Ajuste: imagen difuminada más visible (no tan oscura) */
.blur-band > img{filter:blur(3px) brightness(.9);transform:scale(1.06);}
.blur-band .ov{background:linear-gradient(180deg,rgba(29,33,37,.22),rgba(29,33,37,.48));}
.blur-band .content h2,.blur-band .content p{text-shadow:0 2px 14px rgba(0,0,0,.55);}

/* Hero con foto MUY difuminada (estilo agua) + texto encima — como la home del proyecto inicial */
.photo-hero{position:relative;overflow:hidden;min-height:clamp(360px,52vh,520px);display:grid;place-items:center;text-align:center;color:#fff;}
.photo-hero .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:blur(14px) brightness(.85) saturate(1.1);transform:scale(1.18);}
.photo-hero .hero-bg-ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(29,33,37,.34) 0%,rgba(29,33,37,.55) 100%);}
.photo-hero .wrap{position:relative;z-index:2;max-width:780px;padding:74px 28px;}
.photo-hero .kicker{color:#fff;justify-content:center;}
.photo-hero .kicker::before{background:#fff;}
.photo-hero h1{color:#fff;font-size:clamp(2.3rem,4.8vw,3.6rem);font-weight:900;text-shadow:0 2px 18px rgba(0,0,0,.45);}
.photo-hero .lead{color:rgba(255,255,255,.92);font-size:1.16rem;margin:16px auto 0;max-width:640px;text-shadow:0 2px 14px rgba(0,0,0,.5);}

/* Hero foto: imagen visible (apenas difuminada) y velo más tenue */
.photo-hero .hero-bg{filter:blur(1px) brightness(.96);transform:scale(1.04);}
.photo-hero .hero-bg-ov{background:linear-gradient(180deg,rgba(29,33,37,.18) 0%,rgba(29,33,37,.4) 100%);}

/* Hero foto v2: tarjeta redondeada, bordes difuminados (vignette) y tono más bajo */
.photo-hero{padding:30px 22px 8px;min-height:0;display:block;text-align:initial;color:inherit;background:transparent;}
.photo-hero-inner{position:relative;max-width:1180px;margin:0 auto;border-radius:30px;overflow:hidden;min-height:clamp(340px,48vh,480px);display:grid;place-items:center;text-align:center;color:#fff;box-shadow:inset 0 0 90px 38px rgba(29,33,37,.55), var(--shadow);}
.photo-hero-inner .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:blur(1px) brightness(.84);transform:scale(1.05);}
.photo-hero-inner .hero-bg-ov{position:absolute;inset:0;background:radial-gradient(135% 125% at 50% 38%, rgba(29,33,37,.16) 0%, rgba(29,33,37,.42) 58%, rgba(29,33,37,.66) 100%);}
.ph-content{position:relative;z-index:2;max-width:720px;padding:58px 30px;}
.ph-content .kicker{color:#fff;justify-content:center;}
.ph-content .kicker::before{background:#fff;}
.ph-content h1{color:#fff;font-size:clamp(2.2rem,4.6vw,3.4rem);font-weight:900;text-shadow:0 2px 18px rgba(0,0,0,.5);}
.ph-content .lead{color:rgba(255,255,255,.92);font-size:1.14rem;margin:16px auto 0;max-width:620px;text-shadow:0 2px 14px rgba(0,0,0,.55);}
@media(max-width:600px){.photo-hero{padding:18px 14px 4px;}.photo-hero-inner{border-radius:22px;box-shadow:inset 0 0 60px 24px rgba(29,33,37,.55), var(--shadow);}}

/* Hero foto FINAL: idéntico al proyecto inicial (imagen nítida + velo claro lateral, texto oscuro a la izquierda) */
.photo-hero{position:relative;overflow:hidden;min-height:clamp(420px,56vh,560px);padding:0;display:block;background:transparent;text-align:left;color:var(--ink);margin:18px clamp(12px,3vw,30px) 0;border-radius:28px;box-shadow:var(--shadow);}
.photo-hero > .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:none;transform:none;}
.photo-hero > .hero-bg-ov{position:absolute;inset:0;background:linear-gradient(90deg, rgba(247,248,249,.96) 0%, rgba(247,248,249,.86) 43%, rgba(201,25,46,.12) 100%);box-shadow:none;}
.photo-hero .ph-content{position:relative;z-index:1;max-width:760px;margin:0 auto;padding:clamp(78px,12vh,120px) 28px 70px;color:var(--ink);text-align:center;}
.photo-hero .ph-content .kicker{color:var(--red);justify-content:center;}
.photo-hero .ph-content .kicker::before{background:var(--red);}
.photo-hero .ph-content h1{color:var(--ink);font-size:clamp(2.4rem,5.4vw,3.8rem);font-weight:900;text-shadow:none;}
.photo-hero .ph-content .lead{color:var(--muted);font-size:1.16rem;margin:18px auto 0;max-width:580px;text-shadow:none;}
@media(max-width:520px){.photo-hero{min-height:380px;border-radius:20px;margin:12px 12px 0;}}

/* Hero foto: letras con más tono/contraste para leerse mejor sobre la imagen */
.photo-hero .ph-content h1{color:var(--ink);text-shadow:0 1px 3px rgba(255,255,255,.6);}
.photo-hero .ph-content .lead{color:var(--slate);text-shadow:0 1px 3px rgba(255,255,255,.65);}
.photo-hero > .hero-bg-ov{background:linear-gradient(90deg, rgba(247,248,249,.97) 0%, rgba(247,248,249,.9) 48%, rgba(201,25,46,.14) 100%);}

/* Hero foto: máxima legibilidad del texto (velo casi blanco bajo el texto + letras más oscuras) */
.photo-hero > .hero-bg-ov{background:linear-gradient(90deg, rgba(245,247,249,1) 0%, rgba(245,247,249,.98) 52%, rgba(245,247,249,.62) 75%, rgba(201,25,46,.14) 100%);}
.photo-hero .ph-content h1{color:#0d0f11;text-shadow:0 1px 2px rgba(255,255,255,.9);}
.photo-hero .ph-content .lead{color:#1a1d21;font-weight:500;text-shadow:0 1px 2px rgba(255,255,255,.9);}
.photo-hero .ph-content .kicker{color:var(--red-dark);}

/* Hero con imagen ILUSTRADA (SVG): el propio panel ya es claro-izq/oscuro-dcha, así que el velo es muy suave */
.photo-hero.is-illus > .hero-bg{filter:none;}
.photo-hero.is-illus > .hero-bg-ov{background:linear-gradient(90deg, rgba(243,245,247,.45) 0%, rgba(243,245,247,0) 40%, transparent 100%);}

/* Leer más / Leer menos (texto recortado expandible) */
/* Tarjeta redondeada para diferenciar cada sección de contenido */
.readmore{background:var(--paper);border:1px solid var(--line);border-radius:22px;padding:30px clamp(22px,3.4vw,40px) 26px;box-shadow:0 14px 34px -22px rgba(29,33,37,.34);}
@media(max-width:600px){.readmore{border-radius:18px;padding:22px 20px 20px;}}
.readmore p{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;line-clamp:3;overflow:hidden;margin:0;transition:none;}
.readmore.open p{-webkit-line-clamp:unset;line-clamp:unset;overflow:visible;}
.readmore-btn{margin-top:12px;background:none;border:0;color:var(--red);font-weight:800;font-family:inherit;font-size:.95rem;cursor:pointer;letter-spacing:.01em;}
.readmore-btn::after{content:" ↓";display:inline-block;transition:transform .2s;}
.readmore.open .readmore-btn::after{content:" ↑";}
.readmore-btn:hover{color:var(--red-dark);}
.readmore.multi p{display:block;-webkit-line-clamp:unset;line-clamp:unset;overflow:visible;}
.readmore.multi p:not(:first-of-type){display:none;}
.readmore.multi p:first-of-type{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;line-clamp:3;overflow:hidden;}
.readmore.multi.open p{display:block;overflow:visible;}
.readmore.multi.open p:first-of-type{-webkit-line-clamp:unset;line-clamp:unset;}

/* Banner de aceptación de cookies */
.cookie-bar{position:fixed;left:0;right:0;bottom:0;z-index:90;background:var(--paper);border-top:1px solid var(--line);box-shadow:0 -16px 38px -24px rgba(29,33,37,.5);padding:16px clamp(14px,3vw,28px);}
.cookie-bar[hidden]{display:none;}
.cookie-in{max-width:1120px;margin:0 auto;display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:space-between;}
.cookie-in p{margin:0;font-size:.9rem;line-height:1.55;color:var(--slate);flex:1 1 360px;}
.cookie-in p a{color:var(--red);font-weight:700;}
.cookie-btns{display:flex;gap:10px;flex-shrink:0;}
.cookie-btns .btn{padding:9px 20px;font-size:.9rem;}
@media(max-width:680px){.cookie-bar{bottom:60px;}.cookie-in{justify-content:stretch;}.cookie-btns{width:100%;}.cookie-btns .btn{flex:1;}}

/* Titular animado (palabra rotatoria) */
.rotator{display:inline-block;color:var(--red);transition:opacity .35s ease, transform .35s ease;}
.rotator.swap{opacity:0;transform:translateY(8px);}

/* Selector visual de plagas */
.picker{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-top:8px;}
.ppick{position:relative;display:block;aspect-ratio:1/1;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--bone);transform-style:preserve-3d;will-change:transform;transition:transform .15s ease, box-shadow .22s, border-color .22s;}
.ppick-img{position:absolute;inset:0;}
.ppick-img img{width:100%;height:100%;object-fit:cover;object-position:62% center;transition:transform .35s ease;}
.ppick-n{position:absolute;left:0;right:0;bottom:0;z-index:4;padding:20px 10px 11px;color:#fff;font-weight:800;font-size:.9rem;text-align:center;line-height:1.15;background:linear-gradient(to top, rgba(13,15,17,.85) 0%, rgba(13,15,17,.5) 55%, rgba(13,15,17,0) 100%);text-shadow:0 1px 4px rgba(0,0,0,.6);}
.ppick::after{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(circle at var(--mx,50%) var(--my,0%), rgba(255,255,255,.55), rgba(255,255,255,0) 45%);opacity:0;transition:opacity .25s;pointer-events:none;z-index:3;}
.ppick:hover::after{opacity:1;}
.ppick:hover, .ppick:active, .ppick:focus{border-color:#fff;box-shadow:0 0 0 3px #fff, 0 20px 42px -18px rgba(0,0,0,.55);}
.ppick:hover .ppick-img img{transform:scale(1.08);}
@media(max-width:560px){.picker{grid-template-columns:repeat(3,1fr);gap:8px;}.ppick-n{font-size:.8rem;padding:16px 6px 9px;}}
/* Selector con pocas tarjetas: centrado respecto al eje central (no pegado a la izquierda) */
.picker.picker-center{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;}
.picker.picker-center .ppick{flex:0 0 180px;width:180px;}
@media(max-width:560px){.picker.picker-center{gap:10px;}.picker.picker-center .ppick{flex:0 0 44%;width:auto;}}
/* Tarjetas de enlaces internos: centradas aunque haya pocas */
.linkcards{display:flex;flex-wrap:wrap;justify-content:center;gap:18px;}
.linkcards .svc{flex:1 1 300px;max-width:360px;}
/* Tilt 3D en tarjetas */
.svc, .city, .prop, .pest, .step, .stmt, .gdoc, .readmore, .faq-item, .phone-card{transform-style:preserve-3d;will-change:transform;transition:transform .15s ease, box-shadow .25s, border-color .22s;}
/* Toda la tarjeta clicable (para que el 3D no dificulte pulsar el enlace) */
.svc, .city{position:relative;}
.svc .go::after, .city .go::after{content:"";position:absolute;inset:0;z-index:6;border-radius:inherit;}
.svc:hover, .city:hover, .prop:hover, .pest:hover,
.svc:active, .city:active, .prop:active, .pest:active{border-color:var(--red) !important;box-shadow:0 0 0 2px var(--red), 0 22px 44px -20px rgba(201,25,46,.5) !important;}

/* Barra CTA flotante (escritorio) */
.dock{position:fixed;left:50%;bottom:22px;transform:translateX(-50%) translateY(160%);z-index:70;display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:60px;padding:10px 12px 10px 26px;box-shadow:0 24px 55px -22px rgba(29,33,37,.5);transition:transform .4s cubic-bezier(.2,.8,.2,1);}
.dock.show{transform:translateX(-50%) translateY(0);}
.dock-txt{font-weight:800;font-size:.92rem;color:var(--ink);white-space:nowrap;}
.dock .btn{padding:9px 18px;font-size:.9rem;}
@media(max-width:1060px){.dock{display:none;}}

/* Animaciones del hero */
@keyframes heroBreathe{0%,100%{transform:scale(1);opacity:.6;}50%{transform:scale(1.2);opacity:1;}}
@keyframes heroKen{0%,100%{transform:scale(1.02);}50%{transform:scale(1.09);}}

/* Sección STATEMENT de cifras */
.statement{background:var(--graphite);color:#fff;padding:clamp(60px,9vh,108px) 0;}
.statement .wrap{max-width:1100px;}
.stmt-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center;}
.stmt b{display:block;font-size:clamp(2.8rem,7vw,5rem);font-weight:900;line-height:1;letter-spacing:-.02em;color:#fff;}
.stmt-bar{display:block;width:42px;height:4px;border-radius:4px;background:var(--red);margin:16px auto 12px;transform-origin:center;transition:width .5s ease;}
.stmt:hover .stmt-bar{width:72px;}
.stmt span{display:block;color:#aeb4bb;font-weight:600;font-size:.96rem;letter-spacing:.02em;}
@media(max-width:820px){.stmt-grid{grid-template-columns:1fr 1fr;gap:44px 20px;}}

/* Respeto a quien prefiere menos movimiento */
@media(prefers-reduced-motion:reduce){.hero::after,.hero-visual .ph img{animation:none;}}
