/* =======================================================================
   Qhawana — Estilos base (responsive + accesibles)
   ======================================================================= */

/* ===== Variables de tema ===== */
:root{
  --green-900:#0b2d23;
  --green-800:#124234;
  --green-700:#164e3b; /* principal */
  --green-600:#1c5f49;
  --green-300:#bfe0d5;
  --cream-50:#f7fbf9;
  --gray-900:#111827;
  --gray-700:#374151;
  --gray-500:#6b7280;
  --gray-200:#e5e7eb;
  --white:#fff;

  --radius:18px;
  --shadow-lg:0 20px 40px rgba(0,0,0,.12);
  --shadow-md:0 10px 24px rgba(0,0,0,.10);

  --container: 1200px;
  --gutter: clamp(16px, 3vw, 24px);
  --section-y: clamp(40px, 6vw, 72px);

  /* Altura navbar para offset de anclas */
  --nav-h: 72px;
}

/* ===== Reset ===== */
*,*::before,*::after{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: "Inter", sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
  color:var(--gray-900);
  background:var(--cream-50);
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit}

/* ===== Helpers ===== */
.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:var(--section-y)}
.head{margin-top:30px}

/* Scroll suave + offset para anclas */
html{scroll-behavior:smooth}
section[id],[id].section{scroll-margin-top:calc(var(--nav-h) + 8px)}

/* =======================================================================
   NAVBAR (sticky + compacto + animación subir/bajar)
   ======================================================================= */
.navbar{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.7);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(0,0,0,.06);
  transform:translateY(0);
  transition:transform .28s ease, box-shadow .2s ease, background-color .2s ease;
}
.navbar.scrolled{background:var(--white);box-shadow:0 4px 20px rgba(0,0,0,.08)}
.navbar.hide{transform:translateY(-100%)}

.nav-wrap{
  max-width:var(--container);margin-inline:auto;
  padding:14px var(--gutter);
  display:flex;align-items:center;gap:16px;
  transition:padding .2s ease;
}
.navbar.scrolled .nav-wrap{padding-block:10px}

