
:root{
  --bg:#ffffff;
  --ink:#202020;
  --muted:#666;
  --line:#e6e6e6;
  --soft:#f5f5f3;
  --dark:#0e2538;
  --dark-2:#153852;
  --accent:#244d68;
  --max:1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Arial, Helvetica, sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
}
a{color:inherit}
.container{width:min(var(--max), calc(100% - 40px)); margin:0 auto}
.narrow{max-width:780px}
.site-header{
  position:sticky;
  top:0;
  z-index:10;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:18px 28px;
  background:rgba(14,37,56,.98);
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.brand{display:flex; align-items:center; text-decoration:none; min-width:260px}
.brand img{display:block; width:260px; max-width:100%; height:auto}
.brand-mark{font-size:34px; font-weight:800; letter-spacing:-2px}
.brand-text{font-size:12px; text-transform:uppercase; letter-spacing:2.2px; line-height:1.15; max-width:190px}
.site-nav{display:flex; align-items:center; gap:22px; flex-wrap:wrap; justify-content:flex-end}
.site-nav a{
  text-decoration:none;
  text-transform:uppercase;
  letter-spacing:1.6px;
  font-size:12px;
  color:#f2f2f2;
  opacity:.9;
}
.site-nav a:hover{opacity:1; text-decoration:underline; text-underline-offset:6px}
.nav-toggle{display:none}
.hero{
  position:relative;
  overflow:hidden;
  min-height:470px;
  display:grid;
  place-items:center;
  text-align:center;
  background:linear-gradient(135deg,#f5f5f3,#ffffff);
}
.hero-bg{
  position:absolute; inset:0;
  background:
    linear-gradient(to bottom, rgba(255,255,255,.1), rgba(255,255,255,.92)),
    radial-gradient(circle at 18% 34%, rgba(14,37,56,.18), transparent 25%),
    radial-gradient(circle at 78% 20%, rgba(14,37,56,.14), transparent 24%),
    linear-gradient(135deg, #d6dcdf, #f6f6f6 48%, #c9d1d5);
  filter:grayscale(.7);
}
.hero-bg:after{
  content:"";
  position:absolute;
  width:4px;
  height:72%;
  left:72%;
  top:12%;
  background:rgba(14,37,56,.24);
  box-shadow:
    -18px 22px 0 rgba(14,37,56,.12),
    28px -8px 0 rgba(14,37,56,.10);
}
.hero-content{position:relative; padding:80px 0}
.eyebrow{
  margin:0 0 16px;
  text-transform:uppercase;
  letter-spacing:3.4px;
  font-size:12px;
  font-weight:700;
  color:#5c5c5c;
}
.hero .eyebrow{color:#333}
h1,h2,h3{line-height:1.15; margin:0 0 18px}
h1{
  font-size:clamp(34px, 5vw, 60px);
  letter-spacing:.035em;
  text-transform:uppercase;
  font-weight:500;
}
h2{font-size:clamp(28px, 3.2vw, 42px); font-weight:500}
h3{font-size:20px}
.hero p{max-width:820px; margin:0 auto 28px; font-size:20px; color:#404040}
.hero-actions{display:flex; gap:14px; justify-content:center; flex-wrap:wrap}
.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:13px 20px;
  border:1px solid var(--dark);
  background:var(--dark);
  color:#fff;
  text-decoration:none;
  text-transform:uppercase;
  letter-spacing:1.2px;
  font-size:12px;
  font-weight:700;
  cursor:pointer;
}
.button:hover{filter:brightness(.92)}
.section{padding:84px 0}
.section.alt{background:var(--soft)}
.section-heading{max-width:760px; margin-bottom:36px}
.lead{font-size:24px; line-height:1.45; color:#333}
.split{
  display:grid;
  grid-template-columns:minmax(0, .85fr) minmax(0, 1.15fr);
  gap:64px;
  align-items:start;
}
.cards{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:22px;
}
.card{
  display:block;
  min-height:205px;
  padding:28px;
  background:#fff;
  border:1px solid var(--line);
  text-decoration:none;
  transition:transform .18s ease, box-shadow .18s ease;
}
.card:hover{transform:translateY(-3px); box-shadow:0 12px 30px rgba(0,0,0,.08)}
.card p{color:var(--muted); margin-bottom:0}
.check-list{padding:0; margin:22px 0 0; list-style:none}
.check-list li{position:relative; padding-left:28px; margin:10px 0}
.check-list li:before{
  content:"";
  position:absolute;
  left:0;
  top:.63em;
  width:12px;
  height:2px;
  background:var(--dark);
}
.contact-grid{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
  gap:70px;
}
.contact-form{
  display:grid;
  gap:16px;
  padding:30px;
  background:var(--soft);
  border:1px solid var(--line);
}
label{display:grid; gap:8px; font-weight:700; font-size:14px}
input,textarea{
  width:100%;
  border:1px solid #cfcfcf;
  background:#fff;
  padding:12px 14px;
  font:inherit;
}
.site-footer{
  background:var(--dark);
  color:#fff;
  padding:42px 0 24px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.3fr 1fr 1fr;
  gap:28px;
}
.footer-grid p{color:#d6d6d6}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12); margin-top:24px; padding-top:20px; color:#bdbdbd}
@media (max-width:900px){
  .site-header{align-items:flex-start; flex-wrap:wrap}
  .nav-toggle{
    display:inline-flex;
    background:transparent;
    color:#fff;
    border:1px solid rgba(255,255,255,.4);
    padding:8px 12px;
    text-transform:uppercase;
    letter-spacing:1px;
  }
  .site-nav{
    display:none;
    width:100%;
    justify-content:flex-start;
    gap:14px 18px;
    padding-top:12px;
  }
  .site-nav.open{display:flex}
  .split,.contact-grid,.footer-grid{grid-template-columns:1fr; gap:32px}
  .cards{grid-template-columns:1fr 1fr}
}
@media (max-width:620px){
  .container{width:min(var(--max), calc(100% - 28px))}
  .site-header{padding:16px}
  .brand{min-width:0}
  .brand img{width:220px}
  .brand-mark{font-size:28px}
  .brand-text{font-size:10px; letter-spacing:1.8px}
  .hero{min-height:430px}
  .hero p{font-size:17px}
  .section{padding:58px 0}
  .cards{grid-template-columns:1fr}
  .card{min-height:unset}
}
