:root {
  --bg:#d8e3f5;
  --surface:#edf3fb;
  --surface-2:#d7e4f6;
  --text:#1f2d4a;
  --muted:#56657f;
  --line:#bfd0e6;
  --blue:#3f74d8;
  --purple:#3f74d8;
  --blue-dark:#173a78;
  --btn-bg:#173a78;
  --btn-bg-hover:#5f86ea;
  --btn-text:#ffffff;
  --shadow:0 18px 40px rgba(62,66,114,.12)
}
* {
  box-sizing:border-box
}
html {
  scroll-behavior:smooth
}
[id] {
  scroll-margin-top: 110px;
}
@media (max-width: 920px) {
  [id] {
    scroll-margin-top: 92px;
  }
}
body {
  margin:0;
  font-family:Arial,Helvetica,sans-serif;
  background:linear-gradient(180deg,#eaf2fb 0%,#dce9f8 100%);
  color:var(--text);
  line-height:1.6
}


html, body {
  overflow-x: clip;
}

@supports not (overflow: clip) {
  html, body {
    overflow-x: hidden;
  }
}
a {
  color:inherit;
  text-decoration:none
}
img {
  max-width:100%;
  display:block
}
.container {
  width:min(1120px,calc(100% - 32px));
  margin:0 auto
}
header {
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(237,243,251,.94);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line)
}
.nav {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  padding:14px 0
}
.brand {
  font-weight:800;
  font-size:.98rem;
  min-height:50px;
  font-size:1.5rem;
  letter-spacing:-.03em
}
.brand small {
  display:block;
  font-size:.72rem;
  color:var(--blue-dark);
  letter-spacing:.2em;
  text-transform:uppercase;
  margin-top:2px
}
.nav-links {
  display:flex;
  gap:20px;
  flex-wrap:wrap;
  color:var(--muted);
  font-size:.95rem
}
.nav-links a:hover {
  color:var(--purple)
}
.btn,button {
  display:inline-block;
  border:none;
  cursor:pointer;
  background-color:var(--btn-bg);
  color:var(--btn-text);
  padding:13px 20px;
  border-radius:999px;
  font-weight:700;
  box-shadow:var(--shadow);
  transition:background-color .65s ease, color .65s ease, transform .65s ease, border-color .65s ease, box-shadow .65s ease;
  will-change:background-color,color,transform
}
.btn.secondary {
  background:var(--surface);
  color:var(--text);
  border:1px solid var(--line);
  box-shadow:none
}
.hero {
  padding:72px 0 40px
}
.hero-grid {
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:32px;
  align-items:center
}
.badge {
  display:inline-block;
  padding:8px 12px;
  border-radius:999px;
  background:linear-gradient(135deg,rgba(79,111,217,.12),rgba(23,58,120,.10));
  border:1px solid rgba(23,58,120,.16);
  color:var(--blue-dark);
  text-transform:uppercase;
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.18em
}
h1,h2,h3 {
  line-height:1.08;
  letter-spacing:-.03em;
  margin:0 0 12px
}
h1 {
  font-size:clamp(2.4rem,6vw,4.5rem)
}
h2 {
  font-size:clamp(1.9rem,4.4vw,3rem)
}
h3 {
  font-size:1.4rem
}
.lead {
  font-size:1.08rem;
  color:var(--muted)
}
.hero-actions {
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:24px
}
.hero-actions-centered {
  justify-content:center;
}
.card-grid {
  display:grid;
  gap:22px
}
.card-grid.four {
  grid-template-columns:repeat(4,1fr)
}
.card-grid.three {
  grid-template-columns:repeat(3,1fr)
}
.card-grid.two {
  grid-template-columns:repeat(2,1fr)
}
.card {
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:28px;
  padding:24px;
  box-shadow:var(--shadow)
}
.card img {
  border-radius:20px;
  margin-bottom:16px;
  border:1px solid var(--line)
}
.section {
  padding:44px 0
}
.section.alt {
  background:linear-gradient(180deg,rgba(207,224,246,.96),rgba(190,211,239,.99));
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line)
}
.eyebrow {
  color:var(--blue-dark);
  font-weight:800;
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin-bottom:10px
}
.checklist {
  padding:0;
  margin:18px 0 0;
  list-style:none
}
.checklist li {
  padding:10px 0 10px 26px;
  position:relative;
  border-bottom:1px solid rgba(23,58,120,0.10)
}
.checklist li:before {
  content:"✓";
  position:absolute;
  left:0;
  color:var(--blue-dark);
  font-weight:700
}
.split {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:26px;
  align-items:start
}

/* Keep paired About page cards visually balanced */
.about-balanced-cards {
  align-items: stretch;
}

.about-balanced-cards > .about-section-card {
  height: 100%;
}
.banner {
  background:linear-gradient(135deg,rgba(79,111,217,.14),rgba(23,58,120,.10));
  border:1px solid var(--line);
  border-radius:30px;
  padding:28px
}
.kicker {
  color:var(--blue-dark);
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.75rem
}
.muted {
  color:var(--muted)
}
footer {
  padding:38px 0 50px;
  color:var(--muted)
}
.footer-grid {
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:20px
}
.input,textarea,select {
  width:100%;
  padding:13px 14px;
  border-radius:14px;
  border:1px solid var(--line);
  background:var(--surface);
  color:var(--text)
}
form {
  display:grid;
  gap:14px
}
label {
  font-weight:700;
  font-size:.95rem
}
.small {
  font-size:.92rem
}
.menu-toggle {
  display:none;
  width:48px;
  height:48px;
  border:1px solid var(--line);
  background:var(--surface);
  border-radius:14px;
  padding:0;
  box-shadow:none;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px
}
.menu-toggle span {
  display:block;
  width:20px;
  height:2px;
  background:var(--text);
  border-radius:999px
}
.table-wrap {
  overflow:auto
}
.pricing-table {
  width:100%;
  border-collapse:collapse;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  box-shadow:var(--shadow)
}
.pricing-table th,.pricing-table td {
  padding:14px 16px;
  text-align:left;
  vertical-align:top;
  border-bottom:1px solid rgba(23,58,120,0.10)
}
.pricing-table th {
  background:#e8f0fa;
  font-size:.95rem
}
.pricing-table tr:last-child td {
  border-bottom:none
}
.note {
  background:#eef4fb;
  border:1px solid #bfd0e6;
  border-radius:18px;
  padding:16px 18px;
  color:#274c87
}
.brand {
  display:inline-flex;
  align-items:center;
  gap:12px;
  min-width:0
}
.brand-mark {
  width:auto;
  height:48px;
  max-width:min(220px,38vw);
  object-fit:contain;
  flex:0 0 auto
}
.brand-text {
  display:flex;
  flex-direction:column;
  min-width:0
}
.about-side-card {
  text-align:center
}
.about-card-logo {
  width:100%;
  max-width:100%;
  max-height:100%;
  height:auto;
  object-fit:contain;
  margin:0 auto 16px
}
@media (max-width:920px) {
  .hero-grid,.split,.footer-grid,.card-grid.four,.card-grid.three,.card-grid.two {
    grid-template-columns:1fr
  }
  .menu-toggle {
    display:flex
  }
  .nav {
    position:relative;
    align-items:flex-start;
    flex-wrap:wrap
  }
  .brand {
    max-width:calc(100% - 68px)
  }
  .brand-mark {
    height:42px;
    max-width:min(180px,46vw)
  }
  .nav-links {
    display:none;
    width:100%;
    flex-direction:column;
    gap:0;
    background:var(--surface);
    border:1px solid var(--line);
    border-radius:18px;
    padding:10px 0;
    box-shadow:var(--shadow)
  }
  .nav-links a {
    display:block;
    padding:12px 16px
  }
  .nav-links.open {
    display:flex
  }
}
.about-hero-grid,.hero-grid.hero-grid-service {
  align-items:start
}
.about-hero-grid {
  grid-template-columns:minmax(0,1.25fr) minmax(280px,420px)
}
.hero-grid.hero-grid-service {
  grid-template-columns:minmax(0,1.3fr) minmax(300px,420px)
}
.about-side-card,.hero-promo-card,.section-lead-card,.about-section-card {
  padding:22px
}
.about-section-card,.section-lead-card {
  padding:24px
}
.hero-left-stack {
  display:grid;
  gap:18px;
  align-content:start
}
.hero-good-fit-inline {
  max-width:720px
}
.hero-good-fit-inline h3 {
  margin-bottom:10px
}
.hero-good-fit-inline .checklist {
  margin-bottom:0
}
.about-list-two-col,.checklist.checklist-two-col {
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px 22px
}
.checklist.checklist-three-col {
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px 22px
}
.about-list-two-col li,.checklist.checklist-two-col li,.checklist.checklist-three-col li {
  margin:0
}

.section-inline-card {
  margin:20px 0 22px
}

