*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --green:#16a34a;--green-d:#0f7a30;--green-l:#dcfce7;--green-xl:#f0fdf4;
  --ink:#0a0f1e;--ink2:#374151;--muted:#6b7280;--border:#e5e7eb;
  --bg:#f8fafc;--white:#ffffff;
  --radius:16px;--radius-sm:10px;
  --shadow:0 2px 12px rgba(0,0,0,.07);--shadow-md:0 6px 24px rgba(0,0,0,.1);
  --font:'Plus Jakarta Sans',system-ui,sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--ink);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ── LAYOUT ── */
.wrap{max-width:1120px;margin:0 auto;padding:0 16px}
@media(min-width:768px){.wrap{padding:0 24px}}

/* ── HEADER ── */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 16px;max-width:1120px;margin:0 auto}
@media(min-width:768px){.header-inner{padding:14px 24px}}
.logo{display:flex;align-items:center;gap:8px;font-weight:800;font-size:15px;color:var(--ink)}
@media(min-width:480px){.logo{font-size:17px;gap:10px}}
.logo-mark{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#16a34a,#22c55e);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:14px;flex-shrink:0}
@media(min-width:480px){.logo-mark{width:38px;height:38px}}
.site-nav{display:flex;align-items:center;gap:4px}
.site-nav a.nav-link{display:none}
@media(min-width:680px){.site-nav a.nav-link{display:block;padding:8px 12px;border-radius:999px;font-weight:600;font-size:14px;color:var(--ink2);transition:.15s}.site-nav a.nav-link:hover{background:var(--green-l);color:var(--green-d)}}
.site-nav .cta{background:var(--green);color:#fff;padding:10px 14px;border-radius:999px;font-weight:700;font-size:13px;white-space:nowrap;box-shadow:0 2px 8px rgba(22,163,74,.35)}
@media(min-width:480px){.site-nav .cta{padding:10px 18px;font-size:14px}}
.site-nav .cta:hover{background:var(--green-d);color:#fff}

/* ── HERO ── */
.hero{background:linear-gradient(160deg,#f0fdf4 0%,#e0f2fe 100%);padding:40px 0 36px}
@media(min-width:768px){.hero{padding:72px 0 64px}}
.hero-inner{display:grid;grid-template-columns:1fr;gap:24px;align-items:center;max-width:1120px;margin:0 auto;padding:0 16px}
@media(min-width:768px){.hero-inner{grid-template-columns:1fr 1fr;gap:48px;padding:0 24px}}
.hero-eyebrow{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--border);border-radius:999px;padding:5px 12px;font-size:12px;font-weight:600;color:var(--green-d);margin-bottom:14px;box-shadow:var(--shadow)}
h1{font-size:clamp(28px,6vw,52px);font-weight:800;line-height:1.1;letter-spacing:-.02em;color:var(--ink);margin-bottom:14px}
h1 span{color:var(--green)}
.hero-sub{font-size:15px;color:var(--ink2);line-height:1.6;margin-bottom:22px}
@media(min-width:768px){.hero-sub{font-size:17px;margin-bottom:28px}}
.hero-actions{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
@media(min-width:480px){.hero-actions{flex-direction:row;flex-wrap:wrap}}
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--green);color:#fff;padding:15px 22px;border-radius:999px;font-weight:700;font-size:15px;box-shadow:0 4px 16px rgba(22,163,74,.4);transition:.2s;width:100%}
@media(min-width:480px){.btn-primary{width:auto;padding:14px 24px}}
.btn-primary:hover{background:var(--green-d);transform:translateY(-1px)}
.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:#fff;color:var(--ink);padding:15px 22px;border-radius:999px;font-weight:700;font-size:15px;border:1.5px solid var(--border);box-shadow:var(--shadow);transition:.2s;width:100%}
@media(min-width:480px){.btn-outline{width:auto;padding:14px 24px}}
.btn-outline:hover{border-color:var(--green);color:var(--green)}
.hero-trust{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--muted)}
@media(min-width:480px){.trust-item{font-size:13px}}
.hero-img-wrap{display:block;position:relative}
.hero-img-main{border-radius:24px;width:100%;height:420px;object-fit:cover;box-shadow:var(--shadow-md)}
.hero-badge{position:absolute;bottom:20px;left:20px;background:#fff;border-radius:14px;padding:12px 16px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:10px}
.hero-badge-stars{color:#f59e0b;font-size:16px;letter-spacing:1px}
.hero-badge-text{font-size:13px;font-weight:700;color:var(--ink)}
.hero-badge-sub{font-size:11px;color:var(--muted)}

/* ── STATS BAR ── */
.stats-bar{background:var(--green);padding:18px 0}
.stats-inner{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;max-width:1120px;margin:0 auto;padding:0 16px}
@media(min-width:600px){.stats-inner{grid-template-columns:repeat(4,1fr);gap:0;padding:0 24px}}
.stat-item{text-align:center;padding:6px 0}
@media(min-width:600px){.stat-item{border-right:1px solid rgba(255,255,255,.2)}.stat-item:last-child{border-right:none}}
.stat-num{font-size:26px;font-weight:800;color:#fff}
@media(min-width:600px){.stat-num{font-size:28px}}
.stat-label{font-size:11px;color:rgba(255,255,255,.85);font-weight:500;margin-top:2px}

/* ── SECTIONS ── */
.section{padding:48px 0}
@media(min-width:768px){.section{padding:72px 0}}
.section-alt{background:var(--bg)}
.section-label{font-size:12px;font-weight:700;color:var(--green);letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}
.section-title{font-size:clamp(22px,4vw,38px);font-weight:800;color:var(--ink);line-height:1.15;letter-spacing:-.02em;margin-bottom:10px}
.section-sub{font-size:14px;color:var(--muted);max-width:520px}
@media(min-width:768px){.section-sub{font-size:16px}}
.section-head{margin-bottom:28px}
@media(min-width:768px){.section-head{margin-bottom:40px}}

/* ── SERVICES ── */
.services-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:480px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.services-grid{grid-template-columns:repeat(3,1fr);gap:20px}}
.svc-card{background:#fff;border-radius:var(--radius);border:1px solid var(--border);padding:20px;transition:.2s}
@media(min-width:768px){.svc-card{padding:28px}}
.svc-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.svc-icon{width:44px;height:44px;border-radius:12px;background:var(--green-l);display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:14px}
.svc-card h3{font-size:16px;font-weight:700;margin-bottom:6px}
@media(min-width:768px){.svc-card h3{font-size:18px}}
.svc-card p{color:var(--muted);font-size:13px;line-height:1.6;margin-bottom:12px}
.svc-price{font-size:13px;font-weight:700;color:var(--green);background:var(--green-l);padding:4px 10px;border-radius:999px;display:inline-block}
.svc-link{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:var(--green);margin-top:10px}

/* ── HOW IT WORKS ── */
.steps{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:600px){.steps{grid-template-columns:repeat(3,1fr);gap:32px}}
.step{text-align:center;padding:24px 20px}
@media(min-width:768px){.step{padding:32px 24px}}
.step-num{width:48px;height:48px;border-radius:50%;background:var(--green);color:#fff;font-size:20px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.step h3{font-size:16px;font-weight:700;margin-bottom:8px}
.step p{color:var(--muted);font-size:13px;line-height:1.6}

/* ── GALLERY ── */
.gallery-scroll{display:grid;grid-auto-flow:column;grid-auto-columns:260px;gap:12px;overflow-x:auto;padding:4px 0 16px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
@media(min-width:480px){.gallery-scroll{grid-auto-columns:300px}}
@media(min-width:768px){.gallery-scroll{grid-auto-columns:320px;gap:16px}}
.gallery-scroll::-webkit-scrollbar{height:4px;background:var(--border)}
.gallery-scroll::-webkit-scrollbar-thumb{background:var(--green);border-radius:2px}
.gallery-item{scroll-snap-align:start;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.gallery-item img{width:100%;height:220px;object-fit:cover;display:block}
@media(min-width:768px){.gallery-item img{height:280px}}
.gallery-caption{padding:8px 12px;background:#fff;font-size:12px;font-weight:600;color:var(--muted)}

/* ── REVIEWS ── */
.reviews-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:580px){.reviews-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.reviews-grid{grid-template-columns:repeat(3,1fr);gap:20px}}
.rv-card{background:#fff;border-radius:var(--radius);border:1px solid var(--border);padding:18px;box-shadow:var(--shadow)}
.rv-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.rv-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0}
.rv-name{font-weight:700;font-size:14px;color:var(--ink)}
.rv-stars{color:#f59e0b;font-size:12px;margin-top:2px}
.rv-time{color:var(--muted);font-size:11px;font-weight:400}
.rv-text{font-size:13px;color:var(--ink2);line-height:1.65;margin-bottom:10px}
.rv-tag{font-size:11px;font-weight:600;color:var(--green);background:var(--green-l);padding:3px 9px;border-radius:999px;display:inline-block}
.reviews-cta{margin-top:24px;text-align:center}
@media(min-width:768px){.reviews-cta{margin-top:32px}}

/* ── PRICING ── */
.pricing-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:580px){.pricing-grid{grid-template-columns:repeat(2,1fr);gap:20px}}
.price-card{background:#fff;border-radius:var(--radius);border:1px solid var(--border);padding:22px;box-shadow:var(--shadow)}
@media(min-width:768px){.price-card{padding:28px}}
.price-card.featured{border-color:var(--green);border-width:2px;position:relative}
.featured-badge{position:absolute;top:-12px;left:20px;background:var(--green);color:#fff;font-size:11px;font-weight:700;padding:4px 12px;border-radius:999px}
.price-card h3{font-size:17px;font-weight:700;margin-bottom:4px}
.price-card .from{font-size:13px;color:var(--muted);margin-bottom:14px}
.price-list{list-style:none}
.price-list li{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:14px;color:var(--ink2)}
.price-list li:last-child{border-bottom:none}
.price-list .price-val{font-weight:700;color:var(--green)}

/* ── CALCULATOR ── */
.calc-wrap{background:#fff;border-radius:var(--radius);border:1px solid var(--border);padding:20px;box-shadow:var(--shadow)}
@media(min-width:768px){.calc-wrap{padding:32px}}
.calc-items{display:grid;gap:10px;margin-bottom:14px}
.calc-row{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center}
.calc-row select{width:100%;padding:10px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:13px;color:var(--ink);background:#fff}
@media(min-width:480px){.calc-row select{font-size:14px;padding:10px 12px}}
.calc-row select:focus{outline:2px solid var(--green-l);border-color:var(--green)}
.calc-val{font-weight:700;color:var(--green);min-width:44px;text-align:right;font-size:14px}
@media(min-width:480px){.calc-val{min-width:50px;font-size:15px}}
.calc-remove{background:#fee2e2;border:none;border-radius:8px;color:#b91c1c;cursor:pointer;padding:8px 9px;font-weight:700;font-size:13px}
.calc-add{background:var(--green-xl);border:1.5px dashed var(--green);border-radius:var(--radius-sm);color:var(--green-d);cursor:pointer;padding:10px;width:100%;font-family:var(--font);font-weight:600;font-size:14px}
.calc-total-row{display:flex;justify-content:space-between;align-items:center;background:var(--green-xl);border-radius:var(--radius-sm);padding:14px 16px;margin-top:14px;border:1px solid var(--green-l)}
@media(min-width:480px){.calc-total-row{padding:16px 20px}}
.calc-total-label{font-weight:700;font-size:14px}
@media(min-width:480px){.calc-total-label{font-size:15px}}
.calc-total-val{font-size:28px;font-weight:800;color:var(--green)}
@media(min-width:480px){.calc-total-val{font-size:32px}}

/* ── BOOKING FORM ── */
.book-inner{display:grid;grid-template-columns:1fr;gap:32px;align-items:start}
@media(min-width:768px){.book-inner{grid-template-columns:1fr 1fr;gap:48px}}
.book-info-item{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.book-info-icon{width:42px;height:42px;border-radius:12px;background:var(--green-l);display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}
.form-wrap{background:#fff;border-radius:var(--radius);border:1px solid var(--border);padding:20px;box-shadow:var(--shadow-md)}
@media(min-width:480px){.form-wrap{padding:28px}}
@media(min-width:768px){.form-wrap{padding:32px}}
.form-grid{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:480px){.form-grid{grid-template-columns:1fr 1fr}}
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:13px;font-weight:600;color:var(--ink)}
.field input,.field select,.field textarea{padding:12px 13px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:14px;color:var(--ink);background:#fff;transition:.15s;width:100%}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-l)}
.field-full{grid-column:1/-1}
.form-submit{width:100%;padding:15px;background:var(--green);color:#fff;border:none;border-radius:999px;font-family:var(--font);font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 4px 16px rgba(22,163,74,.4);transition:.2s}
.form-submit:hover{background:var(--green-d)}
.form-note{font-size:12px;color:var(--muted);text-align:center;margin-top:6px}

/* ── FAQ ── */
.faq-list{display:grid;gap:8px}
@media(min-width:768px){.faq-list{gap:10px}}
.faq-item{background:#fff;border-radius:var(--radius-sm);border:1px solid var(--border);overflow:hidden}
.faq-q{width:100%;text-align:left;background:none;border:none;padding:16px 18px;font-family:var(--font);font-size:14px;font-weight:600;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px}
@media(min-width:768px){.faq-q{padding:18px 20px;font-size:15px}}
.faq-q .arrow{font-size:18px;color:var(--green);transition:.25s transform;flex-shrink:0}
.faq-q.open .arrow{transform:rotate(45deg)}
.faq-a{padding:0 18px;max-height:0;overflow:hidden;transition:.3s max-height}
@media(min-width:768px){.faq-a{padding:0 20px}}
.faq-a.open{max-height:200px;padding-bottom:16px}
.faq-a p{font-size:13px;color:var(--ink2);line-height:1.65}
@media(min-width:768px){.faq-a p{font-size:14px}}

/* ── SERVICE AREAS ── */
.areas-grid{display:flex;flex-wrap:wrap;gap:8px}
@media(min-width:768px){.areas-grid{gap:10px}}
.area-pill{display:inline-flex;align-items:center;gap:5px;background:#fff;border:1px solid var(--border);border-radius:999px;padding:8px 14px;font-size:13px;font-weight:600;color:var(--ink2);box-shadow:var(--shadow);transition:.15s}
.area-pill:hover{border-color:var(--green);color:var(--green)}

/* ── CTA BANNER ── */
.cta-banner{background:linear-gradient(135deg,#16a34a,#0f9d58);border-radius:20px;padding:40px 24px;text-align:center;color:#fff}
@media(min-width:600px){.cta-banner{border-radius:24px;padding:56px 48px}}
.cta-banner h2{font-size:clamp(22px,4vw,40px);font-weight:800;margin-bottom:10px}
.cta-banner p{font-size:15px;opacity:.9;margin-bottom:24px}
@media(min-width:768px){.cta-banner p{font-size:17px;margin-bottom:28px}}
.cta-btns{display:flex;flex-direction:column;gap:10px;align-items:center}
@media(min-width:480px){.cta-btns{flex-direction:row;justify-content:center}}
.btn-white{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--green);padding:15px 28px;border-radius:999px;font-weight:800;font-size:15px;box-shadow:0 4px 20px rgba(0,0,0,.15);transition:.2s;width:100%;justify-content:center}
@media(min-width:480px){.btn-white{width:auto;padding:16px 32px;font-size:16px}}
.btn-white:hover{transform:translateY(-2px)}
.btn-sms{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.15);color:#fff;padding:15px 28px;border-radius:999px;font-weight:700;font-size:15px;border:2px solid rgba(255,255,255,.4);transition:.2s;width:100%;justify-content:center}
@media(min-width:480px){.btn-sms{width:auto;padding:16px 32px;font-size:16px}}
.btn-sms:hover{background:rgba(255,255,255,.25)}

/* ── FOOTER ── */
.site-footer{background:#0a0f1e;color:#9ca3af;padding:48px 0 32px}
.footer-inner{display:grid;grid-template-columns:1fr;gap:28px;max-width:1120px;margin:0 auto;padding:0 16px 32px;border-bottom:1px solid rgba(255,255,255,.08)}
@media(min-width:600px){.footer-inner{grid-template-columns:2fr 1fr 1fr;gap:40px;padding:0 24px 40px}}
.footer-brand .logo{color:#fff;margin-bottom:12px}
.footer-brand p{font-size:13px;line-height:1.6;max-width:280px}
.footer-col h4{font-size:12px;font-weight:700;color:#fff;margin-bottom:12px;text-transform:uppercase;letter-spacing:.06em}
.footer-col a{display:block;font-size:13px;color:#9ca3af;margin-bottom:8px;transition:.15s}
.footer-col a:hover{color:#fff}
.footer-bottom{display:flex;flex-direction:column;gap:8px;max-width:1120px;margin:20px auto 0;padding:0 16px;font-size:12px}
@media(min-width:600px){.footer-bottom{flex-direction:row;justify-content:space-between;align-items:center;margin:24px auto 0;padding:0 24px;gap:10px}}
.footer-bottom a{color:#6b7280;transition:.15s}
.footer-bottom a:hover{color:#fff}

/* ── WHATSAPP ── */
.wa-btn{position:fixed;bottom:84px;right:16px;z-index:999;width:52px;height:52px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.45);transition:.2s}
@media(min-width:768px){.wa-btn{bottom:24px;right:24px;width:56px;height:56px}}
.wa-btn:hover{transform:scale(1.1)}

/* ── MOBILE STICKY CALL BAR ── */
.mobile-call-bar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:998;box-shadow:0 -2px 16px rgba(0,0,0,.15)}
@media(min-width:768px){.mobile-call-bar{display:none}}
.mob-call{flex:2;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;gap:8px;padding:16px 12px;font-weight:800;font-size:16px}
.mob-sms{flex:1;background:#fff;color:var(--ink);display:flex;align-items:center;justify-content:center;gap:6px;padding:16px 10px;font-weight:700;font-size:13px;border-top:1px solid var(--border);border-left:1px solid var(--border)}

/* ── SPLASH ── */
#splash{position:fixed;inset:0;z-index:9999;background:#fff;display:grid;place-items:center;transition:opacity .5s ease,visibility 0s linear .5s}
#splash.gone{opacity:0;visibility:hidden;pointer-events:none}
.splash-logo{font-family:var(--font);font-size:32px;font-weight:800;color:var(--green)}

/* ── MOBILE BODY PADDING ── */
body{padding-bottom:60px}
@media(min-width:768px){body{padding-bottom:0}}

/* ── UTILITY ── */
.muted{color:var(--muted)}
.card{background:var(--white);border-radius:var(--radius);border:1px solid var(--border);padding:20px;box-shadow:var(--shadow)}
@media(min-width:768px){.card{padding:24px}}

@media(max-width:767px){
  .hero-img-main{height:240px!important;border-radius:16px!important}
  video.hero-img-main{height:240px!important}
}
