
:root {
  --navy: #10325d;
  --navy-deep: #0a2342;
  --navy-soft: #1c4f8c;
  --blue-tint: #edf4fb;
  --blue-border: rgba(16, 50, 93, 0.14);
  --red: #b22234;
  --red-deep: #8f1b2a;
  --red-soft: #d54b5b;
  --white: #ffffff;
  --offwhite: #f8fbff;
  --ink: #1a2633;
  --muted: #516173;
  --border: rgba(16, 50, 93, 0.12);
  --shadow: 0 18px 36px rgba(10, 35, 66, 0.12);
  --shadow-soft: 0 8px 18px rgba(10, 35, 66, 0.07);
  --radius: 4px;
  --radius-sm: 3px;
  --container: 1360px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Source Sans 3", Arial, sans-serif;
  color: var(--ink);
  background:
    linear-gradient(180deg, rgba(16, 50, 93, 0.03) 0, rgba(16, 50, 93, 0) 240px),
    linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  line-height: 1.6;
}
body.nav-open { overflow: hidden; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
.skip-link {
  position: absolute; left: 1rem; top: -4rem; background: var(--navy-deep); color: white;
  padding: 0.75rem 1rem; border-radius: 0.5rem; z-index: 1000;
}
.skip-link:focus { top: 1rem; }
.container { width: min(calc(100% - 2rem), 1500px); margin: 0 auto; }

.site-header {
  position: relative;
  background:
    linear-gradient(180deg, #ffffff 0%, #f6f9ff 100%);
}
.site-header::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 5px;
  background: linear-gradient(90deg, var(--red) 0 33.333%, white 33.333% 66.666%, var(--navy) 66.666%);
}
.site-header::after {
  content: "";
  position: absolute;
  right: -120px;
  top: 120px;
  width: 340px;
  height: 340px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(16, 50, 93, 0.08), transparent 70%);
  pointer-events: none;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 100;
  backdrop-filter: blur(8px);
  background: rgba(255, 255, 255, 0.97);
  border-bottom: 3px solid var(--navy);
  box-shadow: 0 4px 12px rgba(10, 35, 66, 0.05);
}
.topbar-inner {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  justify-content: start;
  column-gap: 1.2rem;
  row-gap: 0.75rem;
  padding: 0.55rem 0;
}
.brand {
  display: inline-flex; align-items: center; gap: 0.95rem; min-width: 0; flex: 0 0 auto;
}
.brand-mark {
  width: 58px; height: 58px; display: grid; place-items: center; border-radius: 50%;
  color: white;
  background:
    radial-gradient(circle at 32% 30%, rgba(255,255,255,0.28), transparent 28%),
    linear-gradient(180deg, var(--red) 0%, var(--navy) 100%);
  border: 3px solid white;
  box-shadow: 0 0 0 2px rgba(16, 50, 93, 0.16), var(--shadow-soft);
  font-family: "Cinzel", Georgia, serif; font-weight: 700; letter-spacing: 0.08em;
}
.brand-text { display: flex; flex-direction: column; min-width: 0; }
.brand-text strong, .brand-text span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.brand-text strong { font-family: "Cinzel", Georgia, serif; font-size: 1.08rem; color: var(--navy-deep); }
.brand-text span { color: var(--muted); font-size: 0.95rem; }
.site-nav { margin-left: 0; min-width: 0; width: 100%; justify-self: start; }

.nav-list,
.submenu,
.program-card ul,
.site-footer ul,
.link-list,
.info-list,
.feature-list,
.detail-list,
.article-list,
.tier-list,
.simple-list { list-style: none; margin: 0; padding: 0; }

