/* ============================================================
   Agua Caliente PR — Estilo "Sol moderno"
   Tipografía grotesca (Sora) + Inter · botones píldora · tarjetas
   redondeadas · motivos de sol y agua. Paleta sol+agua (MARCA.md).
   PARA RE-MARCAR: cambia el bloque :root (colores + fuentes).
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@500;600;700;800&family=Inter:wght@400;500;600&display=swap');

:root{
  --bg:#FBF6EE; --bg2:#F6EDDF; --ink:#1E1A16; --soft:#5A5048;
  --line:#ECE0CF; --teal:#0C3B3C; --teal-deep:#0A2E2E;
  --red:#E2502B; --red-deep:#C0381A; --gold:#E6A33C;
  --sans:'Inter',system-ui,-apple-system,sans-serif;
  --head:'Sora',system-ui,sans-serif;
  --max:1140px; --r:20px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.7;font-size:1.04rem}
img,svg{max-width:100%}
img{display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--max);margin:0 auto;padding:0 26px}

/* Accesibilidad */
:focus-visible{outline:3px solid var(--red);outline-offset:3px;border-radius:4px}
.skip-link{position:absolute;left:-999px;top:0;z-index:200;background:var(--ink);color:#fff;padding:12px 20px;font-family:var(--head);font-size:.85rem;border-radius:0 0 10px 0}
.skip-link:focus{left:0;top:0}

/* Reveal */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}

/* Header */
header{position:sticky;top:0;z-index:50;background:rgba(251,246,238,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;max-width:var(--max);margin:0 auto;padding:16px 26px}
.nav-logo{display:flex;align-items:center;gap:11px;font-family:var(--head);font-weight:800;font-size:1.18rem;letter-spacing:-.3px;color:var(--ink)}
.nav-logo img{height:38px;width:auto}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none}
.nav-links a{font-family:var(--head);font-weight:600;font-size:.92rem;color:var(--soft);transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--red)}
.lang-btn{background:transparent;border:2px solid var(--line);border-radius:999px;font-family:var(--head);font-weight:700;font-size:.78rem;padding:7px 15px;cursor:pointer;color:var(--ink);transition:.2s}
.lang-btn:hover{border-color:var(--ink)}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--ink);line-height:0;padding:6px}

