:root{
  --green-900:#0c3a2c;
  --green-700:#12624a;
  --green-500:#1b8a66;
  --green-400:#2aa67e;
  --mint-100:#e8f5ef;
  --mint-50:#f3faf7;
  --gold:#c8a45a;
  --ink:#13201b;
  --gray:#5c6b64;
  --line:#e3ebe7;
  --white:#ffffff;
  --bg:#fbfdfc;
  --font-display:'Outfit',sans-serif;
  --font-body:'Manrope',sans-serif;
  --radius:18px;
  --radius-sm:12px;
  --shadow:0 14px 40px -18px rgba(12,58,44,0.22);
  --shadow-sm:0 6px 24px -14px rgba(12,58,44,0.25);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.15;letter-spacing:-0.01em}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.container{width:90%;max-width:1180px;margin:0 auto}
section{padding:96px 0}

/* ---------- HEADER ---------- */
header{
  position:fixed;width:100%;top:0;z-index:100;
  background:rgba(251,253,252,0.82);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:10px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:68px;height:68px;border-radius:50%;border:2px solid var(--mint-100);box-shadow:0 4px 14px -6px rgba(12,58,44,0.3)}
.brand-text strong{display:block;font-family:var(--font-display);font-weight:700;font-size:1.4rem;letter-spacing:0.02em;text-transform:uppercase;color:var(--green-900);line-height:1.05}
.brand-text span{font-size:0.74rem;letter-spacing:0.14em;text-transform:lowercase;color:var(--gray)}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a{font-size:0.92rem;color:var(--gray);font-weight:500;transition:color .2s}
.nav-links a:hover{color:var(--green-700)}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-weight:500;font-size:0.92rem;
  padding:12px 22px;border-radius:100px;transition:all .25s;cursor:pointer;border:none;
}
.btn-primary{background:var(--green-700);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--green-900);transform:translateY(-2px)}
.btn-wpp{background:#25d366;color:#fff !important;font-weight:600;box-shadow:0 6px 18px -8px rgba(37,211,102,0.7)}
.btn-wpp svg{flex-shrink:0;fill:#fff}
.btn-wpp:hover,.btn-wpp:visited,.btn-wpp:focus{background:#1eb558;color:#fff !important}
.btn-wpp:hover{transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--green-700);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--green-500);color:var(--green-900)}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px}
.menu-toggle span{width:24px;height:2px;background:var(--green-900);border-radius:2px;transition:.3s}

/* ---------- HERO ---------- */
.hero{position:relative;padding:120px 0 110px;overflow:hidden}
.hero::before{
  content:"";position:absolute;top:-180px;right:-160px;width:560px;height:560px;
  background:radial-gradient(circle,var(--mint-100),transparent 70%);z-index:0;
}
.hero::after{
  content:"";position:absolute;bottom:-120px;left:-120px;width:360px;height:360px;
  background:radial-gradient(circle,rgba(200,164,90,0.10),transparent 70%);z-index:0;
}
.hero .container{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr 0.9fr;gap:60px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:0.78rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--green-500);font-weight:600;margin-bottom:22px}
.eyebrow::before{content:"";width:28px;height:1.5px;background:var(--gold)}
.hero h1{font-size:clamp(2.4rem,5vw,3.7rem);color:var(--green-900);margin-bottom:24px}
.hero h1 em{font-style:normal;color:var(--green-500)}
.hero p{font-size:1.08rem;color:var(--gray);max-width:520px;margin-bottom:36px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}
.hero-visual{position:relative}
.hero-card{
  background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:34px;border:1px solid var(--line);
}
.hero-logo{width:96px;height:96px;border-radius:50%;margin:0 auto 18px;border:3px solid var(--mint-100);display:block}
.hero-card h3{text-align:center;color:var(--green-900);font-size:1.25rem;margin-bottom:4px}
.hero-card .role{text-align:center;font-size:0.85rem;color:var(--gray);margin-bottom:26px}
.hero-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.stat{background:var(--mint-50);border-radius:var(--radius-sm);padding:16px;text-align:center}
.stat strong{display:block;font-family:var(--font-display);font-size:1.5rem;color:var(--green-700);font-weight:700}
.stat span{font-size:0.74rem;color:var(--gray);letter-spacing:0.04em}