.nav-list { display: flex; align-items: stretch; justify-content: flex-start; gap: 0.35rem; flex-wrap: nowrap; }
.nav-list > li { position: relative; }
.nav-list > li > a,
.submenu-toggle {
  display: inline-flex; align-items: center; justify-content: center; min-height: 46px;
  padding: 0.72rem 0.9rem; border: 1px solid rgba(16, 50, 93, 0.16); background: linear-gradient(180deg, #ffffff 0%, #eef4fd 100%); color: var(--navy-deep);
  border-radius: 0; font-weight: 700; font-size: 0.88rem; line-height: 1.1; white-space: nowrap; cursor: pointer; text-transform: uppercase; letter-spacing: 0.02em; box-shadow: inset 0 -3px 0 rgba(16, 50, 93, 0.06);
}
.submenu-toggle::after { content: "▾"; font-size: 0.8em; margin-left: 0.45rem; }
.nav-list > li > a:hover,
.nav-list > li > a:focus-visible,
.submenu-toggle:hover,
.submenu-toggle:focus-visible,
.nav-list > li > a.is-current,
.submenu-toggle.is-current {
  background: linear-gradient(180deg, #eaf1fb 0%, #dce8f7 100%); color: var(--navy); outline: none; border-color: rgba(16, 50, 93, 0.25); box-shadow: inset 0 -3px 0 rgba(178, 34, 52, 0.18);
}
.submenu {
  position: absolute; top: calc(100% + 0.25rem); left: 0; min-width: 270px; background: rgba(255,255,255,0.99);
  border: 1px solid var(--blue-border); border-radius: 0; box-shadow: var(--shadow);
  padding: 0.55rem; opacity: 0; visibility: hidden; transform: translateY(8px);
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
}
.submenu li a {
  display: block; padding: 0.8rem 0.85rem; border-radius: 0; color: var(--ink);
}
.submenu li a:hover,
.submenu li a:focus-visible,
.submenu li a.is-current { background: rgba(178, 34, 52, 0.08); color: var(--red-deep); outline: none; }
.has-submenu:hover > .submenu,
.has-submenu:focus-within > .submenu,
.has-submenu.is-open > .submenu { opacity: 1; visibility: visible; transform: translateY(0); }
.mega-menu { min-width: 380px; }

.brand-banner {
  display: block;
  width: min(100%, 360px);
  height: auto;
}

@media (min-width: 1025px) {
  .brand-banner { width: 340px; max-width: 100%; }
  .nav-list > li > a,
  .submenu-toggle { padding-inline: 0.6rem; font-size: 0.87rem; }
}

.nav-toggle {
  display: none; width: 48px; height: 48px; border-radius: 12px; border: 1px solid rgba(16, 50, 93, 0.14);
  background: white; padding: 0; cursor: pointer; align-items: center; justify-content: center; flex-direction: column; gap: 5px;
}
.nav-toggle span { width: 22px; height: 2px; background: var(--navy-deep); border-radius: 999px; transition: transform 0.25s ease, opacity 0.2s ease; }
.nav-toggle.is-active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.is-active span:nth-child(2) { opacity: 0; }
.nav-toggle.is-active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.hero,
.page-hero {
  position: relative;
  padding: 4.2rem 0 5rem;
}
.hero::before,
.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(178,34,52,0.12) 0 14px, transparent 14px 100%),
    linear-gradient(135deg, #0b2648 0%, #123967 58%, #1a4c82 100%);
}
.hero::after,
.page-hero::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 12px;
  background: linear-gradient(90deg, var(--red) 0 33.333%, white 33.333% 66.666%, var(--navy) 66.666%);
}
.hero-grid,
.page-hero-grid {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(290px, 0.9fr);
  gap: 2rem;
  align-items: center;
}
.page-hero-grid { align-items: end; }

.eyebrow {
  margin: 0 0 0.65rem; font-size: 0.83rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--red);
}
.hero .eyebrow,
.page-hero .eyebrow,
.eyebrow.light { color: rgba(255,255,255,0.82); }