/* Botones */
.btn{display:inline-flex;align-items:center;gap:8px;border-radius:999px;font-family:var(--head);font-weight:700;font-size:.95rem;padding:14px 28px;cursor:pointer;transition:.25s;border:2px solid transparent}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-deep)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn-light:hover{background:#fff;color:var(--teal-deep)}
.btn-block{width:100%;justify-content:center}

/* Hero (home) */
.hero{position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(1200px 600px at 80% -10%, rgba(230,163,60,.40), transparent 60%),
  radial-gradient(900px 500px at 92% 0%, rgba(226,80,43,.20), transparent 55%);z-index:0}
.hero-wrap{position:relative;z-index:1;max-width:var(--max);margin:0 auto;padding:72px 26px 84px;display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.tag{display:inline-flex;align-items:center;gap:9px;font-family:var(--head);font-weight:700;font-size:.82rem;letter-spacing:.4px;color:var(--red-deep);background:rgba(226,80,43,.1);padding:7px 15px;border-radius:999px;margin-bottom:22px}
.tag .dot{width:9px;height:9px;border-radius:50%;background:var(--red)}
.hero h1{font-family:var(--head);font-weight:800;font-size:clamp(2.5rem,5.2vw,4rem);line-height:1.04;letter-spacing:-1.4px}
.hero .sub{font-size:1.18rem;color:var(--soft);margin:22px 0 30px;max-width:520px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-art{position:relative;border-radius:28px;overflow:hidden;box-shadow:0 30px 70px rgba(30,26,22,.18);border:6px solid #fff}
.hero-art img{width:100%;height:clamp(320px,46vh,480px);object-fit:cover}
.sun{position:absolute;top:-26px;left:-26px;width:120px;height:120px;z-index:2}

/* Wave divider */
.wave{display:block;width:100%;height:60px}
.wave path{fill:var(--bg2)}

/* Page hero (interiores) */
.page-hero{position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(900px 460px at 88% -20%, rgba(230,163,60,.34), transparent 60%);z-index:0}
.page-hero .container{position:relative;z-index:1;padding-top:78px;padding-bottom:64px}
.page-hero h1{font-family:var(--head);font-weight:800;font-size:clamp(2.3rem,5vw,3.6rem);line-height:1.06;letter-spacing:-1.2px;margin-bottom:18px}
.page-hero p{color:var(--soft);font-size:1.14rem;max-width:660px}

/* Secciones */
section{padding:92px 0}
.eyebrow{font-family:var(--head);font-weight:700;font-size:.82rem;letter-spacing:1px;text-transform:uppercase;color:var(--red);margin-bottom:14px}
h2.display{font-family:var(--head);font-weight:800;font-size:clamp(2rem,4vw,3rem);line-height:1.1;letter-spacing:-.8px;margin-bottom:18px}
.lede{color:var(--soft);font-size:1.12rem;max-width:680px}
.bg2{background:var(--bg2)}
.divider{border:none;border-top:1px solid var(--line);max-width:var(--max);margin:0 auto}

/* Feature */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.feature-img{border-radius:var(--r);height:100%;max-height:460px;width:100%;object-fit:cover;box-shadow:0 22px 50px rgba(30,26,22,.12)}
.check-list{list-style:none}
.check-list li{position:relative;padding-left:34px;margin-bottom:13px;color:var(--soft);font-weight:500}
.check-list li::before{content:"";position:absolute;left:0;top:8px;width:18px;height:18px;border-radius:50%;background:var(--gold);box-shadow:inset 0 0 0 4px var(--red)}
.check-list li strong{color:var(--ink);font-weight:700}

/* Tarjetas */
.grid{display:grid;gap:26px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:0 14px 40px rgba(30,26,22,.08);transition:.3s;padding:34px 30px}
.card:hover{transform:translateY(-6px);box-shadow:0 26px 56px rgba(30,26,22,.14)}
.card.has-photo{padding:0}
.card-photo{width:100%;aspect-ratio:4/3;object-fit:cover}
.card-body{padding:26px 26px 30px}
.card h3{font-family:var(--head);font-weight:700;font-size:1.3rem;margin-bottom:8px;letter-spacing:-.3px}
.card p{color:var(--soft);font-size:.98rem}
.card .pad{padding:34px 30px}

/* Filas numeradas (servicios / valores) */
.service-row{display:grid;grid-template-columns:88px 1fr;gap:26px;padding:46px 0;border-top:1px solid var(--line)}
.service-row:last-of-type{border-bottom:1px solid var(--line)}
.service-row .num{font-family:var(--head);font-weight:800;font-size:2.2rem;line-height:1;color:var(--red);letter-spacing:-1px}
.service-row h3{font-family:var(--head);font-weight:700;font-size:1.5rem;margin-bottom:10px;letter-spacing:-.4px}
.service-row p{color:var(--soft);max-width:680px}
.service-row .check-list{margin-top:16px}

/* Stats */
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:48px}
.stat{background:#fff;border-radius:var(--r);padding:38px 26px;text-align:center;box-shadow:0 14px 40px rgba(30,26,22,.07)}
.stat .num{font-family:var(--head);font-weight:800;font-size:clamp(2.6rem,5vw,3.6rem);line-height:1;color:var(--red);letter-spacing:-1px}
.stat .label{font-family:var(--head);font-weight:700;font-size:.82rem;letter-spacing:.5px;text-transform:uppercase;color:var(--soft);margin-top:12px}

/* CTA oscuro */
.dark-band{background:linear-gradient(135deg,var(--teal),var(--teal-deep));color:#fff;text-align:center;padding:90px 26px;position:relative;overflow:hidden}
.dark-band::after{content:"";position:absolute;top:-60px;right:-40px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(230,163,60,.5),transparent 65%)}
.dark-band>*{position:relative;z-index:1}
.dark-band h2{font-family:var(--head);font-weight:800;font-size:clamp(1.9rem,4vw,2.9rem);letter-spacing:-.6px;margin-bottom:16px}
.dark-band p{color:rgba(255,255,255,.86);max-width:560px;margin:0 auto 30px}
.dark-band .tel{display:inline-block;margin-top:20px;color:var(--gold);font-family:var(--head);font-weight:700}

/* Contacto */
.form-grid{display:grid;gap:20px}
.form-grid label{font-family:var(--head);font-size:.78rem;letter-spacing:.5px;text-transform:uppercase;font-weight:700;display:block;margin-bottom:8px;color:var(--soft)}
.form-grid input,.form-grid select,.form-grid textarea{width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:12px;background:#fff;color:var(--ink);font-size:1rem;font-family:var(--sans)}
.form-grid input:focus,.form-grid select:focus,.form-grid textarea:focus{outline:none;border-color:var(--red)}
.contact-info .item{margin-bottom:30px}
.contact-info .label{font-family:var(--head);font-size:.78rem;letter-spacing:.5px;text-transform:uppercase;font-weight:700;color:var(--soft);margin-bottom:6px}
.contact-info .val{font-family:var(--head);font-weight:700;font-size:1.25rem;color:var(--ink)}
.contact-info .val a{border-bottom:2px solid var(--gold);transition:.2s}
.contact-info .val a:hover{color:var(--red)}

/* Footer */
footer{border-top:1px solid var(--line);padding:54px 26px;text-align:center}
footer .foot-logo{display:flex;align-items:center;justify-content:center;gap:10px;font-family:var(--head);font-weight:800;font-size:1.1rem;margin-bottom:16px;color:var(--ink)}
footer .foot-logo img{height:32px;width:auto}
footer .foot-links{display:flex;justify-content:center;gap:24px;list-style:none;flex-wrap:wrap;margin-bottom:18px}
footer .foot-links a{font-family:var(--head);font-weight:600;font-size:.9rem;color:var(--soft)}
footer .foot-links a:hover{color:var(--red)}
footer .copy{font-size:.85rem;color:var(--soft)}

/* Responsive */
@media(max-width:880px){
  .hero-wrap,.feature,.grid-3,.grid-2,.stats-grid{grid-template-columns:1fr;gap:30px}
  .service-row{grid-template-columns:1fr;gap:8px;padding:34px 0}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--bg);padding:22px 26px;border-bottom:1px solid var(--line);gap:18px}
  .nav-links.open{display:flex}
  .menu-toggle{display:block}
  section{padding:64px 0}
  .page-hero .container{padding-top:54px;padding-bottom:44px}
}

/* Botones flotantes (WhatsApp + Llamar) */
.float-cta{position:fixed;right:18px;bottom:18px;z-index:80;display:flex;flex-direction:column;gap:12px}
.float-cta a{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 26px rgba(30,26,22,.28);transition:transform .2s ease,box-shadow .2s ease}
.float-cta a:hover{transform:translateY(-3px);box-shadow:0 16px 32px rgba(30,26,22,.34)}
.float-cta .wa{background:#25D366}
.float-cta .call{background:var(--red)}
.float-cta svg{width:28px;height:28px;fill:#fff}
@media(max-width:600px){.float-cta{right:14px;bottom:14px}.float-cta a{width:52px;height:52px}.float-cta svg{width:26px;height:26px}}
@media print{.float-cta{display:none}}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
