
:root{
  --bg:#0a1615;
  --ink:#0e2421;
  --text:#102523;
  --muted:#6b8f8c;
  --brand:#12171f;
  --brand-2:#d4e43d;
  --surface:#ffffff;
  --surface-2:#f5f7f7;
  --radius:12px;
  --shadow:0 10px 30px rgba(0,0,0,.08);
  --w:1080px;
  --focus: 0 0 0 3px #d4e43d40;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;color:var(--ink);background:var(--surface);line-height:1.6}
img{max-width:100%;height:auto}
.container{width:min(100% - 2rem, var(--w));margin-inline:auto}
.grid-2{display:grid;gap:1.25rem;grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{display:grid;gap:1.25rem;grid-template-columns:repeat(3,minmax(0,1fr))}
@media (max-width:900px){.grid-2,.grid-3{grid-template-columns:1fr}}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;clip:rect(0,0,0,0);white-space:nowrap;border:0;overflow:hidden}

.site-header{position:sticky;top:0;background:rgba(255,255,255,.95);backdrop-filter:saturate(180%) blur(10px);border-bottom:2px solid var(--brand);z-index:10}
.site-header .container{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0}
.brand{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--brand);font-weight:800}
.nav{display:flex;align-items:center;gap:1rem}
.nav a{color:var(--ink);text-decoration:none;padding:.5rem .75rem;border-radius:8px}
.nav a:hover{background:var(--surface-2)}
.nav-toggle{display:none;background:none;border:1px solid #e1e7e7;border-radius:8px;padding:.4rem .6rem}
@media (max-width:780px){
  .nav{position:fixed;inset:64px 0 auto 0;background:white;border-bottom:1px solid #eef1f1;display:none;flex-direction:column;padding:1rem}
  .nav.open{display:flex}
  .nav-toggle{display:block}
}

.hero{background:linear-gradient(180deg, var(--surface), var(--surface-2));padding:5rem 0 3rem;border-bottom:2px solid var(--brand)}
.hero h1{font-size:clamp(2rem, 1.6rem + 1.6vw, 3rem);margin:0 0 .6rem;color:var(--brand)}
.lead{font-size:1.125rem;color:#35514e}
.hero-cta{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}
.pill-list{display:flex;gap:.5rem;flex-wrap:wrap;margin:1rem 0 0;padding:0;list-style:none}
.pill-list li{background:var(--surface-2);border:1px solid #e6efee;padding:.4rem .6rem;border-radius:999px;font-size:.9rem;color:#35514e}

.feature-cards article,.projects .card{background:white;border:1px solid #eef1f1;border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow)}
.feature-cards h3{margin-top:0;color:var(--brand)}

.logos{padding:2rem 0}
.logos h2{margin-bottom:.5rem;color:var(--brand)}

.btn{display:inline-block;text-decoration:none;border:2px solid var(--brand);padding:.6rem .9rem;border-radius:10px;font-weight:700}
.btn-cta{background:var(--brand);color:white;border-color:var(--brand)}
.btn-cta:hover{filter:brightness(1.05)}
.btn-secondary{background:white;color:var(--brand);border-color:var(--brand)}

.site-footer{margin-top:3rem;padding:2rem 0;background:var(--brand);color:#ffffff}
.site-footer a{color:#ffffff}
.site-footer .print{display:flex;justify-content:space-between;gap:1rem;border-top:1px solid rgba(255,255,255,.2);padding-top:1rem;margin-top:1rem}
.small{font-size:.9rem}

.list-plain{list-style:none;margin:0;padding:0}
.list-plain li{margin:.4rem 0}

form{display:grid;gap:1rem;margin:1rem 0 2rem}
input,select,textarea{width:100%;padding:.6rem .7rem;border-radius:8px;border:1px solid #cfe1df;background:white}
input:focus,select:focus,textarea:focus{outline:none;box-shadow:0 0 0 3px #d4e43d66;border-color:var(--brand)}
label{display:grid;gap:.4rem}

.tags{display:flex;gap:.4rem;list-style:none;padding:0;margin:.6rem 0 0}
.tags li{background:#d4e43d22;border:1px solid #d4e43d66;border-radius:999px;padding:.25rem .5rem;font-size:.85rem;color:var(--brand)}

.service-blocks article{background:white;border:1px solid #eef1f1;border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow)}

@media (prefers-reduced-motion:no-preference){
  .btn-cta{transition:transform .04s ease-in}
  .btn-cta:active{transform:translateY(1px)}
}
