@import url("https://fonts.googleapis.com/css2?family=Newsreader:opsz,wght@6..72,500;6..72,600&display=swap");


:root{
  --navy:#11263f;
  --navy-2:#1d3a5c;
  --blue:#5f89b5;
  --mist:#eef4f8;
  --mist-2:#d9e5ef;
  --ink:#16222f;
  --muted:#5c6c7c;
  --line:#d8e2ea;
  --white:#ffffff;
  --success:#1f6f4a;
  --error:#a43838;
  --shadow:0 10px 28px rgba(17,38,63,.08);
  --radius:20px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--ink);
  background:linear-gradient(180deg,#f7fbff 0%, #fff 180px);
  line-height:1.55;
}
a{color:var(--navy-2); text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%}
.container{width:min(1080px, calc(100% - 32px)); margin:0 auto}
.site-header{
  position:sticky; top:0; z-index:20;
  backdrop-filter: blur(8px);
  background:rgba(255,255,255,.82);
  border-bottom:1px solid rgba(216,226,234,.65);
}
.nav-wrap{display:flex; align-items:center; justify-content:space-between; gap:16px; min-height:70px}
.brand{
  font-family:"Newsreader", Georgia, "Times New Roman", serif;
  font-weight:600;
  letter-spacing:.012em;
  color:var(--navy);
  font-size:1.16rem;
  line-height:1.1;
  text-rendering:optimizeLegibility;
}
.brand small{display:block; color:var(--muted); font-weight:600; font-size:.72rem; margin-top:2px}
.nav-links{display:flex; gap:18px; align-items:center}
.nav-links a{font-weight:600; color:var(--navy)}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  min-height:48px; padding:0 18px; border-radius:999px; border:1px solid transparent;
  font-weight:700; transition:transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
}
.btn:hover{text-decoration:none; transform:translateY(-1px)}
.btn-primary{background:var(--navy); color:#fff; box-shadow:var(--shadow)}
.btn-primary:hover{background:#0d1f34}
.btn-secondary{background:#fff; color:var(--navy); border-color:var(--line)}
.btn-secondary:hover{background:#f8fbfd}
.hero{padding:72px 0 36px}
.hero-grid{display:grid; grid-template-columns:1.15fr .85fr; gap:28px; align-items:start}
.eyebrow{
  display:inline-flex; align-items:center; gap:8px; padding:8px 12px;
  border-radius:999px; background:var(--mist); color:var(--navy-2);
  font-weight:700; font-size:.86rem; border:1px solid var(--mist-2)
}
h1{
  font-size:clamp(2rem, 4vw, 3.6rem);
  line-height:1.05; letter-spacing:-.03em; margin:16px 0 16px; color:var(--navy);
}
.hero p.lead{
  font-size:1.08rem; color:var(--muted); max-width:62ch; margin:0 0 24px;
}
.hero-card, .card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow);
}
.hero-card{padding:22px}
.hero-card h3{margin:0 0 10px; color:var(--navy); font-size:1.08rem}
.hero-list{display:grid; gap:12px; margin-top:8px}
.hero-list li{list-style:none; display:flex; gap:12px; color:var(--ink)}
.icon-dot{
  flex:0 0 38px; width:38px; height:38px; border-radius:12px;
  background:var(--mist); color:var(--navy); display:grid; place-items:center; border:1px solid var(--mist-2)
}
.section{padding:34px 0}
.section h2{
  font-size:clamp(1.6rem,3vw,2.4rem); line-height:1.1; letter-spacing:-.02em;
  color:var(--navy); margin:0 0 12px
}
.section p.section-lead{color:var(--muted); max-width:68ch; margin:0 0 22px}
.grid-2{display:grid; grid-template-columns:1fr 1fr; gap:20px}
.grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.service-card, .feature-card{
  padding:22px; background:#fff; border:1px solid var(--line); border-radius:18px; box-shadow:var(--shadow)
}
.service-card h3, .feature-card h3{margin:12px 0 10px; color:var(--navy)}
.service-card p, .feature-card p{margin:0; color:var(--muted)}
.service-card ul{margin:14px 0 0; padding-left:18px; color:var(--ink)}
.band{
  background:linear-gradient(180deg,#f3f8fb 0%, #edf4f8 100%);
  border-top:1px solid var(--line); border-bottom:1px solid var(--line)
}
.stats{display:grid; grid-template-columns:repeat(4,1fr); gap:16px}
.stat{padding:18px; border-radius:18px; background:#fff; border:1px solid var(--line); box-shadow:var(--shadow)}
.stat strong{display:block; font-size:1.2rem; color:var(--navy)}
.stat span{color:var(--muted)}
.about-card{
  padding:24px; background:#fff; border:1px solid var(--line); border-radius:22px; box-shadow:var(--shadow)
}
.about-card p{color:var(--ink); margin:0}
.form-wrap{
  display:grid; grid-template-columns:.95fr 1.05fr; gap:20px; align-items:start
}
.contact-card{padding:22px}
label{display:block; font-weight:700; font-size:.95rem; color:var(--navy); margin-bottom:8px}
input, select, textarea{
  width:100%; min-height:48px; padding:12px 14px; border-radius:14px;
  border:1px solid var(--line); background:#fff; color:var(--ink); font:inherit
}
textarea{min-height:132px; resize:vertical}
.field{margin-bottom:16px}
.help{font-size:.88rem; color:var(--muted)}
.notice{
  padding:12px 14px; border-radius:14px; font-size:.95rem; margin-top:10px; display:none
}
.notice.success{display:block; background:#edf8f2; color:var(--success); border:1px solid #cfe8da}
.notice.error{display:block; background:#fdf0f0; color:var(--error); border:1px solid #efcdcd}
.form-actions{display:flex; gap:12px; align-items:center; flex-wrap:wrap}
.contact-list{display:grid; gap:14px; margin-top:16px}
.contact-item{display:flex; gap:12px; align-items:flex-start}
.page-hero{padding:56px 0 20px}
.page-hero h1{font-size:clamp(1.8rem,4vw,3rem)}
.prose{
  background:#fff; border:1px solid var(--line); border-radius:22px; box-shadow:var(--shadow);
  padding:28px; margin:22px 0 52px
}
.prose h2{font-size:1.2rem; margin:28px 0 10px; color:var(--navy)}
.prose h2:first-child{margin-top:0}
.prose p, .prose li{color:var(--ink)}
.prose ul{padding-left:20px}
.site-footer{
  border-top:1px solid var(--line);
  background:#fff;
  padding:26px 0 38px;
  margin-top:28px
}
.footer-grid{display:flex; justify-content:space-between; gap:18px; align-items:flex-start; flex-wrap:wrap}
.footer-links{display:flex; gap:14px; flex-wrap:wrap}
.sr-only{
  position:absolute!important; width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0
}
@media (max-width: 920px){
  .hero-grid, .form-wrap, .grid-2, .grid-3, .stats{grid-template-columns:1fr}
}
@media (max-width: 760px){
  .nav-wrap{min-height:64px}
  .nav-links{display:none}
  .hero{padding-top:42px}
  .hero p.lead{font-size:1rem}
  .section{padding:28px 0}
}


.narrow{max-width:760px}
.center{text-align:center}
.center-text{margin-left:auto!important;margin-right:auto!important}
.hero-simple{padding:76px 0 44px}
.hero-simple h1{margin-left:auto;margin-right:auto}
.compact-grid{margin-top:18px}
.service-accent{position:relative; text-align:left; overflow:hidden}
.service-accent:before{content:""; position:absolute; inset:0 0 auto 0; height:6px; border-radius:18px 18px 0 0}
.service-build:before{background:linear-gradient(90deg,#244b73 0%, #6f92b8 100%)}
.service-review:before{background:linear-gradient(90deg,#4f7399 0%, #a9bfd4 100%)}
.service-accent h3{margin-top:10px}
.subtle-band{background:linear-gradient(180deg,#f7fbff 0%, #eef4f8 100%)}
.focus-list{max-width:680px; margin:18px auto 0; text-align:left; display:grid; gap:14px}
.focus-list p{margin:0; padding:16px 18px; background:#fff; border:1px solid var(--line); border-radius:16px; box-shadow:var(--shadow); color:var(--ink)}
.centered-card{max-width:720px; margin:0 auto; text-align:left}
.simple-form{max-width:680px; margin:0 auto; text-align:left}
.center-actions{justify-content:center}
.centered-footer{justify-content:center; text-align:center}
.centered-footer .footer-links{justify-content:center}
@media (max-width: 760px){
  .hero-simple{padding-top:56px}
  .service-accent,.focus-list p,.simple-form,.centered-card{box-shadow:0 8px 22px rgba(17,38,63,.06)}
}


#services, #about, #contact {
  scroll-margin-top: 92px;
}

@media (max-width: 760px){
  #services, #about, #contact {
    scroll-margin-top: 78px;
  }
}


.hero-content{max-width:760px;margin:0 auto;}
.hero-simple h1{max-width:none;margin-left:auto;margin-right:auto;}
.hero-simple p.lead{max-width:760px;}
@media (max-width:760px){
  .hero-simple{padding-top:52px;padding-bottom:34px;}
  .hero-content{max-width:100%;}
  .hero-simple h1{font-size:clamp(1.95rem, 9vw, 2.5rem); line-height:1.08;}
  .hero-simple p.lead{font-size:1rem; max-width:34ch;}
}


#services{position:relative;padding-top:42px;}
#services:before{
  content:"";
  position:absolute;
  top:0;
  left:50%;
  transform:translateX(-50%);
  width:min(1080px, calc(100% - 32px));
  height:1px;
  background:linear-gradient(90deg, rgba(216,226,234,0) 0%, rgba(216,226,234,.95) 6%, rgba(216,226,234,.95) 94%, rgba(216,226,234,0) 100%);
}
@media (max-width:760px){
  #services{padding-top:36px;}
  #services:before{width:calc(100% - 32px);}
}