.inline-note-card {
  padding:18px 20px
}
.contact-options {
  display:grid;
  gap:14px
}
.contact-cta-list {
  margin:10px 0 0;
  padding-left:18px;
  color:var(--muted)
}
.contact-cta-list li {
  margin:6px 0
}
@media (max-width:980px) {
  .about-hero-grid,.hero-grid.hero-grid-service {
    grid-template-columns:1fr
  }
}
@media (max-width:720px) {
  .about-list-two-col,.checklist.checklist-two-col,.checklist.checklist-three-col {
    grid-template-columns:1fr
  }
}
/* Blog article pages */
.article-hero {
  background: linear-gradient(135deg, rgba(44,85,88,.96), rgba(106,127,95,.92));
  color: #fff;
}
.article-hero .eyebrow,
.article-hero h1,
.article-hero p,
.article-hero .hero-copy,
.article-hero .hero-copy p {
  color: #fff;
}
.article-hero .hero-grid {
  align-items: center;
}
.article-meta {
  color: rgba(255,255,255,.86);
  font-size: .96rem;
  margin-top: 12px;
}
.article-panel {
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 22px;
  padding: 22px;
  backdrop-filter: blur(6px);
}
.article-shell {
  max-width: 1180px;
  margin: 0 auto;
  padding: 36px 20px 70px;
}
.article-layout {
  display: grid;
  gap: 1.5rem;
}
.article-card,
.article-callout,
.article-note,
.article-table-wrap,
.quick-takeaway {
  background: #fff;
  border: 1px solid rgba(44,85,88,.08);
  border-radius: 20px;
  box-shadow: 0 14px 32px rgba(44,85,88,.08);
}
.article-card {
  background: #fff;
  border: 1px solid #d8e2da;
  border-radius: 24px;
  padding: 34px;
  box-shadow: 0 16px 40px rgba(31,42,36,.05);
}
.article-card h2 {
  margin-top: 38px;
  margin-bottom: 12px;
}
.article-card h3 {
  margin-top: 26px;
  margin-bottom: 8px;
}
.article-card p,
.article-card li {
  color: #4f5d54;
}
.article-card ul,
.quick-takeaway ul,
.article-note ul {
  margin: 0;
  padding-left: 1.2rem;
}
.article-card ul {
  padding-left: 20px;
}
.back-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  font-weight: 700;
  margin-bottom: 18px;
}
.lead-copy {
  font-size: 1.08rem;
  color: #445248;
}
.callout,
.article-callout {
  background: #eef5f0;
  border-left: 5px solid #3e6f73;
  border-radius: 18px;
  padding: 18px 20px;
  margin: 22px 0;
}
.table-wrap,
.article-table-wrap {
  overflow-x: auto;
  margin: 18px 0;
}
.article-table {
  width: 100%;
  min-width: 760px;
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
  border: 1px solid #d8e2da;
  border-radius: 18px;
}
.article-table th,
.article-table td {
  padding: 14px 16px;
  text-align: left;
  vertical-align: top;
  border-bottom: 1px solid #e6edf5;
}
.article-table th {
  background: #e8eeea;
  color: #2c5558;
  font-weight: 700;
}
.article-table tr:last-child td {
  border-bottom: none;
}
.note-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  margin-top: 18px;
}
.note-box,
.article-note {
  border: 1px solid #d8e2da;
  border-radius: 20px;
  background: #f7faf7;
  padding: 18px;
}
.quick-takeaway h2,
.article-card h2,
.article-callout h2,
.article-note h3 {
  color: #2c5558;
}
.cta-box,
.article-cta {
  margin-top: 34px;
  border: 1px solid #d8e2da;
  border-radius: 22px;
  background: linear-gradient(135deg, #eef5f0, #f2f6ee);
  padding: 24px;
}
.cta-box .hero-actions {
  margin-top: 16px;
}
@media (max-width: 920px) {
  .note-grid {
    grid-template-columns: 1fr;
  }
  .article-card {
    padding: 24px;
  }
}
/* Test and tag article image gallery */
.image-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
  margin: 1rem 0 2rem;
  align-items: start;
}
.image-card {
  margin: 0;
}
.image-link {
  display: block;
  text-decoration: none;
  color: inherit;
}
.image-media {
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid rgba(44,85,88,.10);
  background: #eef2ee;
  box-shadow: 0 14px 32px rgba(44,85,88,.08);
}
.image-media img {
  display: block;
  width: 100%;
  height: auto;
}
.image-overlay {
  position: absolute;
  inset: auto 0 0 0;
  padding: .9rem 1rem;
  background: linear-gradient(180deg, rgba(44,85,88,0) 0%, rgba(44,85,88,.88) 100%);
  color: #fff;
  font-size: .95rem;
  line-height: 1.45;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .2s ease, transform .2s ease;
}
.image-link:hover .image-overlay,
.image-link:focus .image-overlay,
.image-link:focus-visible .image-overlay {
  opacity: 1;
  transform: translateY(0);
}
.image-link:focus-visible {
  outline: 3px solid rgba(62,111,115,.40);
  outline-offset: 4px;
  border-radius: 18px;
}
.image-card figcaption {
  margin-top: .75rem;
  color: #4a5b50;
  font-size: .95rem;
  line-height: 1.5;
}
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
@media (max-width: 700px) {
  .article-shell {
    padding: 2rem 0;
  }
  .article-card,
  .article-callout,
  .article-note,
  .quick-takeaway,
  .article-cta {
    padding: 1.2rem;
  }
}
.brand {
  font-weight:800;
  font-size:1.5rem;
  letter-spacing:-.03em;
}
.brand-text-logo-only {
  align-items:flex-start;
  gap:0;
}
.brand-text-logo-only .brand-mark {
  height:86px;
  max-width:min(420px,46vw);
}
@media (max-width:920px) {
  .brand-text-logo-only .brand-mark {
    height:64px;
    max-width:min(300px,68vw);
  }
}


.pricing-group {
  margin-top:24px;
  padding:24px;
  border:1px solid var(--line);
  border-radius:28px;
  background:rgba(255,255,255,.34)
}
.pricing-group-primary {
  background:rgba(255,255,255,.5)
}
.pricing-group-header {
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px,420px);
  gap:22px;
  align-items:end;
  margin-bottom:18px
}
.pricing-group-header h3 {
  margin-bottom:0
}
.pricing-group-header .muted {
  margin:0
}
@media (max-width: 900px) {
  .pricing-group-header {
    grid-template-columns:1fr;
    align-items:start
  }
}


/* Enhanced main menu styling */
.site-nav a,
.main-nav a,
.primary-nav a,
.nav-links a,
.menu a,
.site-header nav a,
.header-nav a,
nav a {
  font-size: 1.06rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.site-nav a,
.main-nav a,
.primary-nav a,
.nav-links a,
.menu a,
.site-header nav a,
.header-nav a {
  transition: transform 0.18s ease, opacity 0.18s ease, color 0.18s ease;
}

.site-nav a:hover,
.main-nav a:hover,
.primary-nav a:hover,
.nav-links a:hover,
.menu a:hover,
.site-header nav a:hover,
.header-nav a:hover {
  transform: translateY(-1px);
  opacity: 0.96;
}

@media (max-width: 768px) {
  .site-nav a,
  .main-nav a,
  .primary-nav a,
  .nav-links a,
  .menu a,
  .site-header nav a,
  .header-nav a,
  nav a {
    font-size: 1rem;
  }
}



.hero-brandline {
  margin: 0.9rem 0 0;
  font-size: 0.95rem;
  line-height: 1.4;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.85;
}

@media (max-width: 768px) {
  .hero-brandline {
    font-size: 0.86rem;
    margin-top: 0.75rem;
  }
}


/* Home page simplified hero */
.hero-content-only {
  display: block;
}

.hero-content-only > div:first-child {
  max-width: 760px;
}


/* Home hero visual refresh */
.hero-centered.hero-home-refresh {
  position: relative;
  padding: 5.5rem 0 4.75rem;
  overflow: hidden;
}

.hero-centered.hero-home-refresh::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at top left, rgba(117, 90, 255, 0.16), transparent 34%),
    radial-gradient(circle at top right, rgba(75, 140, 255, 0.16), transparent 32%),
    radial-gradient(circle at bottom center, rgba(255, 255, 255, 0.04), transparent 28%);
  pointer-events: none;
}

.hero-centered-inner {
  position: relative;
  max-width: 860px;
  margin: 0 auto;
  text-align: center;
}

.hero-kicker {
  display: inline-block;
  margin: 0 0 1rem;
  padding: 0.55rem 1rem;
  border-radius: 999px;
  font-size: 0.86rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: rgba(255, 255, 255, 0.08);
}

.hero-home-refresh h1 {
  max-width: 12ch;
  margin: 0 auto 1.1rem;
  font-size: clamp(2.4rem, 5vw, 4.4rem);
  line-height: 1.05;
}

.hero-home-refresh .hero-intro {
  max-width: 760px;
  margin: 0 auto;
  font-size: 1.08rem;
  line-height: 1.7;
}

.hero-home-refresh .hero-actions {
  display: flex;
  justify-content: center;
  gap: 0.9rem;
  flex-wrap: wrap;
  margin-top: 1.6rem;
}

.hero-home-refresh .hero-points {
  display: flex;
  justify-content: center;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-top: 1.5rem;
}

