:root{
  --teal:#2DC5A2;--teal-dark:#1fa884;--teal-deep:#0d6b57;
  --teal-pale:#e8f9f5;--dark:#12201c;--mid:#3a5248;
  --muted:#7a9990;--cream:#f6faf8;--white:#fff;
  --border:#d4ede6;--wa:#25D366;--wa-dark:#1ebe5d;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--dark);overflow-x:hidden;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:14px 40px;background:rgba(246,250,248,0.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);}
.nav-logo{display:flex;align-items:center;gap:10px;}
.nav-logo img{width:38px;height:38px;border-radius:9px;object-fit:cover;}
.nav-logo-text{font-family:'Playfair Display',serif;font-size:1.35rem;color:var(--dark);}
.nav-logo-text span{color:var(--teal);}
.nav-cta{display:flex;align-items:center;gap:7px;background:var(--wa);color:white;font-weight:600;font-size:.86rem;padding:10px 20px;border-radius:50px;text-decoration:none;transition:all .2s;box-shadow:0 4px 14px rgba(37,211,102,.3);}
.nav-cta:hover{background:var(--wa-dark);transform:translateY(-1px);}

/* HERO */
.hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;padding-top:72px;}
.hero-left{padding:70px 60px 70px 72px;animation:fadeUp .8s ease both;}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:var(--teal-pale);color:var(--teal-dark);font-size:.76rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:5px 13px;border-radius:50px;margin-bottom:22px;border:1px solid #b2e8da;}
.hero-badge::before{content:'●';font-size:.45rem;}
h1{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,3.4vw,3.1rem);line-height:1.15;color:var(--dark);margin-bottom:18px;}
h1 em{font-style:italic;color:var(--teal);}
.hero-sub{font-size:1rem;color:var(--mid);line-height:1.65;margin-bottom:32px;max-width:420px;font-weight:300;}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center;}
.btn-primary{display:flex;align-items:center;gap:8px;background:var(--wa);color:white;font-weight:600;font-size:.98rem;padding:14px 28px;border-radius:50px;text-decoration:none;transition:all .2s;box-shadow:0 6px 22px rgba(37,211,102,.35);}
.btn-primary:hover{background:var(--wa-dark);transform:translateY(-2px);}
.btn-secondary{color:var(--teal-dark);font-weight:500;font-size:.92rem;text-decoration:none;display:flex;align-items:center;gap:6px;transition:gap .2s;}
.btn-secondary:hover{gap:10px;}

/* HERO RIGHT */
.hero-right{position:relative;height:100vh;overflow:hidden;animation:fadeIn 1s ease both .2s;}
.hero-right-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.hero-right-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(13,107,87,.78) 0%,rgba(45,197,162,.55) 100%);}
.hero-inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:22px;padding:40px;}
.hero-inner img.logo{width:150px;height:150px;border-radius:26px;object-fit:cover;box-shadow:0 22px 56px rgba(0,0,0,.25);animation:float 4s ease-in-out infinite;}
.hero-logo-caption{font-family:'Playfair Display',serif;font-size:1.9rem;color:white;letter-spacing:.06em;text-align:center;}
.hero-logo-caption small{display:block;font-family:'DM Sans',sans-serif;font-size:.8rem;font-weight:300;letter-spacing:.14em;text-transform:uppercase;opacity:.7;margin-top:5px;}
.hero-stat-row{display:flex;gap:18px;margin-top:8px;}
.hero-stat{background:rgba(255,255,255,.14);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.22);border-radius:14px;padding:14px 20px;text-align:center;color:white;}
.hero-stat strong{display:block;font-family:'Playfair Display',serif;font-size:1.6rem;}
.hero-stat span{font-size:.7rem;opacity:.75;letter-spacing:.06em;text-transform:uppercase;}

/* STRIP */
.strip{background:var(--dark);padding:16px 80px;display:flex;align-items:center;justify-content:center;gap:56px;flex-wrap:wrap;}
.strip-item{display:flex;align-items:center;gap:9px;font-size:.83rem;font-weight:300;letter-spacing:.04em;color:rgba(255,255,255,.7);}
.strip-item svg{color:var(--teal);flex-shrink:0;}