.hero h1,
.page-hero h1,
.section-heading h2,
.heritage-band h2,
.cta-strip h2,
.content-card h2,
.content-card h3,
.panel-card h2,
.timeline-card h3,
.table-card h2,
.notice-card h2,
.feature-panel h3 {
  margin: 0; font-family: "Cinzel", Georgia, serif; line-height: 1.15; color: var(--navy-deep);
}
.hero h1,
.page-hero h1 {
  color: white; font-size: clamp(2.3rem, 5vw, 4.2rem); max-width: 13ch; text-shadow: 0 2px 14px rgba(0,0,0,0.18);
}
.hero-text,
.page-hero p,
.section-heading p,
.content-card p,
.panel-card p,
.notice-card p,
.program-card p,
.table-card p,
.timeline-card p,
.rich-text p { color: var(--muted); }
.hero .hero-text,
.page-hero p,
.page-hero .breadcrumbs,
.hero-copy > p:not(.eyebrow) { color: rgba(255,255,255,0.88); }

.hero-actions,
.page-actions,
.button-row { display: flex; flex-wrap: wrap; gap: 0.85rem; margin-top: 1.5rem; }
.button {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; min-height: 48px;
  padding: 0.82rem 1.2rem; border-radius: 0; font-weight: 700; text-transform: uppercase; letter-spacing: 0.03em;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}
.button:hover, .button:focus-visible { transform: translateY(-1px); box-shadow: var(--shadow-soft); outline: none; }
.button-primary { background: linear-gradient(135deg, var(--red), var(--red-deep)); color: white; }
.button-secondary { background: rgba(255,255,255,0.1); color: white; border: 1px solid rgba(255,255,255,0.3); }
.button-light { background: white; color: var(--navy-deep); }
.text-link { color: var(--red); font-weight: 700; }
.text-link::after { content: " →"; }
.hero .text-link { color: var(--navy); }

.hero-panel,
.page-hero-panel { display: grid; gap: 1rem; }
.hero-panel-card,
.panel-card,
.notice-card,
.feature-panel,
.side-card {
  background: rgba(255,255,255,0.98);
  border: 1px solid rgba(16,50,93,0.16);
  border-radius: var(--radius);
  padding: 1.4rem;
  box-shadow: var(--shadow-soft);
}
.hero-panel-card { position: relative; overflow: hidden; }
.hero-panel-card::before,
.panel-card::before,
.notice-card::before,
.feature-panel::before,
.side-card::before,
.info-card::before,
.program-card::before,
.content-card::before,
.timeline-card::before,
.table-card::before,
.mini-card::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 6px;
  background: linear-gradient(90deg, var(--red) 0, white 40%, var(--navy) 100%);
}
.hero-panel-card.accent,
.notice-card.accent,
.panel-card.accent {
  background: linear-gradient(145deg, var(--navy-deep), var(--navy));
  color: white;
}
.hero-panel-card.accent h2,
.hero-panel-card.accent p,
.hero-panel-card.accent .card-kicker,
.hero-panel-card.accent .text-link,
.notice-card.accent h2,
.notice-card.accent p,
.notice-card.accent .eyebrow,
.notice-card.accent a,
.panel-card.accent h2,
.panel-card.accent p { color: white; }
.card-kicker,
.kicker { display: inline-block; margin-bottom: 0.5rem; font-size: 0.82rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--red); }