.hero-home-refresh .hero-points span {
  display: inline-flex;
  align-items: center;
  padding: 0.55rem 0.9rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  font-size: 0.94rem;
}

@media (max-width: 768px) {
  .hero-centered.hero-home-refresh {
    padding: 4.5rem 0 4rem;
  }

  .hero-home-refresh h1 {
    max-width: 100%;
  }

  .hero-home-refresh .hero-intro {
    font-size: 1rem;
  }

  .hero-home-refresh .hero-points span {
    font-size: 0.9rem;
  }
}


/* Wider home hero override */
.hero-centered.hero-home-refresh {
  padding: 6rem 0 5rem;
}

.hero-centered-inner {
  max-width: 1280px;
}

.hero-home-refresh h1 {
  max-width: 18ch;
}

.hero-home-refresh .hero-intro {
  max-width: 1100px;
}

.hero-kicker {
  font-size: 1.12rem;
  padding: 0.8rem 1.35rem;
  margin: 0 0 1.35rem;
}

@media (max-width: 768px) {
  .hero-centered.hero-home-refresh {
    padding: 4.75rem 0 4rem;
  }

  .hero-centered-inner,
  .hero-home-refresh .hero-intro,
  .hero-home-refresh h1 {
    max-width: 100%;
  }

  .hero-kicker {
    font-size: 0.98rem;
  }
}


/* Tighter home hero spacing */
.hero-centered.hero-home-refresh {
  padding: 3rem 0 2.4rem;
}

.hero-home-refresh h1 {
  max-width: 10.5ch;
}

@media (max-width: 768px) {
  .hero-centered.hero-home-refresh {
    padding: 2.25rem 0 2rem;
  }

  .hero-home-refresh h1 {
    max-width: 11ch;
  }
}


/* Hero width and spacing correction */
.hero-centered.hero-home-refresh {
  padding: 2rem 0 1.5rem;
}

.hero-centered-inner {
  max-width: 1400px;
}

.hero-home-refresh .hero-intro {
  max-width: 1200px;
}

.hero-home-refresh h1 {
  max-width: 13ch;
}

@media (max-width: 768px) {
  .hero-centered.hero-home-refresh {
    padding: 1.5rem 0 1.25rem;
  }

  .hero-centered-inner,
  .hero-home-refresh .hero-intro,
  .hero-home-refresh h1 {
    max-width: 100%;
  }
}


/* Hero heading width expansion */
.hero-home-refresh h1 {
  max-width: 24ch;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 768px) {
  .hero-home-refresh h1 {
    max-width: 100%;
  }
}


/* Full header blue override */
header,
.site-header,
.header,
.header-wrap,
.header-inner,
.site-topbar,
.topbar,
.navbar,
.navbar-wrap,
.navbar-inner,
.site-header .container,
header .container,
.header .container {
  background: #4f6fd9 !important;
}

header *,
.site-header *,
.header *,
.navbar * {
  border-color: rgba(255, 255, 255, 0.18);
}

header a,
.site-header a,
.header a,
.navbar a,
.site-nav a,
.main-nav a,
.primary-nav a,
.nav-links a,
.menu a,
.mobile-menu a {
  color: #f5f7fb !important;
}

header a:hover,
.site-header a:hover,
.header a:hover,
.navbar a:hover,
.site-nav a:hover,
.main-nav a:hover,
.primary-nav a:hover,
.nav-links a:hover,
.menu a:hover,
.mobile-menu a:hover {
  color: #ffffff !important;
  opacity: 1 !important;
}

header button,
.site-header button,
.header button,
.navbar button,
.menu-toggle {
  color: #f5f7fb !important;
  background: transparent !important;
  border-color: rgba(245, 247, 251, 0.35) !important;
}

header svg,
.site-header svg,
.header svg,
.navbar svg,
.menu-toggle svg {
  stroke: #f5f7fb !important;
  fill: currentColor;
}

@media (max-width: 768px) {
  header,
  .site-header,
  .header,
  .header-wrap,
  .header-inner,
  .site-topbar,
  .topbar,
  .navbar,
  .navbar-wrap,
  .navbar-inner,
  .site-header .container,
  header .container,
  .header .container,
  .site-nav,
  .main-nav,
  .primary-nav,
  .nav-links,
  .menu,
  .mobile-menu,
  .site-header nav,
  header nav,
  .header nav {
    background: #4f6fd9 !important;
  }
}



.nav-links {
  align-items:center;
}
.nav-item {
  position:relative;
  display:flex;
  align-items:center;
}
.nav-link {
  display:inline-flex;
  align-items:center;
  padding:10px 6px;
}
.has-submenu > .nav-link::after {
  content:'▾';
  font-size:.72rem;
  margin-left:6px;
  opacity:.75;
}
.submenu {
  display:none;
  position:absolute;
  top:100%;
  left:0;
  min-width:220px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:16px;
  padding:8px 0;
  box-shadow:var(--shadow);
  z-index:150;
}
.submenu a {
  display:block;
  padding:10px 14px;
  white-space:nowrap;
  color:var(--blue-dark);
  font-weight:600;
}
.submenu a:hover {
  background:rgba(23,58,120,.06);
  color:var(--blue-dark);
}
.submenu::before {
  content:'';
  position:absolute;
  left:0;
  right:0;
  top:-10px;
  height:10px;
}
.has-submenu:hover .submenu,
.has-submenu:focus-within .submenu,
.has-submenu.open .submenu {
  display:block;
}
footer {
  background:#173a78;
  color:#eaf2fb;
  border-top:1px solid rgba(255,255,255,.08);
}
footer a, footer .brand small {
  color:#dbe9ff;
}
@media (max-width:920px) {
  .nav-links {
    align-items:stretch;
  }
  .nav-item {
    width:100%;
  }
  .nav-link {
    display:flex;
    justify-content:space-between;
    width:100%;
    padding:12px 16px;
  }
  .submenu {
    position:static;
    min-width:0;
    border:none;
    border-top:1px solid var(--line);
    border-radius:0;
    box-shadow:none;
    background:rgba(23,58,120,.04);
    padding:6px 0 8px;
  }
  .submenu a {
    padding:10px 28px;
    white-space:normal;
  }
  .has-submenu:hover .submenu,
  .has-submenu:focus-within .submenu {
    display:none;
  }
  .has-submenu.open .submenu {
    display:block;
  }
}

/* Submenu text contrast fix */
header .submenu a,
.site-header .submenu a,
.navbar .submenu a,
.nav-links .submenu a,
.submenu a {
  color: #173a78 !important;
}
header .submenu a:hover,
.site-header .submenu a:hover,
.navbar .submenu a:hover,
.nav-links .submenu a:hover,
.submenu a:hover {
  color: #173a78 !important;
}


/* Mobile hamburger menu text contrast fix */
@media (max-width: 920px) {
  .nav-links,
  #site-menu,
  header .nav-links,
  .site-header .nav-links {
    background: #ffffff !important;
    border-color: rgba(23, 58, 120, 0.12) !important;
  }

  header .nav-links > .nav-link,
  header .nav-links .nav-item > .nav-link,
  .site-header .nav-links > .nav-link,
  .site-header .nav-links .nav-item > .nav-link,
  .nav-links > .nav-link,
  .nav-links .nav-item > .nav-link,
  .nav-links a {
    color: #173a78 !important;
  }

  header .nav-links > .nav-link:hover,
  header .nav-links .nav-item > .nav-link:hover,
  .site-header .nav-links > .nav-link:hover,
  .site-header .nav-links .nav-item > .nav-link:hover,
  .nav-links > .nav-link:hover,
  .nav-links .nav-item > .nav-link:hover,
  .nav-links a:hover {
    color: #173a78 !important;
    background: rgba(23, 58, 120, 0.06) !important;
  }

  .has-submenu > .nav-link::after {
    color: #173a78 !important;
    opacity: 0.85;
  }

  .submenu {
    background: rgba(23, 58, 120, 0.04) !important;
  }
}


/* Mobile submenu behaviour fix */
@media (max-width: 920px) {
  .has-submenu > .nav-link {
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
  }

  .has-submenu.open > .nav-link {
    background: rgba(23, 58, 120, 0.08) !important;
  }
}



