:root { --bg:#fff; --text:#0b0b0b; --muted:#6b6b6b; --line:#eaeaea; --accent:#0e7c62; --radius:12px; --shadow:0 8px 30px rgba(0,0,0,0.06); }
* { box-sizing:border-box; }
html,body { margin:0; padding:0; }
body { font-family:"Noto Sans",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif; color:var(--text); background:var(--bg); line-height:1.6; }
img { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; }
.container { max-width:1160px; margin:0 auto; padding:0 20px; }
.skip-link { position:absolute; left:-9999px; }
.skip-link:focus { left:16px; top:16px; background:#000; color:#fff; padding:8px 10px; border-radius:6px; }
.site-header { position:sticky; top:0; background:#fff; border-bottom:1px solid var(--line); z-index:50; }
.site-header .container { display:flex; align-items:center; justify-content:space-between; height:68px; }
.brand { display:flex; align-items:center; gap:10px; font-weight:800; letter-spacing:-0.01em; }
.nav-toggle { width:40px; height:40px; border:none; background:transparent; border-radius:8px; display:none; position:relative; padding:0; }
/* small hamburger lines */
.nav-toggle::before {
  content: "";
  position: absolute;
  left: 10px;
  right: 10px;
  top: 50%;
  height: 2px;
  background:var(--muted);
  box-shadow: 0 -8px 0 0 var(--muted), 0 8px 0 0 var(--muted);
  transform: translateY(-50%);
  border-radius:2px;
}
/* keep accessible focus state */
.nav-toggle:focus-visible { outline:2px solid var(--accent); outline-offset:3px; }
.site-nav { display:flex; gap:18px; align-items:center; }
.site-nav a { padding:8px 10px; border-radius:8px; }
.site-nav a[aria-current="page"] { background:#f4f4f4; }
.site-nav .cta { background:#0b0b0b; color:#fff; }
.hero { padding:56px 0; }
.hero-grid { display:grid; grid-template-columns:1.1fr 1fr; gap:36px; align-items:center; }
.hero-copy h1 { font-size:44px; line-height:1.1; margin:0 0 12px; }
.hero-cta { display:flex; gap:12px; margin:16px 0 10px; }
.button { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:12px 16px; border-radius:10px; border:1px solid var(--line); background:#fff; font-weight:600; transition:background-color .18s ease, color .18s ease, box-shadow .18s ease, transform .18s ease, border-color .18s ease; }
.button.primary { background:var(--accent); color:#fff; border-color:var(--accent); }
.button.ghost { background:#fff; }
.trust-badges { display:grid; grid-template-columns:repeat(3,auto); gap:10px 18px; padding:0; margin:18px 0 0; list-style:none; color:var(--muted); }
.strip.metrics { background:#fafafa; border-block:1px solid var(--line); }
.metrics-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; padding:22px 0; }
.metric { background:#fff; border:1px solid var(--line); border-radius:12px; padding:16px; text-align:center; box-shadow:var(--shadow); }
.metric strong { display:block; font-size:24px; }
.section-head { text-align:center; margin:56px 0 22px; }
.section-head h2::after { content:""; display:block; width:64px; height:3px; margin:10px auto 0; background:var(--accent); border-radius:2px; }
.cards { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.card { border:1px solid var(--line); border-radius:14px; overflow:hidden; background:#fff; display:flex; flex-direction:column; box-shadow:var(--shadow); }
.card img { aspect-ratio: 4/3; object-fit:cover; }
.card .card-body { padding:16px; display:flex; flex-direction:column; gap:8px; }
.section-cta { text-align:center; margin:20px 0 0; }
.showcase .gallery, .gallery { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.gallery figure { margin:0; border-radius:12px; overflow:hidden; border:1px solid var(--line); background:#fff; }
.gallery img { width:100%; height:100%; aspect-ratio:4/3; object-fit:cover; transition:transform .2s ease; }
.gallery a:hover img { transform:scale(1.02); }
.testimonials .quotes { list-style:none; display:grid; grid-template-columns:repeat(3,1fr); gap:16px; padding:0; }
.quote { border:1px solid var(--line); border-radius:12px; padding:16px; background:#fff; box-shadow:var(--shadow); }
.map-cta { padding:56px 0; background:#fafafa; border-top:1px solid var(--line); }
.map-grid { display:grid; grid-template-columns:1fr 1.2fr; gap:24px; align-items:center; }
.map-wrap { border:1px solid var(--line); border-radius:12px; overflow:hidden; background:#fff; box-shadow:var(--shadow); }
.map { height:380px; }
.faq .accordion { display:grid; gap:10px; }
.faq details { border:1px solid var(--line); border-radius:10px; padding:12px 16px; background:#fff; }
.cta-strip { background:linear-gradient(90deg, var(--accent) 0%, #0b5746 100%); color:#fff; margin:56px 0 0; }
.cta-inner { display:flex; align-items:center; justify-content:space-between; gap:16px; padding:22px 0; }
.site-footer { border-top:1px solid var(--line); margin-top:0; }
.footer-grid { display:grid; grid-template-columns:1.2fr 1fr 1fr; gap:24px; padding:32px 0; }
.footer-nav, .contact-col { display:grid; gap:8px; }
.footer-brand { font-weight:800; }
.subfooter { border-top:1px solid var(--line); padding:12px 0; color:var(--muted); }
.page-head { margin:24px 0 22px; }
.pad-top { padding-top:28px; }
.about-grid { display:grid; grid-template-columns:1.1fr 1fr; gap:24px; align-items:center; }
.values { margin:44px 0; }
.pillars { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; list-style:none; padding:0; }
.pillars li { border:1px solid var(--line); border-radius:12px; padding:14px; background:#fff; display:grid; gap:6px; box-shadow:var(--shadow); }
.filters { display:flex; gap:8px; margin:10px 0 18px; }
.chip { border:1px solid var(--line); background:#fff; padding:8px 12px; border-radius:999px; }
.chip.is-active { background:#0b0b0b; color:#fff; border-color:#0b0b0b; }
.chip:hover, .chip:focus-visible { border-color:var(--accent); background:#f4fbf8; color:var(--accent); }
.lightbox[hidden] { display:none; }
.lightbox { position:fixed; inset:0; background:rgba(0,0,0,.8); display:grid; place-items:center; padding:20px; }
.lightbox img { max-width:min(1200px, 90vw); max-height:70vh; border-radius:12px; box-shadow:0 10px 40px rgba(0,0,0,.5); }
.lightbox-close { position:absolute; top:18px; right:18px; width:40px; height:40px; background:#fff; border:1px solid var(--line); border-radius:10px; }
.contact-form { display:grid; gap:12px; }
.contact-form .grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
label { display:grid; gap:6px; font-weight:600; }
input, select, textarea { border:1px solid var(--line); border-radius:10px; padding:12px; background:#fff; font:inherit; }
input:focus, select:focus, textarea:focus { outline:2px solid var(--accent); outline-offset:2px; }
.checkbox { font-weight:400; }
.form-actions { display:flex; align-items:center; gap:12px; }
.inline { display:flex; align-items:center; gap:10px; }
.bullets { list-style:disc; padding-left:18px; }
.sr-only { position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; }
.home-fab { position:fixed; right:20px; bottom:20px; background:#0b0b0b; color:#fff; border:1px solid var(--line); border-radius:999px; padding:10px 14px; font-weight:700; box-shadow:var(--shadow); transition:background-color .18s ease, border-color .18s ease, box-shadow .18s ease; }
.home-fab:hover, .home-fab:focus-visible { background:var(--accent); border-color:var(--accent); box-shadow:0 10px 30px rgba(0,0,0,.12); }
@media (max-width:1000px){
  .hero-grid, .map-grid, .about-grid { grid-template-columns:1fr; }
  .metrics-grid { grid-template-columns:repeat(2,1fr); }
  .cards, .showcase .gallery, .gallery, .testimonials .quotes, .pillars { grid-template-columns:1fr 1fr; }
}
@media (max-width:640px){
  .site-nav { display:none; position:absolute; inset:68px 0 auto 0; background:#fff; border-bottom:1px solid var(--line); padding:10px 20px; }
  .site-nav.open { display:grid; gap:6px; }
  .nav-toggle { display:inline-grid; place-items:center; }
  .trust-badges { grid-template-columns:1fr; }
  .cards, .showcase .gallery, .gallery, .testimonials .quotes, .pillars, .contact-form .grid, .metrics-grid { grid-template-columns:1fr; }
  .cta-inner { flex-direction:column; text-align:center; }
}