/* SERVICES */
.section{padding:90px 80px;}
.section-label{font-size:.73rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);margin-bottom:12px;}
h2{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,2.8vw,2.5rem);color:var(--dark);line-height:1.2;margin-bottom:14px;}
.section-intro{font-size:.97rem;color:var(--mid);line-height:1.7;max-width:500px;font-weight:300;margin-bottom:52px;}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;}
.service-card{background:white;border-radius:18px;overflow:hidden;border:1px solid var(--border);transition:transform .25s,box-shadow .25s;}
.service-card:hover{transform:translateY(-5px);box-shadow:0 18px 44px rgba(45,197,162,.11);}
.service-card-img{width:100%;height:190px;object-fit:cover;display:block;}
.service-card-body{padding:28px 26px;}
.service-icon{width:44px;height:44px;border-radius:11px;background:var(--teal-pale);display:flex;align-items:center;justify-content:center;margin-bottom:16px;}
.service-icon svg{width:22px;height:22px;color:var(--teal);}
.service-card h3{font-family:'Playfair Display',serif;font-size:1.22rem;color:var(--dark);margin-bottom:9px;}
.service-card p{font-size:.88rem;color:var(--mid);line-height:1.65;font-weight:300;}
.service-tag{display:inline-block;margin-top:14px;font-size:.71rem;font-weight:600;color:var(--teal-dark);background:var(--teal-pale);padding:3px 11px;border-radius:50px;}

/* GALLERY */
.gallery{padding:0 80px 90px;}
.gallery-label{font-size:.73rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);margin-bottom:12px;}
.gallery h2{margin-bottom:40px;}
.gallery-grid{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:220px 220px;gap:14px;}
.gallery-grid img{width:100%;height:100%;object-fit:cover;border-radius:14px;display:block;}
.gallery-grid img:first-child{grid-row:span 2;border-radius:18px;}

/* CTA BANNER */
.cta-banner{background:var(--teal);padding:72px 80px;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;}
.cta-banner-text h2{color:white;font-size:clamp(1.7rem,2.8vw,2.2rem);margin-bottom:8px;}
.cta-banner-text p{color:rgba(255,255,255,.8);font-size:.97rem;font-weight:300;}
.btn-white{display:flex;align-items:center;gap:9px;background:white;color:var(--teal-dark);font-weight:700;font-size:.97rem;padding:15px 32px;border-radius:50px;text-decoration:none;transition:all .2s;white-space:nowrap;box-shadow:0 8px 26px rgba(0,0,0,.14);}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 12px 34px rgba(0,0,0,.18);}

/* LOCATION */
.location-section{padding:90px 80px;}
.location-grid{display:grid;grid-template-columns:1fr 2fr;gap:56px;align-items:center;margin-top:52px;}
.location-info{display:flex;flex-direction:column;gap:26px;}
.loc-item{display:flex;gap:16px;align-items:flex-start;}
.loc-icon{width:44px;height:44px;border-radius:11px;background:var(--teal-pale);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.loc-icon svg{width:21px;height:21px;color:var(--teal);}
.loc-item h4{font-size:.75rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-bottom:3px;}
.loc-item p{font-size:.96rem;color:var(--dark);}
.loc-item a{color:var(--teal-dark);text-decoration:none;font-weight:500;}
.map-embed{border-radius:18px;overflow:hidden;border:1px solid var(--border);box-shadow:0 10px 36px rgba(0,0,0,.07);height:398px;}
.map-embed iframe{width:100%;height:100%;border:none;}

/* FOOTER */
footer{background:var(--dark);padding:36px 80px 90px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px;}
footer p{font-size:.76rem;color:rgba(255,255,255);}

/* FLOATING WA */
.wa-float{position:fixed;bottom:26px;right:26px;z-index:200;background:var(--wa);color:white;width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 28px rgba(37,211,102,.5);text-decoration:none;transition:transform .2s;animation:pulse 2.5s ease-in-out infinite;}
.wa-float:hover{transform:scale(1.1);}

@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes pulse{0%,100%{box-shadow:0 8px 28px rgba(37,211,102,.5)}50%{box-shadow:0 8px 38px rgba(37,211,102,.72),0 0 0 9px rgba(37,211,102,.1)}}

@media(max-width:900px){
  nav{padding:14px 20px;}
  .hero{grid-template-columns:1fr;min-height:auto;}
  .hero-left{padding:60px 20px 60px;}
  .hero-right{height:400px;}
  .section,.gallery,.location-section,.cta-banner{padding:60px 20px;}
  .strip{padding:20px 20px;gap:20px;justify-content: flex-start;}
  .location-grid{grid-template-columns:1fr;}
  footer{padding:36px 20px 120px;}
  .cta-banner{flex-direction:column;align-items:flex-start;}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;}
  .gallery-grid img:first-child{grid-row:span 1;}
  .btn-primary {
      font-size: 1rem;
      padding: 12px 24px;
  }
}
@media (max-width: 575px) {
  nav .nav-cta {
    display: none;
  }
  .hero-badge {
      font-size: .65rem;
  }
  .hero-actions {
      gap: 24px;
  }
}