.services-modern {
  position: relative;
  margin-top: -20px;
  padding-top: 64px;
  padding-bottom: 52px;
  overflow: hidden;
  border-top-left-radius: 34px;
  border-top-right-radius: 34px;
  background:
    linear-gradient(180deg, #e5eefb 0%, #dbe8f8 48%, #d4e2f5 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.78);
}
.services-modern::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at top left, rgba(79, 111, 217, 0.18), transparent 42%),
    radial-gradient(circle at 85% 18%, rgba(23, 58, 120, 0.10), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,0.42), rgba(255,255,255,0.10) 45%, rgba(255,255,255,0.02) 100%);
  pointer-events: none;
}
.services-modern .container {
  position: relative;
  z-index: 1;
}
.services-intro-stack {
  margin-bottom: 34px;
  max-width: none;
  text-align: center;
}
.services-intro-stack h2 {
  margin: 0 0 14px;
  text-align: center;
}
.services-modern h2 {
  margin-bottom: 0;
}
.services-intro {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
}
.services-columns {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 34px;
  align-items: start;
}
.services-columns-modern {
  position: relative;
}
.services-columns-modern::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(79, 111, 217, 0.28), rgba(23, 58, 120, 0.08));
}
.service-column {
  position: relative;
  padding: 28px 20px 0;
  text-align: center;
}
.service-column::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  width: 72px;
  height: 3px;
  border-radius: 999px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, #4f6fd9, rgba(79, 111, 217, 0.25));
}
.service-column + .service-column {
  border-left: 1px solid rgba(23, 58, 120, 0.10);
  padding-left: 20px;
}
.service-column h3 {
  margin-bottom: 12px;
  font-size: clamp(1.25rem, 2.2vw, 1.7rem);
  line-height: 1.08;
  color: #173a78;
}
.service-column p {
  margin: 0 auto 16px;
  max-width: 28ch;
}
.service-scope {
  font-size: .92rem;
  color: var(--muted);
}
.service-btn {
  margin-top: 10px;
}

.home-alt-blue {
  background: linear-gradient(180deg, rgba(226,236,249,0.92), rgba(213,226,244,0.96));
  border-top: 1px solid rgba(23, 58, 120, 0.10);
  border-bottom: 1px solid rgba(23, 58, 120, 0.10);
}
.home-alt-blue .card {
  background: linear-gradient(180deg, rgba(244,248,253,0.98), rgba(233,241,251,0.98));
  border-color: rgba(23, 58, 120, 0.12);
}
.home-alt-blue .checklist li {
  border-bottom: 1px solid rgba(23, 58, 120, 0.10);
}
.home-alt-blue .eyebrow {
  color: #173a78;
}
.home-alt-blue .muted,
.home-alt-blue .lead,
.home-alt-blue .contact-cta-list {
  color: #50627d;
}
@media (max-width: 980px) {
  .services-intro-stack {
    margin-bottom: 28px;
  }
  .services-intro {
    max-width: none;
  }
}
@media (max-width: 860px) {
  .services-columns {
    grid-template-columns: 1fr;
    gap: 26px;
  }
  .service-column {
    padding-right: 0;
    padding-bottom: 8px;
  }
  .service-column + .service-column {
    border-left: 0;
    border-top: 1px solid rgba(23, 58, 120, 0.10);
    padding-left: 0;
    padding-top: 28px;
  }
  .service-column p {
    max-width: 48ch;
  }
}


/* Final navigation, button and footer overrides */
header .container.nav {
  width:min(1320px,calc(100% - 32px));
}

.nav {
  gap:28px;
}

.nav-links {
  gap:14px;
  margin-left:auto;
  align-items:center;
}

.nav-link {
  padding:12px 10px;
  border-radius:999px;
}

.nav-link-button {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 22px !important;
  min-width:110px;
  border:2px solid rgba(255,255,255,.55);
  border-radius:999px;
  background-color:#ffffff !important;
  background-image:none !important;
  color:#173a78 !important;
  font-weight:800;
  box-shadow:0 12px 28px rgba(10,25,56,.16);
  transition:background-color .65s ease, color .65s ease, transform .65s ease, box-shadow .65s ease, border-color .65s ease;
}

.nav-link-button:hover,
.nav-link-button:focus-visible {
  background-color:#dce8ff !important;
  background-image:none !important;
  border-color:rgba(255,255,255,.38) !important;
  color:#173a78 !important;
  box-shadow:0 14px 30px rgba(10,25,56,.18);
  transform:translateY(-1px);
}

.nav-link-button,
.nav-link-button:link,
.nav-link-button:visited {
  color:#173a78 !important;
}

.btn,
a.btn,
button.btn,
.service-btn {
  background-color:#173a78;
  background-image:linear-gradient(90deg,#173a78 0%,#5f86ea 100%);
  color:#ffffff;
  border:6px solid #000000;
  background-clip:padding-box;
  box-shadow:0 10px 24px rgba(10,25,56,.18);
  transition:background-color .45s ease, background-image .45s ease, color .45s ease, transform .45s ease, border-color .28s ease, box-shadow .45s ease;
}

.btn:hover,
a.btn:hover,
button.btn:hover,
.service-btn:hover,
.btn:focus-visible,
a.btn:focus-visible,
button.btn:focus-visible,
.service-btn:focus-visible {
  background-color:#5f86ea;
  background-image:none;
  border-color:#000000;
  color:#173a78;
  box-shadow:0 14px 30px rgba(10,25,56,.18);
  transform:translateY(-1px);
}

.btn.secondary,
a.btn.secondary,
button.btn.secondary {
  background-color:transparent;
  background-image:none;
  color:#173a78;
  border:2px solid #173a78;
  box-shadow:none;
}

.btn.secondary:hover,
a.btn.secondary:hover,
button.btn.secondary:hover,
.btn.secondary:focus-visible,
a.btn.secondary:focus-visible,
button.btn.secondary:focus-visible {
  background-color:#5f86ea;
  background-image:none;
  color:#173a78;
  border-color:#173a78;
}


/* Stronger blue button outline for a cleaner, solid pill edge */
.btn:not(.secondary),
a.btn:not(.secondary),
button.btn:not(.secondary),
.service-btn {
  border:6px solid #000000 !important;
  outline:1px solid #000000;
  outline-offset:-1px;
}

.btn:not(.secondary):hover,
a.btn:not(.secondary):hover,
button.btn:not(.secondary):hover,
.service-btn:hover,
.btn:not(.secondary):focus-visible,
a.btn:not(.secondary):focus-visible,
button.btn:not(.secondary):focus-visible,
.service-btn:focus-visible {
  border-color:#000000 !important;
  outline-color:#000000;
}

footer {
  padding:46px 0 54px;
}

.footer-shell {
  display:grid;
  grid-template-columns:minmax(160px,190px) minmax(0,1.8fr) minmax(220px,.85fr);
  gap:34px;
  align-items:start;
}

.footer-brand-block,
.footer-contact-block {
  min-width:0;
}

.footer-logo {
  width:auto;
  height:52px;
  max-width:165px;
  object-fit:contain;
}

.footer-copy {
  margin:14px 0 0;
  max-width:28ch;
  color:#dbe9ff;
}

.footer-links-grid {
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
  min-width:0;
}

.footer-nav-group {
  min-width:0;
}

.footer-submenu-primary {
  gap:10px;
}

.footer-nav-heading,
.footer-nav-heading:link,
.footer-nav-heading:visited {
  display:inline-block;
  margin-bottom:10px;
  color:#ffffff;
  font-weight:800;
}

.footer-submenu {
  display:grid;
  gap:8px;
}

.footer-submenu a,
.footer-contact-list a,
.footer-copy a {
  color:#dbe9ff;
}

.footer-submenu a:hover,
.footer-contact-list a:hover,
.footer-copy a:hover,
.footer-nav-heading:hover {
  color:#ffffff;
}

.footer-contact-list p {
  margin:0 0 10px;
  color:#dbe9ff;
  word-break:break-word;
}

@media (max-width: 1100px) {
  .footer-shell {
    grid-template-columns:1fr;
    gap:28px;
  }

  .footer-links-grid {
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}

@media (max-width: 920px) {
  .nav-links {
    gap:0;
  }

  .nav-link-button {
    width:calc(100% - 24px);
    margin:10px 12px 4px;
  }

  .footer-links-grid {
    grid-template-columns:1fr;
  }
}

@media (max-width: 640px) {
  .footer-links-grid {
    grid-template-columns:1fr;
  }

  .footer-logo {
    height:58px;
    max-width:135px;
  }
}


/* Smooth desktop submenu fade-in */
@media (min-width: 921px) {
  .has-submenu {
    position: relative;
  }

  .submenu {
    display: block;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(10px);
    transition: opacity .22s ease, transform .22s ease, visibility 0s linear .22s;
  }

  .has-submenu:hover .submenu,
  .has-submenu:focus-within .submenu,
  .has-submenu.open .submenu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
    transition: opacity .22s ease, transform .22s ease, visibility 0s linear 0s;
  }
}

/* Stronger full-bleed angled home sections */
.hero-home-refresh,
.services-modern,
.home-alt-blue {
  position: relative;
  isolation: isolate;
}

.hero-centered.hero-home-refresh {
  overflow: visible;
  padding: 2.4rem 0 2.6rem;
}

.hero-centered.hero-home-refresh::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -18px;
  bottom: -22px;
  width: 100vw;
  transform: translateX(-50%);
  background:
    radial-gradient(circle at 12% 18%, rgba(255,255,255,0.20), transparent 22%),
    radial-gradient(circle at 88% 10%, rgba(255,255,255,0.10), transparent 20%),
    linear-gradient(135deg, #4365d4 0%, #5e7ae0 52%, #7190ec 100%);
  clip-path: polygon(0 36px, 100% 0, 100% calc(100% - 34px), 0 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.25), 0 20px 44px rgba(23,58,120,0.18);
  z-index: -2;
}

.hero-centered.hero-home-refresh::after {
  content: "";
  position: absolute;
  left: 50%;
  top: -18px;
  width: 100vw;
  height: calc(100% + 40px);
  transform: translateX(-50%);
  clip-path: polygon(0 36px, 100% 0, 100% calc(100% - 34px), 0 100%);
  background: linear-gradient(180deg, rgba(255,255,255,0.18), rgba(255,255,255,0.02) 42%, rgba(9,24,58,0.04) 100%);
  pointer-events: none;
  z-index: -1;
}

.hero-kicker {
  position: relative;
  color: #173a78;
  background: #ffffff;
  border: 1px solid rgba(23,58,120,0.10);
  border-radius: 0;
  clip-path: polygon(18px 0, 100% 0, calc(100% - 18px) 100%, 0 100%);
  padding: 0.9rem 1.65rem;
  box-shadow: 0 14px 28px rgba(23,58,120,0.12);
}

.services-modern {
  margin-top: 0;
  padding-top: 34px;
  padding-bottom: 70px;
  overflow: visible;
  background: none;
  border-radius: 0;
  box-shadow: none;
}

.services-modern::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -10px;
  bottom: -10px;
  width: 100vw;
  transform: translateX(-50%);
  background:
    radial-gradient(circle at 14% 22%, rgba(79,111,217,0.20), transparent 25%),
    radial-gradient(circle at 88% 18%, rgba(23,58,120,0.12), transparent 24%),
    linear-gradient(180deg, #edf3fc 0%, #deebf8 52%, #d4e2f5 100%);
  clip-path: polygon(0 12px, 100% 0, 100% calc(100% - 12px), 0 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.84), 0 14px 32px rgba(23,58,120,0.09);
  z-index: -2;
}

.services-modern::after {
  content: "";
  position: absolute;
  left: 50%;
  top: -10px;
  width: 100vw;
  height: calc(100% + 20px);
  transform: translateX(-50%);
  clip-path: polygon(0 12px, 100% 0, 100% calc(100% - 12px), 0 100%);
  border-top: 1px solid rgba(255,255,255,0.8);
  border-bottom: 1px solid rgba(23,58,120,0.10);
  pointer-events: none;
  z-index: -1;
}

.home-alt-blue {
  overflow: visible;
  background: none;
  border: 0;
}

.home-alt-blue::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -28px;
  bottom: -28px;
  width: 100vw;
  transform: translateX(-50%);
  background: linear-gradient(180deg, rgba(226,236,249,0.96), rgba(213,226,244,0.98));
  clip-path: polygon(0 30px, 100% 0, 100% calc(100% - 30px), 0 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.82), 0 14px 34px rgba(23,58,120,0.08);
  z-index: -2;
}

