:root{
  --turquesa:#34b5c6;
  --turquesa-oscuro:#0786aa;
  --azul:#12324b;
  --gris:#666b72;
  --gris-claro:#f3fbfd;
  --blanco:#ffffff;
  --sombra:0 22px 55px rgba(18,50,75,.14);
  --radio:30px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:Arial,Helvetica,sans-serif;background:#fff;color:var(--azul);line-height:1.6;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.container{width:min(1160px,92%);margin:auto}
.header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.95);backdrop-filter:blur(14px);display:flex;align-items:center;justify-content:space-between;padding:12px min(5vw,70px);box-shadow:0 10px 30px rgba(18,50,75,.08)}
.brand{width:165px;background:#fff;border-radius:20px;padding:7px;box-shadow:0 8px 22px rgba(18,50,75,.08)}
.nav{display:flex;align-items:center;gap:8px}
.nav a{padding:10px 15px;border-radius:999px;font-weight:800;color:var(--gris)}
.nav a:hover{background:var(--gris-claro);color:var(--turquesa-oscuro)}
.menu-toggle{display:none;border:0;background:var(--turquesa);color:#fff;border-radius:14px;font-size:26px;padding:6px 12px;cursor:pointer}
.hero{position:relative;width:min(1160px,92%);margin:auto;min-height:calc(100vh - 88px);display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:48px;padding:70px 0 95px}
.hero:before{content:"";position:absolute;right:-16%;top:7%;width:540px;height:540px;border-radius:50%;background:linear-gradient(135deg,rgba(52,181,198,.18),rgba(255,255,255,0));z-index:-1}
.eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(52,181,198,.13);color:var(--turquesa-oscuro);border:1px solid rgba(52,181,198,.24);font-weight:900;letter-spacing:.08em;text-transform:uppercase;font-size:.78rem;border-radius:999px;padding:9px 14px}
.eyebrow.light{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.35);color:#fff}
h1{font-size:clamp(3.2rem,8vw,7rem);line-height:.9;letter-spacing:-.075em;color:var(--turquesa);margin:20px 0 8px}
.slogan{font-size:clamp(1.35rem,3vw,2.3rem);font-weight:800;font-style:italic;color:var(--gris)}
.description{font-size:1.2rem;color:var(--gris);max-width:560px;margin-top:16px}
.hero-buttons{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:13px 24px;border-radius:999px;font-weight:900;transition:.25s ease}
.btn:hover{transform:translateY(-3px)}
.btn.primary{background:linear-gradient(135deg,var(--turquesa),var(--turquesa-oscuro));color:#fff;box-shadow:0 15px 30px rgba(52,181,198,.3)}
.btn.secondary{background:#fff;border:2px solid rgba(52,181,198,.36);color:var(--turquesa-oscuro)}
.btn.white{background:#fff;color:var(--turquesa-oscuro)}
.hero-image-wrap{position:relative}
.hero-image{height:650px;width:100%;object-fit:cover;border:14px solid #fff;border-radius:38px;box-shadow:var(--sombra)}
.hero-card{position:absolute;left:-28px;bottom:32px;width:min(360px,82%);background:#fff;border:1px solid rgba(52,181,198,.16);border-radius:24px;padding:15px;box-shadow:0 18px 45px rgba(18,50,75,.19);text-align:center;font-weight:900;color:var(--gris)}
.quick-info{width:min(1160px,92%);margin:-35px auto 0;position:relative;z-index:5;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.quick-info article{background:#fff;border:1px solid rgba(52,181,198,.16);box-shadow:var(--sombra);border-radius:24px;padding:22px}
.quick-info span{display:block;color:var(--turquesa-oscuro);font-weight:900;text-transform:uppercase;letter-spacing:.07em;font-size:.78rem;margin-bottom:6px}
.quick-info strong{font-size:1.05rem}
.section{padding:95px 0}
.intro,.visual,.contact{background:linear-gradient(180deg,#fff,var(--gris-claro))}
.intro-grid,.visual-grid,.contact-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:55px;align-items:center}
h2{font-size:clamp(2.1rem,4.4vw,4rem);line-height:1.05;letter-spacing:-.055em;margin:16px 0;color:var(--azul)}
.intro-box,.contact-logo,.contact-card{background:#fff;border:1px solid rgba(52,181,198,.16);border-radius:var(--radio);padding:34px;box-shadow:var(--sombra)}
.intro-box img,.contact-logo img{border-radius:22px;margin-bottom:18px}
.intro-box p,.visual p{font-size:1.12rem;color:var(--gris)}
.section-title{text-align:center;max-width:780px;margin:0 auto 46px}
.services{background:#fff}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.service-card{position:relative;min-height:215px;background:#fff;border:1px solid rgba(52,181,198,.16);border-radius:28px;padding:28px;box-shadow:0 14px 36px rgba(18,50,75,.09);overflow:hidden;transition:.25s ease}
.service-card:after{content:"";position:absolute;right:-45px;bottom:-55px;width:155px;height:155px;border-radius:50%;background:rgba(52,181,198,.12)}
.service-card:hover{transform:translateY(-6px);box-shadow:0 22px 48px rgba(18,50,75,.14)}
.service-card span{color:var(--turquesa);font-size:2.2rem;font-weight:900}
.service-card h3{font-size:1.35rem;line-height:1.16;margin-top:24px;position:relative;z-index:2}
.service-card.wide{grid-column:span 2;background:linear-gradient(135deg,#fff,#eaffff)}
.banner{padding:82px 0;background:linear-gradient(135deg,var(--turquesa),var(--turquesa-oscuro));color:#fff;overflow:hidden;position:relative}
.banner:after{content:"";position:absolute;right:-100px;top:-120px;width:380px;height:380px;border-radius:50%;border:36px solid rgba(255,255,255,.18)}
.banner-content{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:center;gap:28px}
.banner h2{color:#fff;font-size:clamp(2.3rem,5vw,4.8rem)}
.banner p{font-size:1.18rem}
.photo-stack{position:relative}
.main-photo{height:620px;width:100%;object-fit:cover;border-radius:38px;box-shadow:var(--sombra)}
.logo-card{position:absolute;right:-24px;bottom:30px;width:64%;background:#fff;border-radius:22px;padding:14px;box-shadow:0 20px 45px rgba(0,0,0,.16)}
.data-list{display:grid;gap:12px;margin-top:24px}
.data-list p{background:#fff;border-left:5px solid var(--turquesa);border-radius:16px;padding:15px 17px;color:var(--gris);box-shadow:0 10px 24px rgba(18,50,75,.07)}
.gallery-section{background:#fff}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.gallery-grid img{height:360px;width:100%;object-fit:cover;border-radius:28px;box-shadow:0 12px 30px rgba(18,50,75,.12);transition:.25s ease}
.gallery-grid img:hover{transform:scale(1.025)}
.contact-card h2{font-size:clamp(2rem,4vw,3.8rem)}
.contact-list{display:grid;gap:14px;margin-top:20px}
.contact-list a,.contact-list p{background:var(--gris-claro);padding:16px 18px;border-radius:17px;color:var(--gris);font-weight:700}
.contact-list strong{color:var(--azul)}
.footer{background:var(--azul);color:#fff;display:flex;justify-content:space-between;gap:15px;flex-wrap:wrap;padding:30px 5%;font-weight:800}
.footer a{text-decoration:underline}
.whatsapp-float{position:fixed;right:22px;bottom:22px;z-index:120;background:#25d366;color:#fff;font-weight:900;border-radius:999px;padding:14px 21px;box-shadow:0 16px 32px rgba(37,211,102,.34)}
@media(max-width:960px){
  .menu-toggle{display:block}.nav{display:none;position:absolute;right:5%;top:78px;flex-direction:column;align-items:stretch;background:#fff;border-radius:22px;padding:12px;box-shadow:var(--sombra)}.nav.open{display:flex}
  .hero,.intro-grid,.visual-grid,.contact-grid{grid-template-columns:1fr}.hero{padding-top:45px}.hero-image{height:520px}.quick-info{grid-template-columns:1fr}.services-grid{grid-template-columns:1fr 1fr}.service-card.wide{grid-column:span 2}.gallery-grid{grid-template-columns:1fr 1fr}.banner-content{align-items:flex-start;flex-direction:column}.main-photo{height:500px}.logo-card{position:relative;width:88%;right:auto;bottom:auto;margin:-55px auto 0}
}
@media(max-width:560px){
  .header{padding:10px 4%}.brand{width:140px}h1{font-size:3.45rem}.hero{min-height:auto;padding-bottom:70px}.hero-image{height:430px}.hero-card{position:relative;left:auto;bottom:auto;width:92%;margin:-46px auto 0}.section{padding:68px 0}.services-grid,.gallery-grid{grid-template-columns:1fr}.service-card.wide{grid-column:auto}.gallery-grid img{height:310px}.hero-buttons .btn{width:100%}.intro-box,.contact-logo,.contact-card{padding:24px}.footer{padding-bottom:88px}.whatsapp-float{left:18px;right:18px;text-align:center}
}