.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.2px}
.brand .logo{width:36px;height:36px;border-radius:10px;background:var(--green-700);display:grid;place-items:center;color:#fff;font-weight:900}
.spacer{flex:1}

.nav{display:flex;align-items:center;gap:14px}
.nav a{padding:10px 12px;border-radius:10px;color:var(--gray-700)}
.nav a[aria-current="true"],.nav a:hover{background:rgba(22,78,59,.09);color:var(--green-800)}

.cta{padding:10px 14px;border-radius:10px;background:var(--green-700);color:#fff;font-weight:600}
.cta:hover{background:var(--green-800)}
.menu-btn{display:none}

@media (max-width:900px){
  .menu-btn{
    display:inline-flex;align-items:center;justify-content:center;
    width:40px;height:40px;border-radius:12px;border:1px solid var(--gray-200)
  }
  .nav{
    position:fixed;inset:auto 0 0 0;transform:translateY(100%);
    background:#fff;box-shadow:0 -20px 40px rgba(0,0,0,.12);
    padding:18px;gap:8px;flex-direction:column;transition:transform .25s ease
  }
  .nav.open{transform:translateY(0)}
  .nav .cta{width:100%;text-align:center}
}

/* =======================================================================
   HERO
   ======================================================================= */
.hero{position:relative;min-height:64vh;display:grid;place-items:center;color:#fff}
.hero-media{position:absolute;inset:0;overflow:hidden;}
.hero-media img{width:100%;height:100%;object-fit:cover;filter:contrast(1.02) saturate(1.02)}
/* overlay via pseudo (no necesitas un div extra) */
.hero-media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.35) 0%,rgba(0,0,0,.35) 40%,rgba(0,0,0,.45) 100%);
}
.hero-inner{position:relative;max-width:var(--container);padding:clamp(48px,7vw,80px) var(--gutter);text-align:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.14);backdrop-filter:blur(4px);font-size:.92rem}
.hero h1{font-size:clamp(32px,5vw,58px);line-height:1.05;margin:12px 0 8px;font-weight:700}
.hero p{font-size:clamp(16px,2.2vw,20px);opacity:.95;margin:0 0 18px}
.badges{display:flex;flex-wrap:wrap;justify-content:center;gap:16px;margin:26px 0}
.badge{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:999px;background:rgba(255,255,255,.12);backdrop-filter:blur(4px);font-weight:300}
.actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.btn{padding:12px 16px;border-radius:12px;font-weight:300;border:1px solid rgba(255,255,255,.28)}
.btn.primary{background:#fff;color:var(--green-800);border-color:#fff}
.btn.ghost{background:transparent;color:#fff}

/* =======================================================================
   FEATURES
   ======================================================================= */
.section{padding:60px var(--gutter)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.card{background:#eef2f1;border:0;border-radius:var(--radius);box-shadow:0 14px 30px rgba(0,0,0,.14);padding:28px}
.card h3{margin:14px 0 10px;color:var(--green-900)}
.card p{color:var(--gray-700);margin:0 0 16px;line-height:1.6}
.link{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--green-700)}
.link::after{content:"→";transition:transform .2s ease}
.link:hover::after{transform:translateX(2px);}
.link:hover{
  text-decoration: underline;
  color: var(--green-600);
}
.iconbox{display:inline-grid;place-items:center;width:56px;height:56px;border-radius:14px;background:var(--green-700);color:#fff;box-shadow:inset 0 0 0 2px rgba(255,255,255,.28)}
.iconbox svg{width:28px;height:28px}
@media (max-width:960px){.cards{grid-template-columns:1fr}}

/* =======================================================================
   TIPOS DE CASA (cards + slider sin JS)
   ======================================================================= */
.tiposcasa{background:rgba(237,245,239,1)}
/* contenedor para repartir 4 cards de forma fluida */
.container-slide{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
  gap: clamp(14px, 3vw, 24px);
  margin-top: 18px;
}

.home-card{
  background:#fff;border-radius:22px;box-shadow:var(--shadow-lg);
  overflow:hidden;border:1px solid rgba(0,0,0,.06);display:flex;flex-direction:column
}
.home-card .content{padding:18px 18px 20px}
.home-card h3{margin:0 0 8px;color:var(--green-900)}
.specs{font-size:10px;display:flex;gap:18px;flex-wrap:wrap;color:var(--green-800);padding:0;margin:0 0 12px;list-style:none}
.home-card hr{border:none;border-top:1px solid var(--gray-200);margin:12px 0 16px}
.btn.solid{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:15px;background:var(--green-700);color:#fff;font-weight:300;width:100%}
.btn.solid:hover{background:var(--green-800)}

/* Slider sin JS (radios + labels) */
.slider{position:relative;height:clamp(200px,28vw,260px);background:#eaf3ee}
.slider input{position:absolute;opacity:0;pointer-events:none}
.slides{position:absolute;inset:0;margin:0;padding:0;list-style:none}
.slides li{position:absolute;inset:0;opacity:0;transition:opacity .35s ease}
.slides img{width:100%;height:100%;object-fit:cover}
/* activos */
.slider input:nth-of-type(1):checked ~ .slides li:nth-child(1){opacity:1}
.slider input:nth-of-type(2):checked ~ .slides li:nth-child(2){opacity:1}
.slider input:nth-of-type(3):checked ~ .slides li:nth-child(3){opacity:1}
.slider input:nth-of-type(4):checked ~ .slides li:nth-child(4){opacity:1}
/* dots */
.dots{position:absolute;left:50%;bottom:10px;transform:translateX(-50%);display:flex;gap:8px;z-index:2}
.dots label{width:8px;height:8px;border-radius:999px;background:rgba(255,255,255,.85);box-shadow:0 1px 3px rgba(0,0,0,.25);cursor:pointer;display:block}
.slider input:nth-of-type(1):checked ~ .dots label:nth-child(1),
.slider input:nth-of-type(2):checked ~ .dots label:nth-child(2),
.slider input:nth-of-type(3):checked ~ .dots label:nth-child(3),
.slider input:nth-of-type(4):checked ~ .dots label:nth-child(4){width:10px;height:10px;background:#fff}

/* =======================================================================
   “Cómo llegar”
   ======================================================================= */
.howto-grid{
  display:grid;grid-template-columns:1.1fr .9fr;
  gap: clamp(16px, 3.2vw, 28px);align-items:start
}
@media (max-width:992px){.howto-grid{grid-template-columns:1fr}}

.map-card{
  background:#fff;border-radius:18px;border:1px solid rgba(0,0,0,.08);
  box-shadow:0 14px 30px rgba(0,0,0,.10);
  overflow:hidden;min-height:280px;display:grid;place-items:center;
  padding: clamp(12px, 2.4vw, 18px);
}
.map-embed{width:100%;aspect-ratio:16/9;border-radius:14px;overflow:hidden}
.map-embed iframe{width:100%;height:100%;border:0}

.arrival-list{margin:16px 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:16px}
.arrival-list li{display:flex;gap:12px;align-items:flex-start}
.arrival-list .i{width:36px;height:36px;border-radius:10px;background:var(--green-700);display:grid;place-items:center;color:#fff;flex:0 0 36px}
.arrival-list .i svg{width:18px;height:18px;fill:#fff}
.arrival-list .t strong{display:block;color:var(--green-900);margin-bottom:2px}
.arrival-list .t p{color:var(--gray-700);margin:0}

.why-card{
  background:var(--green-800);color:#eaf3ee;border-radius:18px;
  padding: clamp(16px, 3.2vw, 22px);
  border:1px solid rgba(255,255,255,.08);box-shadow:0 18px 34px rgba(0,0,0,.14)
}
.why-card h3{margin:0 0 12px;color:#fff}
.why-item{padding:12px 0;border-bottom:1px solid rgba(255,255,255,.12)}
.why-item:last-child{border-bottom:0}
.why-item h4{margin:0 0 6px;color:#fff}
.why-item p{margin:0;color:#e7fbf2;opacity:.95;font-size: 12px;}
/* ===== CTA animada: lift + shine + border glow ===== */
.why-cta{
  position: relative;
  isolation: isolate;          /* evita que los pseudo se mezclen con otros */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;

  margin-top: 18px;
  padding: 12px 16px;
  border-radius: 12px;

  background: #fff;
  color: var(--green-700);
  font-weight: 800;
  border: 1px solid rgba(22,78,59,.12);

  box-shadow: 0 8px 20px rgba(0,0,0,.06);
  transform: translateY(0);
  transition:
    transform .18s ease,
    box-shadow .18s ease,
    color .18s ease,
    background-color .18s ease,
    border-color .18s ease;
  overflow: hidden;            /* recorta el brillo interno */
  cursor: pointer;
}

/* Borde glow (pseudo-borde con máscara) */
.why-cta::before{
  content: "";
  position: absolute;
  inset: 0;
  padding: 1px;                 /* grosor del “borde” */
  border-radius: inherit;
  background: linear-gradient(120deg, #bfe0d5, #1c5f49 40%, #bfe0d5 80%);
  -webkit-mask: 
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  opacity: 0;
  transform: scale(.98);
  transition: opacity .25s ease, transform .25s ease;
  z-index: -1;                 /* queda detrás del botón */
}

/* Brillo barrido */
.why-cta::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    120deg,
    transparent 0%,
    rgba(255,255,255,.6) 45%,
    transparent 60%
  );
  transform: translateX(-120%);
  pointer-events: none;
}

/* Hover: levanta, resalta borde y lanza shine */
.why-cta:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 30px rgba(0,0,0,.12);
  border-color: rgba(22,78,59,.2);
}
.why-cta:hover::before{
  opacity: 1;
  transform: scale(1);
}
.why-cta:hover::after{
  animation: whyShine .8s ease forwards;
}

/* Activo: pequeño “press” */
.why-cta:active{
  transform: translateY(-1px) scale(.99);
}

/* Accesible en teclado */
.why-cta:focus-visible{
  outline: none;
  box-shadow:
    0 0 0 4px rgba(22,78,59,.18),
    0 10px 26px rgba(0,0,0,.14);
}

/* Si dentro pones un ícono/chevron, lo empuja un poco */
.why-cta svg, .why-cta .chev{
  margin-left: .4rem;
  transition: transform .22s ease;
}
.why-cta:hover svg, .why-cta:hover .chev{
  transform: translateX(3px);
}

/* Animación del brillo */
@keyframes whyShine{
  to { transform: translateX(140%); }
}

/* Respeta reduce-motion */
@media (prefers-reduced-motion: reduce){
  .why-cta,
  .why-cta::before,
  .why-cta::after,
  .why-cta svg,
  .why-cta .chev{
    transition: none !important;
    animation: none !important;
  }
}


/* =======================================================================
   ACORDEÓN (apertura suave)
   ======================================================================= */
.q-accordion .q-acc{
  background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:14px;
  box-shadow:0 14px 28px rgba(0,0,0,.10);overflow:hidden;margin-bottom:14px
}
.q-accordion .q-acc > summary{
  list-style:none;display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:14px 16px;background:var(--green-700);color:#fff;font-weight:800;cursor:pointer
}
.q-accordion .q-acc > summary::-webkit-details-marker{display:none}
.q-accordion .q-acc > summary .chev{width:18px;height:18px;fill:none;stroke:#fff;stroke-width:2.4;transition:transform .25s ease}
.q-accordion .q-acc[open] > summary .chev{transform:rotate(180deg)}

/* grid-trick para suavizar */
.q-accordion .q-acc-body{
  display:grid;grid-template-rows:0fr;transition:grid-template-rows .32s ease;padding:0
}
.q-accordion .q-acc[open] .q-acc-body{grid-template-rows:1fr}

.q-accordion .q-acc-content{
  overflow:hidden;padding:14px 16px 16px;opacity:.96;transform:translateY(-2px);
  transition:opacity .28s ease, transform .28s ease;contain:layout
}
.q-accordion .q-acc[open] .q-acc-content{opacity:1;transform:translateY(0)}

/* ==== Imagen recortada dentro del acordeón ==== */
.q-acc-media{
  position: relative;
  width: -webkit-fill-available;
  /* Marco recortador */
  overflow: hidden;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 8px 18px rgba(0,0,0,.10);

  /* Tamaño controlado */
  aspect-ratio: 16 / 9;                         /* proporción fija */
  max-height: clamp(200px, 40vh, 420px);        /* no crecer demasiado */
  margin-top: 10px;
}

.q-acc-media > img{
  width: 100%;
  height: 100%;               /* clave para que el cover funcione */
  object-fit: cover;          /* recorta sin deformar */
  object-position: center;    /* ajusta el encuadre */
  display: block;
}
.q-acc[open] .q-acc-media img{opacity:1}

@media (prefers-reduced-motion:reduce){
  .q-accordion .q-acc-body,
  .q-accordion .q-acc-content,
  .q-accordion .q-acc > summary .chev,
  .q-acc-media img{transition:none !important}
}

/* =======================================================================
   TESTIMONIOS
   ======================================================================= */
#testimonios{background:rgba(237,245,239,1);padding-block:40px}
.tst-head{text-align:center;margin-bottom:16px}
.tst-wrap{position:relative;max-width:720px;margin:18px auto 8px}
.tst-view{overflow:hidden;position:relative;z-index:1}
.tst-track{display:grid;grid-auto-flow:column;grid-auto-columns:100%;transition:transform .35s ease;will-change:transform;padding:0;margin:0;list-style:none}
.tst-slide{padding:8px;display:flex;justify-content:center}
.tst-card{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:18px;box-shadow:0 16px 32px rgba(0,0,0,.10);max-width:560px;width:100%;text-align:center;padding:22px}
.tst-avatar{width:66px;height:66px;border-radius:999px;margin:0 auto 8px;display:grid;place-items:center;border:2px solid #bfe0d5;color:#164e3b;background:#f3faf6}
.tst-avatar svg{width:36px;height:36px;fill:none;stroke:currentColor;stroke-width:1.8}
.tst-name{margin:6px 0 2px;color:#164e3b;font-size:1.05rem}
.tst-date{color:#6b7280;font-size:.92rem;margin-bottom:8px}
.tst-text{color:#374151;margin:0;line-height:1.6}
.tst-btn{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:999px;background:#fff;border:1px solid #e5e7eb;box-shadow:0 6px 16px rgba(0,0,0,.12);display:grid;place-items:center;cursor:pointer;z-index:10;pointer-events:auto}
.tst-btn svg{width:18px;height:18px;fill:none;stroke:#164e3b;stroke-width:2.4}
.tst-prev{left:-44px}.tst-next{right:-44px}
@media (max-width:840px){.tst-prev{left:0}.tst-next{right:0}}
.tst-dots{display:flex;gap:6px;justify-content:center;margin-top:8px}
.tst-dots button{width:6px;height:6px;border-radius:999px;border:0;background:#e5e7eb;cursor:pointer}
.tst-dots button.is-active{width:16px;height:6px;border-radius:999px;background:#164e3b}

/* =======================================================================
   FAQ
   ======================================================================= */
.faq-head{text-align:center;max-width:720px;margin:0 auto 18px;}
.faq-head h2{margin:0 0 6px;font-size:clamp(24px,3.5vw,34px);color:rgba(27, 75, 59, 1);}
.faq-head p{margin:0;color:rgba(27, 75, 59, 1);}
.faq-list{max-width:720px;margin:16px auto 0;display:grid;gap:10px}
.faq-item{border:0;background:#fff;border-radius:14px;box-shadow:0 8px 20px rgba(0,0,0,.08);overflow:hidden}
.faq-item summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px;cursor:pointer;font-weight:600;color:#1c2b27}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item .chev{width:18px;height:18px;flex:0 0 18px;fill:none;stroke:var(--green-700);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .22s ease}
.faq-item[open] .chev{transform:rotate(180deg)}
.faq-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .26s ease}
.faq-item[open] .faq-body{grid-template-rows:1fr}
.faq-content{overflow:hidden}
.faq-content{padding:0 16px 14px;color:var(--gray-700);line-height:1.65}

/* =======================================================================
   GALERÍA
   ======================================================================= */
#galeria{padding-block:40px}
.gallery .container{max-width:1100px}
.gal-head{text-align:center;margin-bottom:18px}
.gal-head h2{margin:0 0 6px;color:var(--green-900)}
.gal-head p{margin:0;color:var(--gray-700)}
.gal-grid{--gap:16px;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--gap);list-style:none;margin:10px 0 0;padding:0}
.gal-item{border-radius:16px;overflow:hidden;background:#000;box-shadow:var(--shadow-md);transition:transform .2s ease,box-shadow .2s ease}
.gal-item:hover{transform:translateY(-2px);box-shadow:0 16px 32px rgba(0,0,0,.14)}
.gal-item figure{position:relative;margin:0;aspect-ratio:4/3}
.gal-item img{width:100%;height:100%;object-fit:cover;transform:scale(1.02);transition:transform .45s ease;will-change:transform}
.gal-item:hover img{transform:scale(1.08)}
.gal-item figure::after{content:"";position:absolute;inset:0;background:radial-gradient(transparent 40%,rgba(0,0,0,.18));opacity:0;transition:opacity .3s ease}
.gal-item:hover figure::after{opacity:1}
.gal-item figcaption{position:absolute;left:0;right:0;bottom:0;padding:10px 12px;color:#fff;font-weight:700;font-size:.95rem;background:linear-gradient(to top,rgba(0,0,0,.55),rgba(0,0,0,0) 65%);opacity:0;transform:translateY(6px);transition:opacity .28s ease,transform .28s ease;pointer-events:none}
.gal-item:hover figcaption{opacity:1;transform:translateY(0)}
/* === verde === */
.gal-item{
  position: relative;
  isolation: isolate;
}

/* suavisado */
.gal-item::before{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(120% 120% at 50% 50%,
              rgba(22,78,59,.25) 0%,
              rgba(22,78,59,.18) 40%,
              rgba(22,78,59,0) 75%);
  opacity:0;
  transform:scale(.96);
  transition: opacity .35s ease, transform .45s ease;
  mix-blend-mode:multiply;
  pointer-events:none;
  z-index:1; 
}

/* anim */
.gal-item:hover::before{
  opacity:1;
  transform:scale(1);
}

/* el splash */
.gal-item::after{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(200px 200px at var(--x,50%) var(--y,50%),
      rgba(22,78,59,.35) 0%,
      rgba(22,78,59,.18) 25%,
      rgba(22,78,59,0) 60%);
  opacity:0;
  transform:scale(.8);
  transition: opacity .35s ease, transform .6s ease;
  mix-blend-mode:multiply;
  pointer-events:none;
  z-index:1;
}
.gal-item:hover::after{
  opacity:.9;
  transform:scale(1.15);
}

/* respeta reduced-motion */
@media (prefers-reduced-motion: reduce){
  .gal-item::before,
  .gal-item::after{
    transition:none !important;
  }
}

/* =======================================================================
   CONTACTO
   ======================================================================= */
.contact-head{text-align:center;margin-bottom:22px}
.contact-head h2{margin:0 0 6px;color:var(--green-900);font-size:clamp(26px,4.4vw,34px)}
.contact-head p{color:var(--gray-700);margin:0}
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap: clamp(16px,3vw,26px);align-items:start;margin-top:10px}
@media (max-width:980px){.contact-grid{grid-template-columns:1fr}}
.contact-card,.benefits-card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:18px;box-shadow:var(--shadow-md);padding: clamp(14px,3vw,18px) clamp(14px,3vw,18px) 16px}
.contact-card .card-title{font-weight:800;color:var(--green-900)}
.contact-card .card-sub{color:var(--gray-700);margin:6px 0 14px}
.field{margin-bottom:12px}
.field label{display:block;font-size:.92rem;color:var(--green-800);margin:0 0 6px}
.field label span{color:#d72f2f}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--gray-200);border-radius:12px;padding:12px 12px;background:#fff;outline:none;transition:border-color .15s ease,box-shadow .15s ease}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--green-600);box-shadow:0 0 0 4px rgba(22,78,59,.10)}
.field small.error{display:block;color:#c62828;min-height:14px;margin-top:4px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:640px){.grid-2{grid-template-columns:1fr}}
.chk{display:flex;align-items:center;gap:10px;margin:8px 0 12px;color:var(--gray-700)}
.chk input{width:18px;height:18px}
.contact-card .btn.solid{margin-top:2px}
.contact-card .btn[disabled]{opacity:.6;cursor:not-allowed}
.contact-card .legal{color:var(--gray-500);font-size:.78rem;text-align:center;margin:10px 0 0}
.form-msg{text-align:center;font-weight:700;margin:8px 0 0}
.benefits-title{font-weight:800;color:var(--white);margin:2px 0 12px}
.benefits-list{  list-style:none;padding:0;margin:0;display:grid;gap:12px}
.benefits-list li{display:grid;grid-template-columns:36px 1fr;gap:12px;align-items:center}
.benefits-list .i{width:36px;height:36px;border-radius:10px;background:var(--green-700);box-shadow:inset 0 0 0 2px rgba(255,255,255,.28);position:relative}
.benefits-list .i::before{content:"";position:absolute;inset:0;margin:auto;width:18px;height:18px;background:#fff;-webkit-mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="%23000" d="m9 16.17l-3.88-3.88L4 13.41L9 18.41L20 7.41L18.59 6l-9.59 9.59Z"/></svg>') center/contain no-repeat;mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="%23000" d="m9 16.17l-3.88-3.88L4 13.41L9 18.41L20 7.41L18.59 6l-9.59 9.59Z"/></svg>') center/contain no-repeat}
.benefits-list .t{color:var(--white);font-size: 13px;font-weight: 200;}
.benefits-list .t strong{color:var(--white)}
.foot-note{margin-top:14px;color:var(--white);font-size:.82rem}
.foot-note .hr{display:block;height:1px;background:var(--gray-200);margin:0 0 10px;border-radius:999px}

/* =======================================================================
   FOOTER
   ======================================================================= */
.footer{
  margin-top: clamp(40px, 6vw, 60px);
  background:var(--green-900);color:#e7f3ef;
  box-shadow:0 -12px 32px rgba(0,0,0,.18) inset;
 
}
.container-footer{
  padding:40px var(--gutter) 18px;
  display:grid;grid-template-columns:1.3fr .9fr .9fr 1.2fr;
  gap: clamp(16px, 3vw, 32px);
}
@media (max-width:1024px){.container-footer{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.container-footer{grid-template-columns:1fr}}

.f-brand img{width: clamp(140px, 22vw, 250px);height:auto;display:block;margin-bottom: clamp(10px, 3vw, 30px);filter:brightness(1.08) saturate(1.02)}
.f-brand p{margin:8px 0 0;color:#cfe6df;line-height:1.5}
.f-strong{color:#fff;font-weight:800}
.f-social{display:flex;gap:10px;margin-top:14px}
.f-social a{width:34px;height:34px;display:grid;place-items:center;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);transition:.2s ease}
.f-social a:hover{background:rgba(255,255,255,.18);transform:translateY(-1px)}
.f-head{font-weight:800;color:#fff;margin:6px 0 10px;letter-spacing:.2px}
.f-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.f-list a{color:#d7ebe6;opacity:.92}
.f-list a:hover{color:#fff}
.f-contact .row{display:flex;align-items:flex-start;gap:10px;margin:8px 0;color:#d7ebe6}
.f-contact .row svg{width:18px;height:18px;flex:0 0 18px;margin-top:3px;opacity:.9}
.f-claim{margin-top:8px;display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:12px;justify-content:center;cursor: pointer;}
.f-claim img{width: clamp(54px, 10vw, 80px);height:auto;border-radius:8px}
.f-claim .mini{font-size:.86rem;color:#cfe6df;line-height:1.35;text-align:center}
.f-bottom{border-top:1px solid rgba(255,255,255,.10);margin-top:18px;padding:12px var(--gutter) 18px;display:flex;align-items:center;justify-content:space-between;gap:12px;color:#cfe6df}
.f-bottom a{color:#fff;font-weight:700}
@media (max-width:640px){.f-bottom{flex-direction:column;text-align:center}}

/* =======================================================================
   Accesibilidad
   ======================================================================= */
@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto !important}}


/*otros*/
.faq-help{
  text-align: center;
}

.hablar:hover{
  background-color: rgba(18, 64, 47, 1);
}
.hablar{
  background-color: rgba(27, 75, 59, 1);
  border: none; 
}

.tarifas{
  background: none;
  background-color: white;
  border: none; 
}

.tarifas:hover{
  background: none;
  background-color: white;
  border: none; 
  color: #000;
}
.faq-help{
      text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.contact-derecha{
  background-color: rgba(27, 75, 59, 1);
  
}
.subrayado:hover{
  text-decoration: underline;
  color: var(--green-600);
}