.home-alt-blue::after {
  content: "";
  position: absolute;
  left: 50%;
  top: -28px;
  width: 100vw;
  height: calc(100% + 56px);
  transform: translateX(-50%);
  clip-path: polygon(0 30px, 100% 0, 100% calc(100% - 30px), 0 100%);
  background: linear-gradient(180deg, rgba(255,255,255,0.14), rgba(255,255,255,0.02));
  pointer-events: none;
  z-index: -1;
}

#contact.home-alt-blue::before,
#contact.home-alt-blue::after {
  clip-path: polygon(0 0, 100% 30px, 100% 100%, 0 calc(100% - 30px));
}

@media (max-width: 920px) {
  .hero-centered.hero-home-refresh {
    padding: 2rem 0 2.15rem;
  }

  .hero-centered.hero-home-refresh::before,
  .hero-centered.hero-home-refresh::after,
  .services-modern::before,
  .services-modern::after,
  .home-alt-blue::before,
  .home-alt-blue::after {
    clip-path: polygon(0 14px, 100% 0, 100% calc(100% - 14px), 0 100%);
  }

  #contact.home-alt-blue::before,
  #contact.home-alt-blue::after {
    clip-path: polygon(0 0, 100% 18px, 100% 100%, 0 calc(100% - 18px));
  }

  .services-modern {
    padding-top: 30px;
    padding-bottom: 56px;
  }

  .hero-kicker {
    clip-path: polygon(12px 0, 100% 0, calc(100% - 12px) 100%, 0 100%);
    padding: 0.75rem 1.2rem;
  }
}


/* Modern service/card treatment */
.card,
.service-column,
.contact-options,
.about-side-card,
.hero-promo-card,
.section-lead-card,
.about-section-card,
.article-card,
.inline-note-card {
  position: relative;
  background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(246,249,254,0.92));
  border: 1px solid rgba(23,58,120,0.10);
  box-shadow: 0 16px 34px rgba(16, 43, 92, 0.08);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: transform .34s ease, box-shadow .34s ease, border-color .34s ease, background-color .34s ease;
}

.card::before,
.service-column::before,
.contact-options::before,
.about-side-card::before,
.hero-promo-card::before,
.section-lead-card::before,
.about-section-card::before,
.article-card::before,
.inline-note-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(255,255,255,0.24), rgba(255,255,255,0.02) 38%, rgba(67,101,212,0.03) 100%);
}

@media (hover: hover) and (pointer: fine) {
  .card:hover,
  .service-column:hover,
  .contact-options:hover,
  .about-side-card:hover,
  .hero-promo-card:hover,
  .section-lead-card:hover,
  .about-section-card:hover,
  .article-card:hover,
  .inline-note-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 22px 44px rgba(16, 43, 92, 0.14);
    border-color: rgba(23,58,120,0.18);
  }
}

.services-modern .service-column {
  border: 1px solid rgba(23,58,120,0.10);
  box-shadow: 0 16px 34px rgba(16, 43, 92, 0.09);
}

.home-alt-blue .card,
.home-alt-blue .service-column {
  background: linear-gradient(180deg, rgba(248,251,255,0.96), rgba(237,244,252,0.94));
}

/* Gentle reveal on scroll */
body.reveal-ready [data-reveal] {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .56s ease, transform .56s ease;
  transition-delay: var(--reveal-delay, 0s);
  will-change: opacity, transform;
}

body.reveal-ready [data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}

body.reveal-ready [data-reveal="left"] {
  transform: translate(-18px, 14px);
}

body.reveal-ready [data-reveal="right"] {
  transform: translate(18px, 14px);
}

body.reveal-ready [data-reveal="left"].is-visible,
body.reveal-ready [data-reveal="right"].is-visible {
  transform: translate(0, 0);
}

@media (prefers-reduced-motion: reduce) {
  body.reveal-ready [data-reveal] {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .card,
  .service-column,
  .contact-options,
  .about-side-card,
  .hero-promo-card,
  .section-lead-card,
  .about-section-card,
  .article-card,
  .inline-note-card {
    transition: none;
  }
}

/* Restore original front-page card styling while keeping reveal/angle updates */
.services-modern .service-column {
  position: relative;
  padding: 20px 20px 0;
  text-align: center;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  transition: none;
}

.services-modern .service-column::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  width: 72px;
  height: 3px;
  border-radius: 999px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, #4f6fd9, rgba(79, 111, 217, 0.25));
}

.services-modern .service-column + .service-column {
  border-left: 1px solid rgba(23, 58, 120, 0.10);
  padding-left: 20px;
}

.services-modern .service-column h3 {
  margin-bottom: 12px;
  font-size: clamp(1.25rem, 2.2vw, 1.7rem);
  line-height: 1.08;
  color: #173a78;
}

.services-modern .service-column p {
  margin: 0 auto 16px;
  max-width: 28ch;
}

.services-modern .service-column:hover {
  transform: none;
  box-shadow: none;
  border-color: transparent;
}

.home-alt-blue .card,
.home-alt-blue .contact-options {
  background: linear-gradient(180deg, rgba(244,248,253,0.98), rgba(233,241,251,0.98));
  border: 1px solid rgba(23, 58, 120, 0.12);
  border-radius: 28px;
  box-shadow: var(--shadow);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.home-alt-blue .card::before,
.home-alt-blue .contact-options::before {
  display: none;
}

@media (hover: hover) and (pointer: fine) {
  .home-alt-blue .card:hover,
  .home-alt-blue .contact-options:hover,
  .services-modern .service-column:hover {
    transform: none;
    box-shadow: var(--shadow);
    border-color: rgba(23, 58, 120, 0.12);
  }
}


/* Very subtle home card polish */
.services-modern .service-column,
.home-alt-blue .card,
.home-alt-blue .contact-options {
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

@media (hover: hover) and (pointer: fine) {
  .services-modern .service-column:hover {
    transform: translateY(-1px);
  }

  .home-alt-blue .card:hover,
  .home-alt-blue .contact-options:hover {
    transform: translateY(-2px);
    box-shadow: 0 18px 34px rgba(16, 43, 92, 0.11);
    border-color: rgba(23, 58, 120, 0.15);
  }
}


/* Header-to-hero seam fix */
header,
.site-header,
.header,
.navbar {
  border-bottom: 0 !important;
  box-shadow: none !important;
}

body.home-page header + .hero,
header + .hero,
main > .hero.hero-home-refresh {
  background: #4f6fd9;
  margin-top: 0;
}

main > .hero.hero-home-refresh {
  position: relative;
}

main > .hero.hero-home-refresh::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -2px;
  height: 4px;
  background: #4f6fd9;
  pointer-events: none;
}


/* Focused hero and service-card animation + angled footer sitewide */
footer {
  position: relative;
  isolation: isolate;
  overflow: visible;
  padding: 62px 0 54px;
  background: none;
}

footer::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -28px;
  bottom: 0;
  width: 100vw;
  transform: translateX(-50%);
  background: linear-gradient(180deg, #234889 0%, #173a78 58%, #123265 100%);
  clip-path: polygon(0 28px, 100% 0, 100% 100%, 0 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.14), 0 -12px 28px rgba(17,38,78,.10);
  z-index: -2;
}

footer::after {
  content: "";
  position: absolute;
  left: 50%;
  top: -28px;
  width: 100vw;
  height: calc(100% + 28px);
  transform: translateX(-50%);
  clip-path: polygon(0 28px, 100% 0, 100% 100%, 0 100%);
  background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,0) 42%);
  pointer-events: none;
  z-index: -1;
}