/* ---------- SECTION HEAD ---------- */
.sec-head{text-align:center;max-width:640px;margin:0 auto 60px}
.sec-head .eyebrow{justify-content:center}
.sec-head h2{font-size:clamp(2rem,4vw,2.7rem);color:var(--green-900);margin-bottom:16px}
.sec-head p{color:var(--gray);font-size:1.04rem}

/* ---------- ABOUT ---------- */
.about{background:var(--white)}
.about .container{display:grid;grid-template-columns:0.85fr 1.15fr;gap:64px;align-items:center}
.about-photo{position:relative}
.about-photo img{width:100%;border-radius:var(--radius);box-shadow:var(--shadow);object-fit:cover}
.about-photo .badge{
  position:absolute;bottom:24px;right:-18px;background:var(--green-700);color:#fff;
  padding:16px 22px;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);
}
.about-photo .badge strong{font-family:var(--font-display);font-size:1.05rem;display:block}
.about-photo .badge span{font-size:0.74rem;opacity:.85;letter-spacing:0.06em}
.about-content h2{font-size:clamp(1.9rem,3.6vw,2.5rem);color:var(--green-900);margin-bottom:8px}
.about-content .cro{font-size:0.85rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--green-500);font-weight:600;margin-bottom:22px}
.about-content p{color:var(--gray);margin-bottom:22px}
.creds{display:flex;flex-direction:column;gap:14px;margin-top:28px}
.cred{display:flex;align-items:center;gap:14px}
.cred-icon{width:42px;height:42px;border-radius:12px;background:var(--mint-100);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--green-700)}
.cred-icon svg{width:20px;height:20px}
.cred-text strong{display:block;font-family:var(--font-display);font-weight:600;color:var(--green-900);font-size:0.98rem}
.cred-text span{font-size:0.84rem;color:var(--gray)}

/* ---------- SERVICES ---------- */
.services{background:var(--mint-50)}
.grid-services{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.service-card{
  background:var(--white);border-radius:var(--radius);padding:32px 28px;border:1px solid var(--line);
  transition:transform .3s,box-shadow .3s;position:relative;overflow:hidden;
}
.service-card::after{content:"";position:absolute;top:0;left:0;width:0;height:3px;background:var(--gold);transition:width .35s}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.service-card:hover::after{width:100%}
.svc-icon{width:54px;height:54px;border-radius:14px;background:var(--mint-100);display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--green-700)}
.svc-icon svg{width:26px;height:26px}
.service-card h3{font-size:1.18rem;color:var(--green-900);margin-bottom:12px}
.service-card p{font-size:0.92rem;color:var(--gray);line-height:1.6}

/* ---------- HOURS + LOCATION ---------- */
.visit .container{display:grid;grid-template-columns:1fr 1.15fr;gap:48px;align-items:stretch}
.hours-card,.map-card{background:var(--white);border-radius:var(--radius);border:1px solid var(--line);overflow:hidden;box-shadow:var(--shadow-sm)}
.hours-card{padding:40px}
.hours-card h3{font-size:1.5rem;color:var(--green-900);margin-bottom:6px}
.hours-card>p{font-size:0.9rem;color:var(--gray);margin-bottom:26px}
.hour-row{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--line)}
.hour-row:last-of-type{border-bottom:none}
.hour-row .day{font-weight:500;color:var(--ink)}
.hour-row .time{font-size:0.9rem;color:var(--green-700);font-weight:600}
.hour-row .closed{color:var(--gray);font-weight:400}
.visit-contact{margin-top:28px;display:flex;flex-direction:column;gap:12px}
.contact-line{display:flex;align-items:center;gap:14px;font-size:0.95rem;color:var(--ink)}
.contact-line svg{width:20px;height:20px;color:var(--green-500);flex-shrink:0}
.map-card iframe{width:100%;height:100%;min-height:420px;border:0;display:block}
.map-placeholder{width:100%;height:100%;min-height:420px;background:var(--mint-100);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--green-700);padding:30px;gap:12px}
.map-placeholder svg{width:48px;height:48px;opacity:.6}
.map-placeholder small{color:var(--gray);max-width:300px;font-size:0.8rem}

