:root {
  --ink: #142326;
  --muted: #5d6f72;
  --line: #dfe8e8;
  --bg: #f6f8f4;
  --panel: #ffffff;
  --teal: #103b3f;
  --green: #23745f;
  --gold: #f0b84f;
  --cream: #fff8e8;
  --shadow: 0 18px 50px rgba(20, 35, 38, .14);
}
* { box-sizing: border-box; }
body { margin: 0; font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; color: var(--ink); background: var(--bg); }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.skip-link { position:absolute; left:-999px; top:0; background:#fff; padding:10px; z-index:50; }
.skip-link:focus { left:12px; }
.site-header { position: sticky; top: 0; z-index: 20; background: rgba(255,255,255,.94); border-bottom: 1px solid var(--line); backdrop-filter: blur(14px); }
.topbar { display:flex; justify-content:space-between; gap:24px; padding:8px clamp(18px,4vw,56px); color:#e9f6f2; background:var(--teal); font-size:14px; }
.topbar div { display:flex; gap:18px; }
.nav-shell { display:flex; align-items:center; gap:24px; padding:16px clamp(18px,4vw,56px); max-width:1240px; margin:auto; }
.brand { display:flex; align-items:center; gap:10px; font-weight:800; font-size:22px; }
.brand-mark { display:grid; place-items:center; width:38px; height:38px; border-radius:8px; background:var(--gold); color:#1f2a14; font-weight:900; }
.desktop-nav { display:flex; gap:22px; margin-left:auto; color:#31474a; font-weight:650; }
.desktop-nav a:hover, .mobile-nav a:hover { color: var(--green); }
.header-cta { padding:12px 18px; border-radius:8px; background:var(--teal); color:#fff; font-weight:800; }
.menu-toggle { display:none; margin-left:auto; background:none; border:0; width:42px; height:42px; }
.menu-toggle span { display:block; height:2px; background:var(--ink); margin:7px; }
.mobile-nav { display:none; padding:0 20px 20px; border-top:1px solid var(--line); }
.mobile-nav.open { display:grid; gap:14px; }
.section { padding: clamp(56px, 8vw, 100px) clamp(18px, 4vw, 56px); }
.inner { max-width:1180px; margin:0 auto; }
.hero { background: linear-gradient(135deg, #f6f8f4 0%, #e6f0ee 44%, #fff8e8 100%); padding-top:42px; }
.hero-grid { display:grid; grid-template-columns:minmax(0,1.02fr) minmax(380px,.8fr); gap:44px; align-items:center; }
.eyebrow { display:inline-flex; align-items:center; gap:8px; color:var(--green); font-weight:800; text-transform:uppercase; font-size:13px; letter-spacing:.08em; }
h1 { font-size: clamp(42px, 6vw, 76px); line-height:1.03; margin:16px 0 20px; letter-spacing:0; }
h2 { font-size: clamp(28px, 4vw, 44px); line-height:1.12; margin:0 0 16px; }
h3 { font-size:22px; margin:0 0 10px; }
p { color:var(--muted); line-height:1.7; }
.lead { font-size:20px; max-width:700px; }
.hero-points, .pill-row { display:flex; flex-wrap:wrap; gap:10px; padding:0; list-style:none; margin:28px 0; }
.hero-points li, .pill { border:1px solid rgba(16,59,63,.16); background:rgba(255,255,255,.72); border-radius:999px; padding:10px 14px; font-weight:750; color:#29484a; }
.btn { display:inline-flex; align-items:center; justify-content:center; border:0; border-radius:8px; min-height:46px; padding:12px 18px; font-weight:850; cursor:pointer; }
.btn-primary { background:var(--teal); color:#fff; box-shadow:0 10px 22px rgba(16,59,63,.2); }
.btn-ghost { background:#eef4f2; color:#214144; }
.btn-light { background:#fff; color:var(--teal); }
.button-row { display:flex; flex-wrap:wrap; gap:12px; margin-top:24px; }
.hero-image { margin-top:28px; border-radius:8px; box-shadow:var(--shadow); aspect-ratio:16/9; object-fit:cover; }
.lead-form { background:var(--panel); border:1px solid var(--line); border-radius:8px; padding:24px; box-shadow:var(--shadow); }
.form-head h2 { margin:6px 0 4px; font-size:28px; }
.form-head p { margin:0 0 18px; }
.progress-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:6px; list-style:none; padding:0; margin:0 0 20px; font-size:12px; color:#718184; }
.progress-steps li { border-bottom:3px solid #d9e3e2; padding-bottom:8px; text-align:center; }
.progress-steps li.active { color:var(--teal); border-color:var(--green); font-weight:800; }
.progress-steps li.done { color:var(--ink); border-color:var(--gold); }
.form-step { display:none; }
.form-step.active { display:block; }
.lead-form label { display:grid; gap:7px; margin:12px 0; font-size:13px; font-weight:750; color:#2a3e42; }
.lead-form input, .lead-form select, .lead-form textarea { width:100%; border:1px solid #cfdcda; border-radius:7px; min-height:48px; padding:12px; font:inherit; background:#fff; }
.lead-form textarea { resize:vertical; }
.form-row { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px; }
.form-row.thirds { grid-template-columns:repeat(3,minmax(0,1fr)); }
.service-choice { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-bottom:14px; }
.service-choice label { margin:0; }
.service-choice input { position:absolute; opacity:0; pointer-events:none; width:1px; min-height:1px; }
.service-choice span { min-height:96px; display:grid; place-items:center; text-align:center; border:1px solid #cfdcda; border-radius:8px; font-weight:850; background:#fbfdfc; }
.service-choice input:checked + span { border:3px solid var(--gold); background:#fff8e4; }
.check { display:flex !important; grid-template-columns:auto 1fr; align-items:center; gap:10px; font-weight:650 !important; }
.check input { width:auto; min-height:auto; }
.hp, .floor-field { display:none !important; }
.floor-field.show { display:grid !important; }
.form-actions { display:flex; justify-content:flex-end; gap:10px; margin-top:18px; }
.form-status { margin:10px 0 0; font-weight:800; color:var(--green); }
.split { display:grid; grid-template-columns: .9fr 1.1fr; gap:42px; align-items:start; }
.card-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:18px; }
.card { background:#fff; border:1px solid var(--line); border-radius:8px; padding:24px; box-shadow:0 8px 24px rgba(20,35,38,.06); }
.card-image { width:100%; aspect-ratio:16/9; object-fit:cover; border-radius:7px; margin:0 0 18px; }
.card a { color:var(--green); font-weight:850; }
.band { background:#fff; }
.dark-band { background:var(--teal); color:#fff; }
.dark-band p, .dark-band .muted { color:#d5e5e2; }
.dark-band .card { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.14); color:#fff; }
.article-shell { max-width:980px; margin:auto; padding:44px clamp(18px,4vw,56px) 80px; }
.article-hero { background:#fff; border:1px solid var(--line); border-radius:8px; padding:clamp(28px,5vw,54px); box-shadow:var(--shadow); }
.breadcrumb { display:flex; gap:8px; flex-wrap:wrap; font-size:14px; color:#607477; margin-bottom:18px; }
.content { margin-top:36px; background:#fff; border-radius:8px; border:1px solid var(--line); padding:clamp(24px,4vw,44px); }
.content h2 { font-size:30px; margin-top:32px; }
.related { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:28px; }
.author-row { display:flex; gap:12px; align-items:center; margin-top:22px; color:#56686b; }
.author-row img { width:48px; height:48px; object-fit:cover; border-radius:50%; background:#dfe8e8; }
.site-footer { background:#0b282b; color:#fff; padding:56px clamp(18px,4vw,56px) 24px; }
.footer-grid { max-width:1180px; margin:auto; display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:28px; }
.site-footer h2 { font-size:16px; margin:0 0 12px; }
.site-footer a { display:block; color:#e3efed; margin:8px 0; }
.site-footer p { color:#cfddda; }
.footer-small { font-size:14px; }
.footer-bottom { max-width:1180px; margin:32px auto 0; border-top:1px solid rgba(255,255,255,.16); padding-top:18px; color:#b8cbc7; }
@media (max-width: 920px) {
  .topbar { display:none; }
  .desktop-nav, .header-cta { display:none; }
  .menu-toggle { display:block; }
  .hero-grid, .split { grid-template-columns:1fr; }
  .hero { padding-top:18px; }
  .card-grid, .related, .footer-grid { grid-template-columns:1fr; }
}
@media (max-width: 620px) {
  .nav-shell { padding:13px 16px; }
  .brand { font-size:18px; }
  .brand-mark { width:34px; height:34px; }
  h1 { font-size:40px; }
  .service-choice, .form-row, .form-row.thirds { grid-template-columns:1fr; }
  .progress-steps { font-size:10px; }
  .lead-form { padding:18px; }
}