.footer-shell {
  position: relative;
  z-index: 1;
}

/* Only animate hero content and home services cards */
body.reveal-ready [data-reveal] {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .52s ease, transform .52s ease;
  transition-delay: var(--reveal-delay, 0s);
  will-change: opacity, transform;
}

body.reveal-ready [data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}

body.reveal-ready [data-reveal="left"] {
  transform: translateX(-24px);
}

body.reveal-ready [data-reveal="right"] {
  transform: translateX(24px);
}

body.reveal-ready [data-reveal="left"].is-visible,
body.reveal-ready [data-reveal="right"].is-visible {
  transform: translateX(0);
}

.hero [data-reveal] {
  backface-visibility: hidden;
}

.services-modern .service-column {
  transition: transform .26s ease, opacity .52s ease;
}

@media (max-width: 920px) {
  footer {
    padding: 54px 0 50px;
  }

  footer::before,
  footer::after {
    top: -18px;
    clip-path: polygon(0 18px, 100% 0, 100% 100%, 0 100%);
  }

  footer::after {
    height: calc(100% + 18px);
  }
}

@media (prefers-reduced-motion: reduce) {
  body.reveal-ready [data-reveal] {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .services-modern .service-column {
    transition: none;
  }
}


/* Final home hero intro override */
.hero-home-refresh .hero-intro {
  width: 100%;
  max-width: 80% !important;
  color: #ffffff !important;
  margin: 0 auto;
}

@media (max-width: 768px) {
  .hero-home-refresh .hero-intro {
    max-width: 100% !important;
  }
}

/* Stronger home hero-to-services angle to match footer */
.services-modern {
  padding-top: 28px;
}

.services-modern::before {
  top: -28px !important;
  bottom: 0 !important;
  background:
    radial-gradient(circle at 14% 22%, rgba(79,111,217,0.20), transparent 25%),
    radial-gradient(circle at 88% 18%, rgba(23,58,120,0.12), transparent 24%),
    linear-gradient(180deg, #edf3fc 0%, #deebf8 52%, #d4e2f5 100%) !important;
  clip-path: polygon(0 28px, 100% 0, 100% 100%, 0 100%) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.84), 0 14px 32px rgba(23,58,120,0.09) !important;
}

.services-modern::after {
  top: -28px !important;
  height: calc(100% + 28px) !important;
  clip-path: polygon(0 28px, 100% 0, 100% 100%, 0 100%) !important;
  background: linear-gradient(180deg, rgba(255,255,255,0.10), rgba(255,255,255,0) 42%) !important;
  border-top: 0 !important;
  border-bottom: 0 !important;
}

@media (max-width: 920px) {
  .services-modern {
    padding-top: 22px;
  }

  .services-modern::before,
  .services-modern::after {
    top: -18px !important;
    clip-path: polygon(0 18px, 100% 0, 100% 100%, 0 100%) !important;
  }

  .services-modern::after {
    height: calc(100% + 18px) !important;
  }
}


.it-hero-plain {
  background: transparent;
  border: 0;
  box-shadow: none;
  clip-path: none;
  padding-top: 56px;
  padding-bottom: 36px;
}

.it-hero-plain::before,
.it-hero-plain::after {
  display: none;
}

.it-hero-plain .hero-kicker {
  color: #ffffff;
  background: #173a78;
  border: 1px solid #173a78;
  border-radius: 0;
  clip-path: polygon(18px 0, 100% 0, calc(100% - 18px) 100%, 0 100%);
  box-shadow: 0 14px 28px rgba(23,58,120,0.18);
}


.hero-offer-strip {
  margin: 1.1rem auto 0;
  padding: 0.9rem 1rem;
  border: 1px solid rgba(31, 58, 147, 0.16);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(245,248,255,0.98), rgba(235,242,255,0.96));
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  max-width: 920px;
  box-shadow: 0 12px 32px rgba(18, 34, 84, 0.08);
}

.hero-offer-copy {
  display: grid;
  gap: 0.3rem;
  text-align: left;
}

.hero-offer-kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--navy);
}

.hero-offer-text {
  margin: 0;
  color: var(--ink);
}

.hero-offer-price {
  color: var(--navy);
  font-weight: 700;
}

.hero-offer-btn {
  white-space: nowrap;
  flex-shrink: 0;
}

@media (max-width: 820px) {
  .hero-offer-strip {
    align-items: flex-start;
    flex-direction: column;
  }

  .hero-offer-btn {
    width: 100%;
    text-align: center;
  }
}


.service-card-link {
  color: inherit;
  text-decoration: none;
}

.service-card-link:hover,
.service-card-link:focus {
  text-decoration: underline;
  text-underline-offset: 0.16em;
}


/* Single-shape angled rounded hero kicker */
.hero-kicker,
.it-hero-plain .hero-kicker {
  position: relative;
  display: inline-block;
  isolation: isolate;
  overflow: visible;
  clip-path: none;
  border: 0;
  background: transparent;
  border-radius: 0;
  padding: 0.9rem 1.85rem;
  --kicker-fill: #ffffff;
  --kicker-stroke: rgba(23,58,120,0.10);
  --kicker-shadow: none;
}

.it-hero-plain .hero-kicker {
  --kicker-fill: #173a78;
  --kicker-stroke: #173a78;
  --kicker-shadow: none;
}

.hero-kicker::before,
.it-hero-plain .hero-kicker::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: var(--kicker-fill);
  border: 1px solid var(--kicker-stroke);
  border-radius: 16px;
  transform: skewX(-18deg);
  box-shadow: var(--kicker-shadow);
}

.hero-kicker::after,
.it-hero-plain .hero-kicker::after {
  content: none;
}

@media (max-width: 640px) {
  .hero-kicker,
  .it-hero-plain .hero-kicker {
    padding: 0.8rem 1.4rem;
  }

  .hero-kicker::before,
  .it-hero-plain .hero-kicker::before {
    border-radius: 14px;
  }
}

/* Remove remaining service hero kicker shading */
.hero.hero-centered .hero-kicker,
.hero.hero-centered.it-hero-plain .hero-kicker,
.it-hero-plain .hero-kicker,
.electrical-hero .hero-kicker,
.it-services-hero .hero-kicker,
.web-hero .hero-kicker,
.tech-hero .hero-kicker {
  box-shadow: none !important;
  text-shadow: none !important;
  filter: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.hero.hero-centered .hero-kicker::before,
.hero.hero-centered.it-hero-plain .hero-kicker::before,
.it-hero-plain .hero-kicker::before,
.electrical-hero .hero-kicker::before,
.it-services-hero .hero-kicker::before,
.web-hero .hero-kicker::before,
.tech-hero .hero-kicker::before {
  box-shadow: none !important;
  filter: none !important;
}

/* Service area page */
.service-area-hero-grid {
  align-items: center;
}

.service-area-map-card {
  padding: 14px;
  overflow: hidden;
}

.fleurieu-map {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 24px;
  border: 1px solid rgba(23,58,120,0.10);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.45);
}