/* ---------- CTA BAND ---------- */
.cta-band{background:linear-gradient(120deg,var(--green-900),var(--green-700));color:#fff;text-align:center;border-radius:0}
.cta-band h2{font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:16px}
.cta-band p{color:rgba(255,255,255,0.82);max-width:560px;margin:0 auto 32px;font-size:1.05rem}
.cta-band .btn-primary{background:#fff;color:var(--green-900)}
.cta-band .btn-primary:hover{background:var(--mint-100)}

/* ---------- FOOTER ---------- */
footer{background:var(--green-900);color:rgba(255,255,255,0.8);padding:64px 0 28px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:44px}
.footer-brand img{width:54px;height:54px;border-radius:50%;margin-bottom:16px}
.footer-brand h4{color:#fff;font-size:1.2rem;margin-bottom:10px}
.footer-brand p{font-size:0.9rem;max-width:320px;color:rgba(255,255,255,0.6)}
.footer-col h5{color:#fff;font-family:var(--font-display);font-size:0.8rem;letter-spacing:0.14em;text-transform:uppercase;margin-bottom:18px}
.footer-col a{display:block;font-size:0.92rem;margin-bottom:11px;color:rgba(255,255,255,0.7);transition:color .2s}
.footer-col a:hover{color:var(--gold)}
.socials{display:flex;gap:12px;margin-top:6px}
.socials a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,0.08);display:flex;align-items:center;justify-content:center;transition:.25s}
.socials a:hover{background:var(--gold);color:var(--green-900)}
.socials svg{width:18px;height:18px}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.12);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:0.82rem;color:rgba(255,255,255,0.5)}

/* ---------- WHATSAPP FLOAT ---------- */
.wpp-float{
  position:fixed;bottom:26px;right:26px;z-index:200;
  width:62px;height:62px;border-radius:50%;background:#25d366;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 30px -6px rgba(37,211,102,0.6);
  transition:transform .25s;animation:pulse 2.4s infinite;
}
.wpp-float:hover{transform:scale(1.08)}
.wpp-float svg{width:34px;height:34px;fill:#fff}
@keyframes pulse{0%{box-shadow:0 10px 30px -6px rgba(37,211,102,0.6),0 0 0 0 rgba(37,211,102,0.4)}70%{box-shadow:0 10px 30px -6px rgba(37,211,102,0.6),0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 10px 30px -6px rgba(37,211,102,0.6),0 0 0 0 rgba(37,211,102,0)}}

/* ---------- REVEAL ANIMATION ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1024px){
  .nav-links{
    position:fixed;top:89px;left:0;right:0;background:var(--white);
    flex-direction:column;gap:0;padding:0;max-height:0;overflow:hidden;
    border-bottom:1px solid var(--line);transition:max-height .35s ease;
  }
  .nav-links.open{max-height:420px;padding:10px 0 20px}
  .nav-links a{padding:14px 24px;width:100%}
  .nav-links .btn{margin:8px 24px 0;justify-content:center}
  .menu-toggle{display:flex}
  .hero .container,.about .container,.visit .container{grid-template-columns:1fr;gap:46px}
  .about-photo{max-width:420px;margin:0 auto}
  .about-photo .badge{right:0}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  section{padding:72px 0}
  .hero{padding:80px 0 70px}
}
@media(max-width:520px){
  .hero-actions{flex-direction:column}
  .hero-actions .btn{justify-content:center}
  .hero-stats{grid-template-columns:1fr 1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .brand img{width:54px;height:54px}
  .brand-text strong{font-size:1.08rem}
  .brand-text span{font-size:0.66rem;letter-spacing:0.1em}
}
