:root{
  --navy:#071123;
  --blue:#075f9e;
  --blue2:#0b6fab;
  --gold:#d8ae55;
  --gold2:#efc86e;
  --text:#071123;
  --muted:#526071;
  --light:#f3f7fb;
  --white:#fff;
  --radius:22px;
  --shadow:0 18px 50px rgba(6,20,43,.14);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,Arial,Helvetica,sans-serif;color:var(--text);background:#fff;line-height:1.6}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(1180px,92%);margin:auto}
.topbar{background:var(--navy);color:#fff;font-size:.92rem;padding:.45rem 0}
.topbar .container,.nav .container{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:blur(10px);border-bottom:1px solid rgba(10,20,35,.08)}
.logo{display:flex;align-items:center;gap:.85rem;padding:.65rem 0}
.logo img{height:64px;width:auto}
.menu{display:flex;gap:1.4rem;align-items:center;font-weight:800;color:#16243a}
.menu a{padding:.8rem 0;border-bottom:3px solid transparent}
.menu a:hover,.menu a.active{border-color:var(--gold);color:var(--blue)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;border:none;border-radius:999px;padding:.9rem 1.25rem;font-weight:900;cursor:pointer;transition:.2s ease}
.btn-primary{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#151515;box-shadow:0 10px 25px rgba(199,160,82,.28)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-blue{background:var(--blue);color:#fff}
.btn-outline{border:1px solid rgba(255,255,255,.45);color:#fff}
.hero{position:relative;min-height:720px;display:flex;align-items:center;color:#fff;overflow:hidden;background:linear-gradient(90deg,rgba(5,12,24,.82),rgba(5,12,24,.44)),url('../img/hero-hallar.jpg') center/cover no-repeat}
.hero:after{content:"";position:absolute;inset:auto 0 0;height:110px;background:linear-gradient(0deg,#fff,transparent)}
.hero-content{position:relative;z-index:2;max-width:760px;padding:4rem 0}
.badge{display:inline-flex;border:1px solid rgba(255,255,255,.35);background:rgba(255,255,255,.13);border-radius:999px;padding:.35rem .8rem;font-weight:900;margin-bottom:1rem}
h1{font-size:clamp(2.6rem,6vw,5.2rem);line-height:1.05;margin:.4rem 0 1.3rem}
.hero p{font-size:1.18rem;max-width:650px;font-weight:650}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem;margin-top:2rem;max-width:700px}
.stat{border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.12);border-radius:18px;padding:1rem}
.stat strong{display:block;color:var(--gold2);font-size:1.3rem}
.section{padding:90px 0}
.section.alt{background:var(--light)}
.eyebrow{color:#c79438;font-weight:950;text-transform:uppercase;letter-spacing:.16em;font-size:.78rem}
.section-title{text-align:center;max-width:760px;margin:0 auto 3.4rem}
.section-title h2{font-size:clamp(2rem,4vw,3.6rem);line-height:1.1;margin:.4rem 0}
.section-title p{color:var(--muted);font-size:1.08rem}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.card img{height:230px;width:100%;object-fit:cover}
.card-body{padding:1.35rem}
.card h3{font-size:1.35rem;margin:.2rem 0 .7rem}
.card p{color:var(--muted);margin:.2rem 0 1rem}
.checks{list-style:none;margin:1rem 0 0;padding:0}
.checks li{margin:.55rem 0;color:#1f2d3d}
.checks li:before{content:"✓";color:#c79438;font-weight:900;margin-right:.55rem}
.split{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.split h2{font-size:clamp(2.2rem,4.6vw,4.3rem);line-height:1.08;margin:.45rem 0 1.2rem}
.split p{font-size:1.06rem}
.round-img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;height:520px;object-fit:cover}
.features{display:grid;gap:1rem;margin-top:1.5rem}
.feature{display:flex;gap:1rem;align-items:flex-start;background:#fff;border:1px solid rgba(10,20,35,.08);border-radius:18px;padding:1rem;box-shadow:0 8px 25px rgba(6,20,43,.05)}
.feature .num{background:#fff5d8;color:#b8872f;font-weight:900;border-radius:12px;min-width:42px;height:42px;display:grid;place-items:center}
.cta{background:var(--navy);color:#fff;border-radius:28px;padding:3rem;display:grid;grid-template-columns:1.4fr .8fr;gap:2rem;align-items:center;box-shadow:var(--shadow)}
.cta h2{font-size:clamp(2rem,4vw,3.6rem);line-height:1.12;margin:0 0 1rem}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.gallery img{height:175px;width:100%;object-fit:cover;border-radius:16px;box-shadow:var(--shadow)}
.reviews{display:grid;grid-template-columns:.8fr 1fr 1fr;gap:1rem;align-items:stretch}
.review-card{background:#fff;border-radius:18px;padding:1.3rem;box-shadow:var(--shadow);border:1px solid rgba(10,20,35,.06)}
.stars{color:#d9a735;font-size:1.25rem;letter-spacing:.06em}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:1.6rem}
.contact-box{background:#fff;border-radius:22px;padding:2rem;box-shadow:var(--shadow);border:1px solid rgba(10,20,35,.06)}
.contact-item{display:flex;gap:1rem;margin:1rem 0}
.icon{background:#fff5d8;color:#b8872f;border-radius:13px;min-width:42px;height:42px;display:grid;place-items:center;font-weight:900}
.map{width:100%;height:330px;border:0;border-radius:18px}
.footer{background:var(--navy);color:#fff;padding:55px 0 25px}
.footer-grid{display:grid;grid-template-columns:1.3fr .8fr .8fr;gap:3rem}
.footer img{height:80px;width:auto;margin-bottom:1rem}
.footer a{display:block;margin:.45rem 0;color:#dfe9f7}
.social-row{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1rem}
.social-btn{border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);padding:.65rem 1rem;border-radius:999px;color:#fff!important}
.copyright{border-top:1px solid rgba(255,255,255,.13);margin-top:2rem;padding-top:1.2rem;display:flex;justify-content:space-between;gap:1rem;color:#b9c7d8;font-size:.9rem}
.page-hero{background:linear-gradient(135deg,#0b4771,#075f9e);color:#fff;padding:105px 0 95px}
.page-hero h1{font-size:clamp(2.4rem,5.3vw,4.8rem)}
.page-hero p{font-size:1.12rem;max-width:700px}
.whatsapp-float{position:fixed;right:26px;bottom:24px;width:58px;height:58px;border-radius:50%;background:#19d26b;color:#fff;display:grid;place-items:center;z-index:80;box-shadow:0 15px 35px rgba(25,210,107,.35);font-size:1.55rem;font-weight:900;font-family:Arial,Helvetica,sans-serif}
.service-list{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.service-list .card{box-shadow:0 12px 35px rgba(6,20,43,.11)}
.legal{max-width:920px;margin:auto;color:#233248}
.legal h2{font-size:2rem}
@media(max-width:900px){
 .topbar .container{display:block;text-align:center}
 .nav .container{flex-direction:column;gap:.2rem}
 .menu{gap:.75rem;flex-wrap:wrap;justify-content:center;font-size:.92rem}
 .logo img{height:52px}
 .hero{min-height:720px}
 .hero-stats,.cards,.service-list,.reviews,.contact-grid,.split,.cta,.footer-grid{grid-template-columns:1fr}
 .gallery{grid-template-columns:1fr 1fr}
 .round-img{height:360px}
 .section{padding:65px 0}
 .page-hero{padding:70px 0}
 .copyright{flex-direction:column;text-align:center}
}
@media(max-width:520px){
 h1{font-size:2.45rem}
 .hero{min-height:680px}
 .hero-content{padding:2rem 0}
 .gallery{grid-template-columns:1fr}
 .cta{padding:2rem}
 .topbar{font-size:.78rem}
 .btn{width:100%}
 .menu .btn-blue{width:auto}
}

.whatsapp-float svg{display:block}
.footer .social-row{margin-top:1.2rem}
.footer .social-btn:hover{background:rgba(255,255,255,.16)}