.map-land {
  fill: url(#landGradient);
  stroke: #5f9b70;
  stroke-width: 5;
  stroke-linejoin: round;
}

.map-road {
  fill: none;
  stroke: #f6f0c8;
  stroke-width: 10;
  stroke-linecap: round;
  stroke-dasharray: 18 12;
}

.map-road-secondary {
  stroke-width: 7;
  opacity: 0.9;
}

.map-town circle {
  fill: #173a78;
  stroke: #ffffff;
  stroke-width: 3;
}

.map-town text,
.map-label,
.map-note {
  font-family: Arial, Helvetica, sans-serif;
  fill: #173a78;
  paint-order: stroke;
  stroke: rgba(255,255,255,0.88);
  stroke-width: 5px;
  stroke-linejoin: round;
  font-weight: 800;
}

.map-town text {
  font-size: 18px;
}

.map-label {
  font-size: 28px;
}

.map-note {
  font-size: 16px;
  font-weight: 700;
}

.map-pin circle,
.map-pin path {
  fill: #4f6fd9;
  stroke: #ffffff;
  stroke-width: 4;
}

.service-area-town-list {
  columns: 2;
  column-gap: 28px;
}

.service-area-town-list li {
  break-inside: avoid;
}

.service-area-services-grid {
  margin-top: 20px;
}

.service-area-services-grid .inline-note-card a,
.service-area-home-card h2 a {
  color: inherit;
  text-decoration: none;
}

.service-area-services-grid .inline-note-card a:hover,
.service-area-home-card h2 a:hover {
  color: var(--blue-dark);
  text-decoration: underline;
  text-underline-offset: 4px;
}

.service-area-home-card .btn {
  margin-top: 10px;
}

@media (max-width: 920px) {
  .service-area-town-list {
    columns: 1;
  }

  .service-area-services-grid {
    grid-template-columns: 1fr;
  }

  .map-town text {
    font-size: 15px;
  }
}

/* Shop hero: keep the home-style blue hero while matching the header seam and avoiding bottom-right bleed */
.shop-hero-blue.hero-home-refresh {
  background: linear-gradient(180deg, #4f6fd9 0 42px, transparent 42px) !important;
  overflow: hidden;
}

.shop-hero-blue.hero-home-refresh::before {
  top: -18px;
  bottom: -22px;
  height: auto;
}

.shop-hero-blue.hero-home-refresh::after {
  top: -18px;
  height: calc(100% + 40px);
}

.shop-hero-blue.hero-home-refresh + .section {
  position: relative;
  z-index: 1;
}

/* Solid visible outline for blue buttons */
.btn:not(.secondary),
a.btn:not(.secondary),
button.btn:not(.secondary),
.service-btn {
  border: 2px solid #000000 !important;
  background-clip: padding-box;
  box-shadow: 0 0 0 3px #000000, 0 10px 24px rgba(10,25,56,.18) !important;
}

.btn:not(.secondary):hover,
a.btn:not(.secondary):hover,
button.btn:not(.secondary):hover,
.service-btn:hover,
.btn:not(.secondary):focus-visible,
a.btn:not(.secondary):focus-visible,
button.btn:not(.secondary):focus-visible,
.service-btn:focus-visible {
  border-color: #000000 !important;
  box-shadow: 0 0 0 3px #000000, 0 14px 30px rgba(10,25,56,.18) !important;
}

/* Final button outline adjustment: match white buttons with a solid navy border */
.btn:not(.secondary),
a.btn:not(.secondary),
button.btn:not(.secondary),
.service-btn {
  border: 2px solid #173a78 !important;
  outline: none !important;
  background-clip: border-box !important;
  box-shadow: 0 10px 24px rgba(10,25,56,.18) !important;
}

.btn:not(.secondary):hover,
a.btn:not(.secondary):hover,
button.btn:not(.secondary):hover,
.service-btn:hover,
.btn:not(.secondary):focus-visible,
a.btn:not(.secondary):focus-visible,
button.btn:not(.secondary):focus-visible,
.service-btn:focus-visible {
  border-color: #173a78 !important;
  outline: none !important;
  box-shadow: 0 14px 30px rgba(10,25,56,.18) !important;
}


/* Customer pathway section on home page */
.start-choice-grid {
  margin-top: 26px;
  margin-bottom: 34px;
}

.start-choice-card {
  display: flex;
  flex-direction: column;
  min-height: 100%;
}

.start-choice-card h3 {
  font-size: 1.22rem;
}

.start-choice-card .btn {
  margin-top: auto;
  align-self: flex-start;
}

.services-intro-secondary {
  margin-top: 8px;
  margin-bottom: 8px;
}

.services-intro-secondary h2 {
  font-size: clamp(1.5rem, 3vw, 2.1rem);
}

.contact-page-split .contact-options {
  align-self: stretch;
}

.contact-quick-links .card {
  display: flex;
  flex-direction: column;
}

.contact-quick-links .btn {
  margin-top: auto;
  align-self: flex-start;
}

@media (max-width: 1100px) {
  .start-choice-grid,
  .contact-quick-links {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 680px) {
  .start-choice-grid,
  .contact-quick-links {
    grid-template-columns: 1fr;
  }
}

/* Customer pathway refinement: modern service-column style and compact browse links */
.start-choice-columns {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  align-items: stretch;
  margin-top: 26px;
  margin-bottom: 30px;
  position: relative;
}

.start-choice-columns::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(79, 111, 217, 0.28), rgba(23, 58, 120, 0.08));
}

.services-modern .start-choice-card {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  padding: 28px 18px 0;
}

.services-modern .start-choice-card .eyebrow {
  margin-bottom: 10px;
}

.services-modern .start-choice-card h3 {
  font-size: clamp(1.12rem, 1.9vw, 1.45rem);
  line-height: 1.12;
}

.services-modern .start-choice-card p {
  max-width: 30ch;
}

.services-modern .start-choice-card .btn {
  margin: auto auto 0;
  align-self: center;
}

.services-browse-links {
  margin-top: 20px;
  padding-top: 22px;
  text-align: center;
  border-top: 1px solid rgba(23, 58, 120, 0.10);
}

.services-browse-links .lead {
  margin: 0 auto 14px;
  max-width: 720px;
}

.browse-link-row {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;
}

@media (max-width: 1100px) {
  .start-choice-columns {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 26px 0;
  }

  .services-modern .start-choice-card:nth-child(3) {
    border-left: 0;
  }
}

@media (max-width: 680px) {
  .start-choice-columns {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .services-modern .start-choice-card + .start-choice-card {
    border-left: 0;
    border-top: 1px solid rgba(23, 58, 120, 0.10);
    padding-left: 0;
    padding-top: 28px;
    margin-top: 26px;
  }
}

/* Keep the selected Start with what you need look, but hold four cards side-by-side on desktop */
.start-choice-columns {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 0 !important;
  align-items: stretch !important;
}

.start-choice-columns .start-choice-card {
  min-width: 0;
}

.services-browse-links,
.services-browse-links .lead,
.browse-link-row {
  text-align: center;
  justify-content: center;
}

@media (max-width: 900px) {
  .start-choice-columns {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 26px 0 !important;
  }

  .services-modern .start-choice-card:nth-child(3) {
    border-left: 0;
  }
}

@media (max-width: 620px) {
  .start-choice-columns {
    grid-template-columns: 1fr !important;
    gap: 0 !important;
  }
}


/* Highlight the recommended Test & Tag combined option */
.card.card-featured {
  border-color: rgba(23, 58, 120, 0.28);
  box-shadow: 0 20px 42px rgba(16, 43, 92, 0.14);
}

.card.card-featured .eyebrow {
  color: var(--blue-dark);
}

/* Contact form page */
.contact-form-layout {
  display:grid;
  grid-template-columns:minmax(0,1.45fr) minmax(280px,.75fr);
  gap:24px;
  align-items:start;
}
.contact-form-card {
  padding:28px;
}
.contact-form {
  margin-top:20px;
}
.form-grid {
  display:grid;
  gap:14px;
}
.form-grid-two {
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.form-field {
  display:grid;
  gap:7px;
}
.form-help {
  margin:0 0 4px;
  color:var(--muted);
  font-size:.94rem;
}
.form-field-checkbox label {
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-weight:600;
  color:var(--muted);
}
.form-field-checkbox input {
  margin-top:3px;
}
.form-actions {
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}
.form-actions p {
  margin:0;
  max-width:520px;
}
.contact-side-stack {
  display:grid;
  gap:18px;
}
.contact-side-stack .contact-options p:last-child,
.contact-side-stack .contact-options ul:last-child {
  margin-bottom:0;
}
@media (max-width:980px) {
  .contact-form-layout {
    grid-template-columns:1fr;
  }
}
@media (max-width:720px) {
  .contact-form-card {
    padding:22px;
  }
  .form-grid-two {
    grid-template-columns:1fr;
  }
}


.card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.card-actions .btn {
  margin-top: 0;
}

/* Contact page layout refinements and light spam trap */
.hp-field {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  overflow: hidden !important;
  pointer-events: none !important;
}

.contact-form-layout {
  align-items: stretch;
}

.contact-guidance-card {
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 22px;
  height: 100%;
}

.contact-guidance-block {
  display: grid;
  gap: 12px;
}

.contact-guidance-block .checklist {
  margin-bottom: 0;
}

.contact-guidance-block-soft {
  margin-top: auto;
  padding-top: 22px;
  border-top: 1px solid rgba(20, 46, 88, 0.12);
}

.contact-bottom-panel {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 0.95fr);
  gap: 28px;
  align-items: center;
  padding: 32px 34px;
  border-radius: 28px;
  background: linear-gradient(135deg, rgba(219, 231, 247, 0.96), rgba(236, 243, 252, 0.96));
  box-shadow: 0 18px 44px rgba(14, 35, 72, 0.10);
}

.contact-bottom-copy h2 {
  margin-bottom: 12px;
}

.contact-bottom-copy p:last-child {
  margin-bottom: 0;
}

.contact-email-card {
  padding: 26px;
  border-radius: 26px;
  background: rgba(255,255,255,0.58);
}

.contact-email-actions {
  display: grid;
  gap: 12px;
  margin-top: 22px;
}

.contact-email-actions .btn {
  width: 100%;
  justify-content: center;
}

@media (max-width: 980px) {
  .contact-bottom-panel {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .contact-guidance-card,
  .contact-bottom-panel,
  .contact-email-card {
    padding: 22px;
  }
}

/* Contact page refinements: balanced side cards with direct contact below */
.contact-form-layout {
  align-items: stretch;
}

.contact-form-card {
  height: 100%;
}

.contact-side-stack-balanced {
  display: flex;
  flex-direction: column;
  gap: 24px;
  height: 100%;
}

.contact-side-stack-balanced .contact-options {
  flex: 1 1 0;
  display: flex;
  flex-direction: column;
}

.contact-side-stack-balanced .contact-options .checklist,
.contact-side-stack-balanced .contact-options p:last-child {
  margin-bottom: 0;
}

.contact-direct-card {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(220px, .55fr) minmax(220px, .55fr);
  gap: 24px;
  align-items: center;
  padding: 28px;
}

.contact-direct-card h2 {
  margin-bottom: 10px;
}

.contact-direct-card p:last-child {
  margin-bottom: 0;
}

.contact-direct-actions {
  display: grid;
  gap: 12px;
}

.contact-direct-actions .btn {
  width: 100%;
  justify-content: center;
}

.contact-direct-details p {
  margin: 0 0 10px;
}

.contact-direct-details p:last-child {
  margin-bottom: 0;
}

@media (max-width: 980px) {
  .contact-side-stack-balanced .contact-options {
    flex: initial;
  }

  .contact-direct-card {
    grid-template-columns: 1fr;
  }
}

/* Soft launch additions */
.soft-launch-page .soft-launch-hero .hero-intro {
  max-width: 840px;
}

.soft-launch-status-section .launch-note-card,
.soft-launch-area .service-area-home-card {
  align-self: stretch;
}

.soft-launch-town-list {
  margin: 1rem 0 0;
  padding-left: 1.25rem;
  color: var(--muted, #506070);
}

.soft-launch-town-list li + li {
  margin-top: .55rem;
}

.footer-links-grid-softlaunch {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 720px) {
  .footer-links-grid-softlaunch {
    grid-template-columns: 1fr;
  }
}

/* Home why/service-area paired section */
.why-service-overview {
  padding: 66px 0;
}

.why-service-grid {
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, .95fr);
  gap: 28px;
  align-items: center;
}

.why-service-copy .checklist {
  margin-top: 24px;
}

.why-service-copy .checklist li {
  font-size: 1rem;
  padding-top: 12px;
  padding-bottom: 12px;
}

.why-service-overview .service-area-home-card {
  padding: 32px;
  border-radius: 28px;
}

.why-service-overview .service-area-home-card h2 {
  margin-bottom: 18px;
}

.why-service-overview .service-area-home-card .hero-actions {
  margin-top: 26px;
}

@media (max-width: 980px) {
  .why-service-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .why-service-overview {
    padding: 48px 0;
  }

  .why-service-overview .service-area-home-card {
    padding: 24px;
  }
}

.form-alert {
  margin: 0 0 18px;
  padding: 14px 16px;
  border-radius: 16px;
  background: rgba(255,255,255,0.78);
  border: 1px solid rgba(23,58,120,0.16);
  box-shadow: 0 10px 24px rgba(23,58,120,0.08);
}

/* Temporary text wordmark while final logo is refined */
.brand-wordmark {
  display:inline-flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  gap:2px;
  min-height:58px;
  text-decoration:none;
  line-height:1;
}

.wordmark-main {
  display:inline-flex;
  align-items:baseline;
  font-size:clamp(1.8rem, 3vw, 2.45rem);
  font-weight:900;
  letter-spacing:-0.075em;
  color:var(--blue-dark);
}

.wordmark-grubb {
  color:var(--ink);
}

.wordmark-it {
  margin-left:0.08em;
  color:var(--blue);
  letter-spacing:-0.04em;
}

.wordmark-tagline {
  display:block;
  margin-top:3px;
  font-size:0.68rem;
  font-weight:800;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--muted);
  white-space:nowrap;
}

.brand-wordmark:hover .wordmark-main,
.brand-wordmark:focus-visible .wordmark-main {
  color:var(--blue);
}

.footer-wordmark,
.footer-wordmark:link,
.footer-wordmark:visited {
  display:inline-flex;
  flex-direction:column;
  align-items:flex-start;
  gap:5px;
  color:#ffffff;
  text-decoration:none;
  line-height:1;
}

.footer-wordmark-main {
  display:inline-flex;
  align-items:baseline;
  font-size:2rem;
  font-weight:900;
  letter-spacing:-0.075em;
}

.footer-wordmark-main strong {
  margin-left:0.08em;
  color:#dbe9ff;
  font-weight:900;
  letter-spacing:-0.04em;
}

.footer-wordmark-line {
  font-size:0.66rem;
  font-weight:800;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:#dbe9ff;
  line-height:1.35;
}

.footer-wordmark:hover .footer-wordmark-main,
.footer-wordmark:focus-visible .footer-wordmark-main {
  color:#dbe9ff;
}

@media (max-width: 920px) {
  .brand-wordmark {
    min-height:50px;
    max-width:calc(100% - 68px);
  }

  .wordmark-main {
    font-size:2rem;
  }

  .wordmark-tagline {
    font-size:0.56rem;
    letter-spacing:0.11em;
    white-space:normal;
    line-height:1.3;
  }
}

@media (max-width: 420px) {
  .wordmark-main {
    font-size:1.75rem;
  }

  .wordmark-tagline {
    max-width:220px;
  }
}

/* Temporary wordmark contrast fix for blue header/footer backgrounds */
header .brand-wordmark,
header .brand-wordmark:link,
header .brand-wordmark:visited {
  color:#ffffff !important;
}

header .brand-wordmark .wordmark-main,
header .brand-wordmark .wordmark-grubb,
header .brand-wordmark .wordmark-it {
  color:#ffffff !important;
  text-shadow:0 1px 2px rgba(11,27,64,0.22);
}

header .brand-wordmark .wordmark-it {
  color:#dbe9ff !important;
}

header .brand-wordmark .wordmark-tagline {
  color:#eef5ff !important;
  text-shadow:0 1px 2px rgba(11,27,64,0.18);
}

header .brand-wordmark:hover .wordmark-main,
header .brand-wordmark:focus-visible .wordmark-main,
header .brand-wordmark:hover .wordmark-grubb,
header .brand-wordmark:focus-visible .wordmark-grubb,
header .brand-wordmark:hover .wordmark-it,
header .brand-wordmark:focus-visible .wordmark-it {
  color:#ffffff !important;
}


/* Soft launch polish: restore reveal animations and remove blue hero corner bleed */
.soft-launch-page main > .hero.hero-home-refresh {
  background: transparent !important;
}

.soft-launch-page .hero-centered.hero-home-refresh {
  overflow: hidden;
}

.soft-launch-page main > .hero.hero-home-refresh::after {
  top: auto;
  left: 50%;
  right: auto;
  height: calc(100% + 40px);
  width: 100vw;
  transform: translateX(-50%);
  background: linear-gradient(180deg, rgba(255,255,255,0.18), rgba(255,255,255,0.02) 42%, rgba(9,24,58,0.04) 100%);
  clip-path: polygon(0 36px, 100% 0, 100% calc(100% - 34px), 0 100%);
  z-index: -1;
}

@media (max-width: 920px) {
  .soft-launch-page main > .hero.hero-home-refresh::after {
    clip-path: polygon(0 14px, 100% 0, 100% calc(100% - 14px), 0 100%);
  }
}

/* Final soft-launch hero/header layer fix: keep the top edge solid and remove exposed corner layers */
.soft-launch-page header,
.soft-launch-page .site-header,
.soft-launch-page header .container,
.soft-launch-page .site-header .container {
  background: #4f6fd9 !important;
}

.soft-launch-page .hero-centered.hero-home-refresh {
  background: transparent !important;
  overflow: hidden !important;
  isolation: isolate;
}

.soft-launch-page .hero-centered.hero-home-refresh::before {
  top: 0 !important;
  bottom: 0 !important;
  height: auto !important;
  background:
    radial-gradient(circle at 12% 18%, rgba(255,255,255,0.20), transparent 22%),
    radial-gradient(circle at 88% 10%, rgba(255,255,255,0.10), transparent 20%),
    linear-gradient(135deg, #4365d4 0%, #5e7ae0 52%, #7190ec 100%) !important;
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 30px), 0 100%) !important;
  z-index: -2 !important;
}

.soft-launch-page .hero-centered.hero-home-refresh::after,
.soft-launch-page main > .hero.hero-home-refresh::after {
  display: none !important;
  content: none !important;
}

@media (max-width: 920px) {
  .soft-launch-page .hero-centered.hero-home-refresh::before {
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 14px), 0 100%) !important;
  }
}