.section { padding: 4.5rem 0; }
.section-heading { max-width: 760px; margin-bottom: 2rem; }
.section-heading.center { margin-left: auto; margin-right: auto; text-align: center; }
.card-grid { display: grid; gap: 1.25rem; }
.four-up { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.three-up { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.two-up { grid-template-columns: repeat(2, minmax(0, 1fr)); }

.info-card,
.program-card,
.content-card,
.timeline-card,
.table-card,
.mini-card {
  position: relative;
  background: white;
  border: 1px solid rgba(16,50,93,0.14);
  border-radius: var(--radius);
  padding: 1.5rem;
  box-shadow: var(--shadow-soft);
}
.info-card,
.mini-card { transition: transform 0.2s ease, box-shadow 0.2s ease; }
.info-card:hover,
.info-card:focus-visible,
.mini-card:hover,
.mini-card:focus-visible { transform: translateY(-3px); box-shadow: var(--shadow); outline: none; }

.quick-links { background: linear-gradient(180deg, rgba(16,50,93,0.02), rgba(255,255,255,0) 35%); }
.heritage-band {
  background:
    linear-gradient(90deg, rgba(16,50,93,0.05), rgba(16,50,93,0.02)),
    linear-gradient(180deg, #f6faff, #eef5fd);
  border-top: 1px solid rgba(16,50,93,0.06);
  border-bottom: 1px solid rgba(16,50,93,0.06);
}
.heritage-grid,
.split-layout,
.content-layout,
.two-column-layout {
  display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr); gap: 1.5rem; align-items: start;
}
.heritage-stats,
.stat-list,
.badge-list { display: grid; gap: 1rem; }
.heritage-stats > div,
.stat-list > div,
.badge-list > div {
  padding: 1.15rem 1.2rem; border-radius: var(--radius-sm); border: 1px solid rgba(16,50,93,0.14); background: rgba(255,255,255,0.96);
  box-shadow: var(--shadow-soft);
}
.heritage-stats strong,
.stat-list strong,
.badge-list strong { display: block; margin-bottom: 0.25rem; color: var(--navy-deep); }
.program-card ul,
.link-list,
.info-list,
.feature-list,
.detail-list,
.simple-list { display: grid; gap: 0.7rem; }
.program-card li a,
.link-list a { color: var(--navy-soft); font-weight: 700; }
.callout-card { background: linear-gradient(180deg, rgba(243,247,253,0.98), rgba(255,255,255,0.98)); }

.cta-strip {
  padding: 3.75rem 0;
  background:
    linear-gradient(90deg, rgba(178,34,52,0.1) 0 12px, transparent 12px 100%),
    linear-gradient(135deg, #0a2342, #12335a);
  color: white;
}
.cta-strip h2,
.cta-strip p { color: white; }
.cta-strip-inner { display: flex; gap: 1.5rem; align-items: center; justify-content: space-between; }

.page-hero { padding-top: 3.25rem; padding-bottom: 4rem; }
.breadcrumbs { margin-bottom: 1rem; color: rgba(255,255,255,0.78); font-size: 0.95rem; }
.breadcrumbs a { color: white; }
.page-shell { padding-bottom: 4.5rem; }
.page-grid { display: grid; grid-template-columns: minmax(0, 1.3fr) minmax(290px, 0.7fr); gap: 1.5rem; align-items: start; }
.main-stack,
.sidebar-stack { display: grid; gap: 1.5rem; }
.content-card h2,
.table-card h2,
.notice-card h2,
.feature-panel h3,
.program-card h3,
.info-card h3 { margin-bottom: 0.75rem; }
.content-card > :first-child,
.notice-card > :first-child,
.table-card > :first-child,
.feature-panel > :first-child,
.panel-card > :first-child { margin-top: 0; }
.content-card > :last-child,
.notice-card > :last-child,
.table-card > :last-child,
.feature-panel > :last-child,
.panel-card > :last-child { margin-bottom: 0; }
.rich-text h3,
.rich-text h4 { font-family: "Cinzel", Georgia, serif; color: var(--navy-deep); margin-bottom: 0.5rem; }
.rich-text p + h3,
.rich-text p + h4,
.rich-text ul + h3,
.rich-text ul + h4 { margin-top: 1.5rem; }
.rich-text ul,
.rich-text ol { margin: 0.75rem 0 0; padding-left: 1.2rem; color: var(--muted); }
.content-card blockquote {
  margin: 1.25rem 0 0; padding: 1rem 1.1rem; border-left: 4px solid var(--red); background: rgba(178,34,52,0.06); border-radius: 0 12px 12px 0;
}
.data-table {
  width: 100%; border-collapse: collapse; overflow: hidden; border-radius: 14px; font-size: 0.98rem; background: white;
}
.data-table th,
.data-table td { padding: 0.9rem 0.95rem; text-align: left; border-bottom: 1px solid rgba(16,50,93,0.08); vertical-align: top; }
.data-table th { background: rgba(16,50,93,0.06); color: var(--navy-deep); font-weight: 700; }
.data-table tr:last-child td { border-bottom: 0; }
.timeline { display: grid; gap: 1rem; }
.timeline-card { position: relative; padding-left: 1.55rem; }
.timeline-card::after {
  content: ""; position: absolute; left: 0; top: 1.75rem; width: 9px; height: 9px; border-radius: 50%; background: var(--red); box-shadow: 0 0 0 6px rgba(178,34,52,0.14);
}
.label-row { display: flex; flex-wrap: wrap; gap: 0.55rem; margin-top: 1rem; }
.pill {
  display: inline-flex; align-items: center; min-height: 34px; padding: 0.35rem 0.8rem; border-radius: 0; background: rgba(16,50,93,0.07); color: var(--navy-deep); font-size: 0.92rem; font-weight: 700;
}
.notice-bar {
  margin-top: 1rem; padding: 0.95rem 1rem; border-radius: 0; background: rgba(16,50,93,0.05); border: 1px solid rgba(16,50,93,0.12);
}
.contact-card a,
.side-card a,
.notice-card a,
.panel-card a { color: var(--red-deep); font-weight: 700; }
.article-list li,
.detail-list li,
.info-list li,
.link-list li,
.feature-list li,
.simple-list li { border-top: 1px solid rgba(16,50,93,0.08); padding-top: 0.7rem; }
.article-list li:first-child,
.detail-list li:first-child,
.info-list li:first-child,
.link-list li:first-child,
.feature-list li:first-child,
.simple-list li:first-child { border-top: 0; padding-top: 0; }

.site-footer {
  background: linear-gradient(180deg, #081c35, #061528);
  color: rgba(255,255,255,0.88);
  padding: 3rem 0 1.4rem;
  position: relative;
}
.site-footer::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 5px;
  background: linear-gradient(90deg, var(--red) 0 33.333%, white 33.333% 66.666%, var(--navy) 66.666%);
}
.footer-grid { display: grid; grid-template-columns: 1.1fr 0.8fr 0.8fr; gap: 1.5rem; }
.site-footer h2,
.site-footer h3 { margin-top: 0; font-family: "Cinzel", Georgia, serif; color: white; }
.site-footer a { color: rgba(255,255,255,0.9); }
.site-footer ul { display: grid; gap: 0.7rem; }
.footer-bottom {
  margin-top: 2rem; padding-top: 1rem; border-top: 1px solid rgba(255,255,255,0.12); color: rgba(255,255,255,0.68); display: flex; flex-wrap: wrap; gap: 0.75rem 1.5rem; justify-content: space-between;
}
.placeholder-note {
  display: inline-flex; align-items: center; gap: 0.45rem; padding: 0.45rem 0.7rem; background: rgba(16,50,93,0.06); border-radius: 999px; color: var(--navy-deep); font-size: 0.9rem; font-weight: 700;
}
.centered-intro { max-width: 760px; }

@media (max-width: 1180px) {
  .nav-toggle { display: inline-flex; }
  .site-nav {
    position: absolute; top: calc(100% + 0.75rem); left: 1rem; right: 1rem; margin-left: 0; background: rgba(255,255,255,0.99);
    border: 1px solid var(--blue-border); border-radius: 0; box-shadow: var(--shadow); padding: 0.8rem; opacity: 0; visibility: hidden; transform: translateY(-8px);
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
  }
  .site-nav.is-open { opacity: 1; visibility: visible; transform: translateY(0); }
  .nav-list { flex-direction: column; align-items: stretch; gap: 0.35rem; }
  .nav-list > li > a,
  .submenu-toggle { width: 100%; justify-content: space-between; border-radius: 0; padding: 0.85rem 0.95rem; }
  .submenu {
    position: static; min-width: 0; margin-top: 0.4rem; padding: 0.4rem; box-shadow: none; border-radius: 14px; opacity: 1; visibility: visible; display: none; transform: none;
  }
  .has-submenu.is-open > .submenu { display: block; }
  .hero-grid,
  .page-hero-grid,
  .heritage-grid,
  .content-layout,
  .split-layout,
  .two-column-layout,
  .page-grid,
  .footer-grid,
  .cta-strip-inner { grid-template-columns: 1fr; }
  .four-up,
  .three-up,
  .two-up { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 760px) {
  .topbar-inner { padding: 0.85rem 0; }
  .brand-mark { width: 50px; height: 50px; font-size: 0.95rem; }
  .brand-text strong { font-size: 0.98rem; }
  .brand-text span { font-size: 0.87rem; }
  .hero,
  .page-hero,
  .section,
  .page-shell,
  .cta-strip { padding-top: 3rem; padding-bottom: 3rem; }
  .hero h1,
  .page-hero h1 { max-width: none; }
  .four-up,
  .three-up,
  .two-up { grid-template-columns: 1fr; }
  .data-table,
  .data-table thead,
  .data-table tbody,
  .data-table th,
  .data-table td,
  .data-table tr { display: block; }
  .data-table thead {
    position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0, 0, 0, 0);
  }
  .data-table tr { border-top: 1px solid rgba(16,50,93,0.08); padding: 0.6rem 0; }
  .data-table td { border: 0; padding: 0.45rem 0; }
  .data-table td::before {
    content: attr(data-label); display: block; font-size: 0.8rem; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; color: var(--navy-soft); margin-bottom: 0.15rem;
  }
  .footer-bottom { flex-direction: column; }
}

@media (max-width: 980px) {
  .brand-banner { width: min(100%, 320px); }
}


@media (max-width: 1024px) {
  .topbar-inner {
    grid-template-columns: 1fr auto;
  }
}


/* Alternate concept: formal rectangular patriotic styling */
.site-header::after {
  right: -160px;
  top: 110px;
  width: 420px;
  height: 420px;
  border-radius: 0;
  background: linear-gradient(135deg, rgba(178,34,52,0.05), rgba(16,50,93,0.03));
  transform: rotate(18deg);
}
.brand-banner {
  border: 1px solid rgba(16,50,93,0.12);
  box-shadow: 0 4px 10px rgba(10,35,66,0.06);
}
.nav-list > li > a,
.submenu-toggle {
  position: relative;
}
.nav-list > li > a::before,
.submenu-toggle::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 3px;
  background: transparent;
}
.nav-list > li > a:hover::before,
.nav-list > li > a:focus-visible::before,
.nav-list > li > a.is-current::before,
.submenu-toggle:hover::before,
.submenu-toggle:focus-visible::before,
.submenu-toggle.is-current::before {
  background: var(--red);
}
.hero-copy {
  max-width: 760px;
}
.hero-panel-card,
.program-card,
.info-card,
.content-card,
.panel-card,
.notice-card,
.feature-panel,
.side-card,
.timeline-card,
.table-card,
.mini-card,
.heritage-stats > div {
  border-left: 4px solid var(--navy);
}
.hero-panel-card.accent,
.notice-card.accent,
.panel-card.accent {
  border-left-color: var(--red);
}
.section-heading h2,
.heritage-band h2,
.cta-strip h2,
.content-card h2,
.content-card h3,
.panel-card h2,
.timeline-card h3,
.table-card h2,
.notice-card h2,
.feature-panel h3 {
  letter-spacing: 0.01em;
}
.quick-links,
.programs,
.page-shell {
  position: relative;
}
.quick-links::before,
.programs::before,
.page-shell::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(16,50,93,0.16), transparent);
}
.data-table {
  border: 1px solid rgba(16,50,93,0.12);
  border-radius: 0;
}
.data-table th {
  background: linear-gradient(180deg, #eef4fb, #e0e9f5);
  border-bottom: 2px solid rgba(16,50,93,0.1);
}
.site-footer {
  border-top: 5px solid var(--red);
}
.footer-grid > div {
  padding-top: 0.25rem;
}
@media (min-width: 1181px) {
  .site-nav {
    padding-left: 0.25rem;
  }
}
