@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@500;600;700&family=Inter:wght@400;500;600&display=swap');

:root{
  --bg:#F4F8FA;
  --surface:#FFFFFF;
  --ink:#0E2A36;
  --navy:#0C447C;
  --navy-deep:#042C53;
  --teal:#0F6E56;
  --alert:#E2693C;
  --line:rgba(14,42,54,0.12);
  --font-display:'Archivo', sans-serif;
  --font-body:'Inter', sans-serif;
}
*{box-sizing:border-box; margin:0; padding:0;}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.65;
}
a{color:inherit; text-decoration:none;}
img,svg{display:block; max-width:100%;}
.wrap{max-width:1040px; margin:0 auto; padding:0 28px;}

header.site{
  position:sticky; top:0; z-index:50;
  background:rgba(244,248,250,0.94);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
header.site .wrap{display:flex; align-items:center; justify-content:space-between; height:74px;}
.logo{font-family:var(--font-display); font-weight:700; font-size:19px; color:var(--navy-deep);}
.logo span{color:var(--teal);}
nav.links{display:flex; gap:26px;}
nav.links a{font-size:14px; font-weight:500; opacity:0.7;}
nav.links a:hover{opacity:1;}
nav.links a.active{opacity:1; color:var(--navy);}
.call-btn{
  background:var(--alert); color:#fff; font-size:13px; font-weight:700;
  padding:10px 18px; border-radius:5px; white-space:nowrap;
}
@media (max-width:680px){ nav.links{display:none;} }

.hero{padding:64px 0 56px;}
.eyebrow{
  font-size:12px; letter-spacing:0.08em; text-transform:uppercase;
  color:var(--teal); font-weight:700; margin-bottom:14px;
  display:flex; align-items:center; gap:8px;
}
.eyebrow::before{content:''; width:18px; height:2px; background:var(--teal);}
.hero h1{
  font-family:var(--font-display); font-weight:700;
  font-size:clamp(30px,4.6vw,46px); line-height:1.12;
  max-width:700px; margin-bottom:18px;
}
.hero h1 em{font-style:normal; color:var(--navy);}
.hero p.lede{font-size:17px; max-width:480px; opacity:0.75; margin-bottom:28px;}
.hero-ctas{display:flex; gap:14px; flex-wrap:wrap;}
.btn{
  display:inline-flex; align-items:center; gap:8px;
  font-size:14px; font-weight:600; padding:12px 22px; border-radius:5px;
}
.btn-primary{background:var(--alert); color:#fff;}
.btn-ghost{border:1px solid var(--line); color:var(--ink); background:#fff;}

.photo-slot{
  border-radius:8px;
  overflow:hidden;
  min-height:220px;
  background:var(--navy-deep);
}
.photo-slot img{width:100%; height:100%; object-fit:cover; display:block;}
.photo-slot.placeholder{
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-deep) 100%);
  color:#F4F8FA;
  display:flex; align-items:center; justify-content:center;
  text-align:center; font-size:13px; letter-spacing:0.02em;
  padding:20px; opacity:0.94;
}
.photo-slot span{opacity:0.6; display:block; margin-top:6px; font-size:12px;}

section{padding:56px 0;}
section.alt{background:var(--surface); border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
h2.h{font-family:var(--font-display); font-weight:700; font-size:clamp(24px,3.4vw,32px); margin-bottom:10px;}
p.sub{opacity:0.7; max-width:520px; margin-bottom:34px;}

.info-strip{display:grid; grid-template-columns:repeat(3,1fr); gap:18px;}
@media (max-width:680px){ .info-strip{grid-template-columns:1fr;} }
.info-card{background:var(--surface); border:1px solid var(--line); border-radius:8px; padding:18px 20px;}
.info-card .label{font-size:11px; text-transform:uppercase; letter-spacing:0.06em; opacity:0.55; margin-bottom:6px; font-weight:700;}
.info-card .val{font-size:15px; font-weight:600;}

.service-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:16px;}
@media (max-width:680px){ .service-grid{grid-template-columns:1fr;} }
.service-card{background:var(--surface); border:1px solid var(--line); border-radius:8px; padding:20px;}
.service-card h4{font-size:16px; font-weight:600; margin-bottom:6px;}
.service-card p{font-size:13px; opacity:0.65;}

.area-tags{display:flex; flex-wrap:wrap; gap:10px;}
.area-tag{
  background:var(--surface); border:1px solid var(--line); border-radius:20px;
  padding:8px 16px; font-size:13px; font-weight:600;
}

.callout-banner{
  background:var(--navy-deep); color:#fff; border-radius:10px; padding:26px 28px;
  display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap;
}
.callout-banner h3{font-family:var(--font-display); font-size:19px; font-weight:700; margin-bottom:4px;}
.callout-banner p{font-size:13px; opacity:0.75;}

.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:36px;}
@media (max-width:680px){ .contact-grid{grid-template-columns:1fr;} }
form .field{margin-bottom:16px;}
form label{display:block; font-size:13px; font-weight:600; margin-bottom:6px;}
form input, form textarea{
  width:100%; padding:11px 12px; border:1px solid var(--line); border-radius:6px;
  font-family:var(--font-body); font-size:14px; background:var(--surface); color:var(--ink);
}
form textarea{resize:vertical; min-height:100px;}
.contact-detail{display:flex; align-items:flex-start; gap:12px; margin-bottom:18px;}
.contact-detail .k{font-size:12px; text-transform:uppercase; letter-spacing:0.05em; opacity:0.55; width:90px; flex-shrink:0; padding-top:2px;}
.contact-detail .v{font-weight:600; font-size:15px;}

footer.site{background:var(--navy-deep); color:#F4F8FA; padding:36px 0; margin-top:40px;}
footer.site .wrap{display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px;}
footer.site .biz{font-family:var(--font-display); font-weight:700; font-size:16px;}
footer.site .credit{font-size:12px; opacity:0.65;}
footer.site .credit a{text-decoration:underline;}
