:root {
  --ink: #172a3a;
  --deep: #203f56;
  --teal: #0f7c86;
  --teal-2: #2a8d90;
  --gold: #c69c45;
  --cream: #fbf8ef;
  --warm: #eef5f6;
  --line: rgba(23, 42, 58, .15);
  --muted: #5b6d76;
  --white: #fff;
  --shadow: 0 24px 70px rgba(23, 42, 58, .13);
  --sans: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --serif: Georgia, "Times New Roman", serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: linear-gradient(135deg, #ffffff, var(--cream) 54%, var(--warm));
  font-family: var(--sans);
  line-height: 1.58;
  overflow-x: hidden;
}
a { color: inherit; }
img { max-width: 100%; height: auto; }
.skip-link { position:absolute; left:-999px; top:8px; background:var(--ink); color:white; padding:8px 12px; z-index:999; }
.skip-link:focus { left:8px; }
.site-header { position:sticky; top:0; z-index:100; border-bottom:1px solid var(--line); background:rgba(255,255,255,.94); backdrop-filter:blur(16px); box-shadow:0 8px 28px rgba(23,42,58,.05); }
.utility { display:flex; align-items:center; gap:12px; max-width:1220px; margin:0 auto; padding:8px 20px; color:var(--muted); border-bottom:1px solid rgba(23,42,58,.09); font-size:12px; }
.utility span { margin-right:auto; color:var(--deep); font-weight:950; letter-spacing:.12em; text-transform:uppercase; }
.utility strong { color:var(--gold); letter-spacing:.1em; text-transform:uppercase; font-size:11px; }
.utility a { border:1px solid var(--line); border-radius:999px; padding:6px 10px; background:rgba(255,255,255,.76); text-decoration:none; font-weight:850; white-space:nowrap; }
.utility a[href^="tel"] { color:white; background:var(--ink); border-color:var(--ink); }
.nav { display:flex; align-items:center; gap:16px; max-width:1220px; min-height:76px; margin:0 auto; padding:12px 20px; }
.brand { display:flex; align-items:center; gap:12px; text-decoration:none; min-width:0; }
.brand img { width:56px; height:56px; flex:0 0 auto; }
.brand span { display:flex; flex-direction:column; line-height:1; min-width:0; }
.brand strong { font-family:var(--serif); font-size:28px; line-height:.94; }
.brand small { margin-top:7px; color:var(--teal); font-size:10px; font-weight:950; letter-spacing:.16em; text-transform:uppercase; }
.nav-actions { display:flex; margin-left:auto; align-items:center; gap:8px; }
.nav-actions a { min-height:44px; display:inline-flex; align-items:center; border-radius:999px; padding:0 15px; font-size:13px; font-weight:950; text-decoration:none; white-space:nowrap; }
.nav-call { color:white; background:var(--ink); }
.nav-ghost { border:1px solid var(--line); background:white; color:var(--deep); }
.hero { max-width:1220px; margin:0 auto; padding:64px 20px 44px; display:grid; grid-template-columns:minmax(0, 1.05fr) minmax(330px, .75fr); gap:42px; align-items:center; }
.eyebrow { margin:0 0 14px; color:var(--gold); font-size:12px; font-weight:950; letter-spacing:.18em; text-transform:uppercase; }
.eyebrow::after { content:""; display:block; width:52px; height:3px; margin-top:11px; border-radius:999px; background:var(--gold); }
.eyebrow.dark { color:var(--teal); }
h1, h2, h3, p { margin-top:0; }
h1 { max-width:860px; margin-bottom:20px; font-family:var(--serif); font-size:72px; line-height:.92; color:var(--ink); }
h2 { margin-bottom:16px; font-family:var(--serif); font-size:46px; line-height:.98; color:var(--ink); }
h3 { margin-bottom:10px; font-family:var(--serif); font-size:26px; line-height:1.04; color:var(--deep); }
.hero-text, .section-head p, .handoff p, .keyword-ledger p, .cta p { color:var(--muted); font-size:20px; line-height:1.48; }
.hero-actions { display:flex; flex-wrap:wrap; gap:10px; margin-top:26px; }
.hero-actions.centered { justify-content:center; }
.btn { min-height:56px; display:inline-flex; align-items:center; justify-content:center; border:2px solid transparent; border-radius:999px; padding:0 18px; text-decoration:none; font-weight:950; text-align:center; }
.btn-primary { background:var(--ink); color:white; }
.btn-secondary { background:white; border-color:var(--line); color:var(--ink); }
.btn-call { background:#dfeff0; border-color:#bed9dc; color:var(--ink); }
.hero-panel { border:1px solid var(--line); border-radius:24px; background:linear-gradient(145deg, white, #edf5f6); padding:28px; box-shadow:var(--shadow); }
.hero-panel img { display:block; width:min(220px, 70%); margin:0 auto 18px; border-radius:20px; background:white; }
.panel-kicker { margin:8px 0 8px; color:var(--teal); font-size:12px; font-weight:950; letter-spacing:.16em; text-transform:uppercase; }
.hero-panel h2 { font-size:30px; }
.hero-panel p { color:var(--muted); }
.handoff { max-width:1220px; margin:0 auto 28px; padding:28px; display:grid; grid-template-columns:minmax(0, 1fr) minmax(280px, .35fr); gap:20px; align-items:center; border:1px solid var(--line); border-radius:24px; background:linear-gradient(135deg, #fff 0%, #f3f8fa 100%); box-shadow:0 16px 46px rgba(23,42,58,.08); }
.handoff-actions { display:grid; gap:10px; }
.band { padding:58px 20px; }
.band.soft { background:rgba(255,255,255,.52); border-block:1px solid rgba(23,42,58,.08); }
.section-head, .keyword-ledger > div { max-width:1120px; margin:0 auto 28px; }
.card-grid { max-width:1120px; margin:0 auto; display:grid; grid-template-columns:repeat(4, minmax(0, 1fr)); gap:14px; align-items:stretch; }
.card { min-height:285px; border:1px solid var(--line); border-radius:8px; padding:22px; background:rgba(255,255,255,.88); box-shadow:0 14px 38px rgba(23,42,58,.075); }
.card p { color:var(--muted); }
.keyword-cloud { max-width:1120px; margin:0 auto; display:flex; flex-wrap:wrap; gap:9px; }
.keyword-cloud span { border:1px solid var(--line); border-radius:999px; background:white; padding:10px 13px; color:var(--deep); font-size:14px; font-weight:900; }
.keyword-ledger { padding:52px 20px; background:#e8f0f2; }
.keyword-ledger > div { margin-bottom:0; border:1px solid var(--line); border-radius:24px; background:rgba(255,255,255,.76); padding:28px; }
.cta { padding:68px 20px; text-align:center; color:white; background:linear-gradient(135deg, #172a3a, #0f5d67 58%, #806b38); }
.cta h2 { max-width:900px; margin-left:auto; margin-right:auto; color:white; }
.cta p { max-width:820px; margin-left:auto; margin-right:auto; color:rgba(255,255,255,.8); }
.cta .btn-secondary { color:white; background:transparent; border-color:rgba(255,255,255,.38); }
.footer { padding:44px 20px 90px; color:rgba(255,255,255,.76); background:#172a3a; }
.footer-grid { max-width:1120px; margin:0 auto; display:grid; grid-template-columns:1.2fr .8fr .8fr; gap:26px; }
.footer h2, .footer h3 { color:white; }
.footer h2 { margin-bottom:12px; font-family:var(--serif); font-size:32px; }
.footer h3 { margin-bottom:12px; font-size:13px; letter-spacing:.15em; text-transform:uppercase; }
.footer a, .footer span { display:block; color:rgba(255,255,255,.82); margin:7px 0; }
.footer .fine { color:rgba(255,255,255,.56); font-size:12px; }
.footer-bottom { max-width:1120px; margin:28px auto 0; padding-top:18px; border-top:1px solid rgba(255,255,255,.12); display:grid; grid-template-columns:1fr 1fr; gap:10px; color:rgba(255,255,255,.56); font-size:12px; }
.sticky-actions { position:fixed; left:0; right:0; bottom:0; z-index:140; display:none; gap:8px; padding:9px; border-top:1px solid var(--line); background:rgba(255,255,255,.94); backdrop-filter:blur(14px); box-shadow:0 -12px 34px rgba(23,42,58,.16); }
.sticky-actions a { flex:1; min-height:46px; display:grid; place-items:center; border-radius:12px; background:var(--ink); color:white; text-decoration:none; font-weight:950; }
.sticky-actions a:nth-child(2), .sticky-actions a:nth-child(3) { background:white; color:var(--ink); border:1px solid var(--line); }
@media (max-width:1080px) {
  h1 { font-size:56px; }
  h2 { font-size:38px; }
  .hero, .handoff, .footer-grid { grid-template-columns:1fr; }
  .card-grid { grid-template-columns:repeat(2, minmax(0, 1fr)); }
}
@media (max-width:680px) {
  .utility strong, .utility span { display:none; }
  .utility { justify-content:center; flex-wrap:wrap; gap:8px; }
  .utility a[href^="tel"], .utility a[href^="mailto"] { width:100%; text-align:center; }
  .nav { min-height:70px; padding:10px 16px; }
  .brand strong { font-size:22px; }
  .brand small { font-size:8px; }
  .brand img { width:48px; height:48px; }
  .nav-actions { display:none; }
  .hero { padding:36px 16px 30px; gap:22px; }
  h1 { font-size:42px; line-height:.98; }
  h2 { font-size:31px; }
  .hero-text, .section-head p, .handoff p, .keyword-ledger p, .cta p { font-size:17px; }
  .hero-actions .btn { width:100%; }
  .handoff { margin:0 16px 20px; padding:20px; border-radius:18px; }
  .band, .keyword-ledger, .cta { padding-left:16px; padding-right:16px; }
  .card-grid { grid-template-columns:1fr; }
  .card { min-height:0; }
  .footer { padding:38px 16px 92px; }
  .footer-bottom { grid-template-columns:1fr; }
  .sticky-actions { display:flex; }
}
