
:root{--brand:#0F2A44;--brand2:#1F4E79;--water:#2E86C1;--cta:#F26B1F;--bg:#fcfcfd;--fg:#1f2937;--muted:#5b6878;--border:#e5e7eb;--card:#fff;}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,sans-serif;color:var(--fg);background:var(--bg);-webkit-font-smoothing:antialiased;line-height:1.6}
h1,h2,h3,h4{font-family:'Manrope',system-ui,sans-serif;letter-spacing:-.02em;line-height:1.15;color:var(--brand);margin:0 0 .5em}
h1{font-size:clamp(2rem,4vw,3.4rem);font-weight:800}
h2{font-size:clamp(1.5rem,2.8vw,2.25rem);font-weight:700}
h3{font-size:1.2rem;font-weight:700}
a{color:var(--brand2);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 1.25rem}
.container-sm{max-width:760px;margin:0 auto;padding:0 1.25rem}

/* Header */
.topbar{background:#0b1f33;color:#cbd5e1;font-size:.78rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;padding:.45rem 1.25rem}
.topbar a{color:#fff}
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1.25rem}
.brand img{height:42px}
.nav ul{display:flex;gap:.25rem;list-style:none;margin:0;padding:0}
.nav ul a{color:#1f2937;padding:.55rem .85rem;border-radius:.5rem;font-weight:500;font-size:.95rem}
.nav ul a:hover{background:#f1f5f9;text-decoration:none}
.nav ul a.active{color:var(--brand);background:#eef4fb;font-weight:700}
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.7rem 1.1rem;border-radius:.5rem;font-weight:600;font-size:.92rem;border:0;cursor:pointer;transition:.2s}
.btn-cta{background:var(--cta);color:#fff;box-shadow:0 6px 20px -8px rgba(242,107,31,.6)}
.btn-cta:hover{filter:brightness(1.08);text-decoration:none}
.btn-ghost{background:transparent;color:var(--brand);border:1px solid var(--border)}
.btn-light{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.3);backdrop-filter:blur(6px)}
.btn-light:hover{background:rgba(255,255,255,.2);text-decoration:none}
.menu-btn{display:none;background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--brand)}
@media(max-width:980px){.nav ul,.nav .btn-cta{display:none}.menu-btn{display:block}.nav.open ul{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:#fff;padding:1rem;border-top:1px solid var(--border);box-shadow:0 12px 32px rgba(0,0,0,.08)}}

/* Hero */
.hero{position:relative;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:-1}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(15,42,68,.95) 0%,rgba(31,78,121,.85) 55%,rgba(46,134,193,.55) 100%)}
.hero-inner{padding:6rem 0 5rem}
.hero h1{color:#fff;max-width:780px}
.hero h1 .accent{color:#FFB347}
.hero p{font-size:1.15rem;max-width:640px;color:rgba(255,255,255,.9)}
.tag{display:inline-flex;align-items:center;gap:.4rem;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);padding:.35rem .8rem;border-radius:999px;font-size:.78rem;font-weight:500}
.cta-row{margin-top:2rem;display:flex;flex-wrap:wrap;gap:.75rem}
.checks{margin:2.5rem 0 0;padding:0;list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;max-width:760px}
.checks li{font-size:.9rem;color:rgba(255,255,255,.9)}
.checks li::before{content:"✓ ";color:#7ee5b4;font-weight:700}

/* Page header */
.pagehead{background:linear-gradient(180deg,#f1f5f9,#fff);border-bottom:1px solid var(--border);padding:3rem 0 2.5rem}
.crumbs{font-size:.85rem;color:var(--muted);margin-bottom:1rem}
.crumbs a{color:var(--muted)}.crumbs span{color:var(--brand)}

/* Sections */
section{padding:4rem 0}
.kicker{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--water);font-weight:700;margin-bottom:.6rem}
.lead{font-size:1.13rem;color:var(--muted);max-width:680px}
.muted{color:var(--muted)}

/* Stats */
.stats{background:#f1f5f9;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:2.5rem 0}
.stats .grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;text-align:center}
@media(min-width:760px){.stats .grid{grid-template-columns:repeat(4,1fr)}}
.stat-n{font-family:'Manrope';font-size:2.2rem;font-weight:800;color:var(--brand)}
.stat-l{font-size:.88rem;color:var(--muted);margin-top:.2rem}

/* Cards */
.cards{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:2.5rem}
.card{background:var(--card);border:1px solid var(--border);border-radius:1rem;overflow:hidden;transition:.3s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:0 20px 40px -20px rgba(15,42,68,.25)}
.card .ph{aspect-ratio:16/10;overflow:hidden}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:.4s}
.card:hover .ph img{transform:scale(1.05)}
.card .body{padding:1.4rem;flex:1;display:flex;flex-direction:column}
.card .body p{color:var(--muted);font-size:.93rem;flex:1}
.card a.more{color:var(--brand2);font-weight:700;font-size:.9rem;margin-top:.6rem;display:inline-block}

/* Why us */
.why{background:linear-gradient(135deg,#eef4fb,#dde7f3)}
.split{display:grid;gap:3rem;align-items:center}
@media(min-width:900px){.split{grid-template-columns:1fr 1fr}}
.split img{border-radius:1rem;box-shadow:0 25px 50px -25px rgba(15,42,68,.4)}
.feat{list-style:none;padding:0;margin:1.5rem 0 0}
.feat li{display:flex;gap:.8rem;margin-bottom:1.2rem}
.feat li::before{content:"✓";flex-shrink:0;width:1.5rem;height:1.5rem;background:var(--water);color:#fff;border-radius:50%;display:grid;place-items:center;font-size:.85rem;font-weight:700;margin-top:.15rem}
.feat strong{display:block;color:var(--brand);margin-bottom:.15rem}
.feat span{color:var(--muted);font-size:.92rem}

/* Process */
.process{display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-top:2.5rem}
.step{background:#fff;border:1px solid var(--border);border-radius:.85rem;padding:1.5rem;transition:.3s}
.step:hover{transform:translateY(-3px);box-shadow:0 14px 30px -14px rgba(15,42,68,.22)}
.step .n{font-family:'Manrope';font-size:1.7rem;font-weight:800;color:var(--water)}

/* Reviews */
.reviews{background:#f8fafc;padding-top:5rem;padding-bottom:5rem}
.reviews .grid{display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));margin-top:2.5rem}
.rev{background:#fff;border:1px solid var(--border);border-radius:1rem;padding:1.6rem}
.rev .stars{color:#f0a020;margin-bottom:.6rem;letter-spacing:2px}
.rev blockquote{margin:0;font-size:.95rem;color:#374151}
.rev cite{display:block;margin-top:1rem;font-style:normal;font-weight:700;color:var(--brand);font-size:.92rem}
.rev cite span{font-weight:400;color:var(--muted)}

/* CTA banner */
.bigcta{background:linear-gradient(135deg,#0F2A44,#1F4E79);color:#fff;border-radius:1.4rem;padding:3.5rem;position:relative;overflow:hidden;margin:3rem 0}
.bigcta::before{content:"";position:absolute;right:-100px;top:-100px;width:300px;height:300px;background:rgba(242,107,31,.3);border-radius:50%;filter:blur(60px)}
.bigcta h2{color:#fff}
.bigcta p{color:rgba(255,255,255,.85);max-width:600px}
.bigcta .cta-row{margin-top:1.5rem}

/* Footer */
footer.site{background:#0a1f33;color:#cbd5e1;margin-top:4rem;padding:3.5rem 0 0}
footer .grid{display:grid;gap:2.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
footer h4{color:#fff;font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem}
footer ul{list-style:none;padding:0;margin:0;font-size:.92rem}
footer ul li{margin-bottom:.5rem}
footer a{color:#cbd5e1}
footer a:hover{color:#fff}
footer .brand img{background:#fff;padding:.3rem .6rem;border-radius:.4rem;height:46px}
footer .small{font-size:.85rem;color:#9ca3b3;margin-top:.8rem;line-height:1.5}
footer .bottom{border-top:1px solid #1c344f;margin-top:2.5rem;padding:1.2rem 0;font-size:.78rem;display:flex;flex-wrap:wrap;justify-content:space-between;gap:.5rem;color:#9ca3b3}
footer .bottom ul{display:flex;flex-wrap:wrap;gap:1.2rem}
footer .bottom ul li{margin:0}

/* Mobile sticky */
.sticky-mobile{display:none}
@media(max-width:760px){
  body{padding-bottom:60px}
  .sticky-mobile{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:40;background:#fff;border-top:1px solid var(--border);box-shadow:0 -4px 20px rgba(0,0,0,.06)}
  .sticky-mobile a{flex:1;text-align:center;padding:.95rem 0;font-weight:700;font-size:.92rem}
  .sticky-mobile a:first-child{color:var(--brand)}
  .sticky-mobile a:last-child{background:var(--cta);color:#fff}
}

/* Cookie banner */
.cookie{position:fixed;bottom:1rem;right:1rem;left:1rem;max-width:420px;margin-left:auto;background:#fff;border:1px solid var(--border);border-radius:.85rem;padding:1.25rem;box-shadow:0 25px 50px -10px rgba(0,0,0,.18);z-index:60;display:none;animation:fadeUp .5s ease-out}
.cookie.show{display:block}
.cookie h3{font-size:1rem;color:var(--brand);margin:0 0 .4rem}
.cookie p{font-size:.85rem;color:var(--muted);margin:0 0 .8rem}
.cookie .row{display:flex;gap:.5rem;justify-content:flex-end}
.cookie button{padding:.5rem .9rem;border-radius:.4rem;font-size:.85rem;font-weight:600;cursor:pointer;border:0}
.cookie .b1{background:#fff;border:1px solid var(--border);color:var(--fg)}
.cookie .b2{background:var(--brand);color:#fff}

/* FAQ */
.faq details{background:#fff;border:1px solid var(--border);border-radius:.6rem;margin-bottom:.6rem;padding:0}
.faq summary{padding:1rem 1.2rem;cursor:pointer;font-weight:600;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::after{content:"+";font-size:1.4rem;color:var(--water);font-weight:300}
.faq details[open] summary::after{content:"–"}
.faq details > div{padding:0 1.2rem 1.1rem;color:var(--muted);font-size:.94rem}

/* Forms */
.form{background:#fff;border:1px solid var(--border);border-radius:1rem;padding:1.8rem;display:grid;gap:1rem;max-width:600px}
.form label{display:block;font-weight:600;font-size:.88rem;margin-bottom:.3rem}
.form input,.form select,.form textarea{width:100%;padding:.7rem .9rem;border:1px solid var(--border);border-radius:.45rem;font-family:inherit;font-size:.95rem;background:#fff}
.form input:focus,.form textarea:focus,.form select:focus{outline:2px solid var(--water);outline-offset:1px;border-color:var(--water)}
.form .row2{display:grid;gap:1rem;grid-template-columns:1fr 1fr}
@media(max-width:600px){.form .row2{grid-template-columns:1fr}}
.form-grid{display:grid;gap:2rem;grid-template-columns:1.4fr 1fr;align-items:start}
@media(max-width:880px){.form-grid{grid-template-columns:1fr}}
.contact-card{background:#fff;border:1px solid var(--border);border-radius:.7rem;padding:1.1rem;display:flex;gap:.8rem;margin-bottom:.85rem}
.contact-card .ic{flex-shrink:0;width:38px;height:38px;background:#eaf3fb;color:var(--water);border-radius:.4rem;display:grid;place-items:center;font-size:1.1rem}
.contact-card div{font-size:.92rem}
.contact-card .lab{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600}

/* Article (blog/policy) */
.prose{max-width:720px;margin:0 auto;font-size:1.02rem;line-height:1.75}
.prose h2{margin-top:2.5rem;font-size:1.5rem}
.prose h3{margin-top:1.8rem;font-size:1.18rem}
.prose ul,.prose ol{padding-left:1.4rem;margin:1rem 0}
.prose li{margin-bottom:.4rem}
.prose strong{color:var(--brand)}
.prose blockquote{border-left:4px solid var(--water);padding-left:1rem;margin:1.5rem 0;color:var(--muted);font-style:italic}

/* Map */
.map{border-radius:.85rem;overflow:hidden;border:1px solid var(--border);aspect-ratio:4/3}
.map iframe{width:100%;height:100%;border:0}

/* Animations */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s,transform .8s}
.reveal.show{opacity:1;transform:translateY(0)}
.hero-inner > *{animation:fadeUp .8s ease-out backwards}
.hero-inner > *:nth-child(1){animation-delay:.05s}
.hero-inner > *:nth-child(2){animation-delay:.18s}
.hero-inner > *:nth-child(3){animation-delay:.32s}
.hero-inner > *:nth-child(4){animation-delay:.45s}
.hero-inner > *:nth-child(5){animation-delay:.58s}

/* Service area chips */
.chips{display:grid;gap:.6rem;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));list-style:none;padding:0}
.chips li{background:#fff;border:1px solid var(--border);padding:.7rem .9rem;border-radius:.5rem;font-size:.92rem;display:flex;align-items:center;gap:.4rem}
.chips li::before{content:"📍";font-size:.85rem}

/* Materials chips */
.mats{display:flex;flex-wrap:wrap;gap:.5rem;margin:.8rem 0 1.5rem;padding:0;list-style:none}
.mats li{font-size:.78rem;padding:.35rem .7rem;border:1px solid var(--border);background:#fff;border-radius:999px;color:var(--brand2)}
.callout{background:#fff;border-left:4px solid var(--cta);padding:1rem 1.2rem;border-radius:.4rem;margin:1.5rem 0;font-size:.95rem;box-shadow:0 4px 12px rgba(0,0,0,.04)}

/* Thank-you success */
#sent{display:none;color:#0a7c45;background:#e8f7ee;border:1px solid #b6e3c5;padding:.7rem 1rem;border-radius:.5rem;font-size:.9rem}
