:root,
[data-bs-theme="light"] {
  --bs-primary: #004890;
  --bs-primary-rgb: 0, 72, 144;
  --bs-success: #00a78d;
  --bs-success-rgb: 0, 167, 141;
  --bs-primary-text-emphasis: #00366d;
  --bs-success-text-emphasis: #006e5f;
  --bs-primary-bg-subtle: #d6e6f7;
  --bs-success-bg-subtle: #cff5ee;
  --bs-primary-border-subtle: #8fb3da;
  --bs-success-border-subtle: #77d8c9;
  --bs-body-color: #2f3a45;
  --bs-secondary-color: #556270;
  --bs-body-bg: #ffffff;
  --bs-emphasis-color: #1d2731;
  --bs-link-color: #004890;
  --bs-link-hover-color: #00386f;
  --bs-focus-ring-color: rgba(0, 72, 144, 0.25);
  --bs-font-sans-serif: "Inter", sans-serif;
}

.btn-primary {
  --bs-btn-color: #ffffff;
  --bs-btn-bg: #004890;
  --bs-btn-border-color: #004890;
  --bs-btn-hover-color: #ffffff;
  --bs-btn-hover-bg: #003f7d;
  --bs-btn-hover-border-color: #003a74;
  --bs-btn-focus-shadow-rgb: 0, 72, 144;
  --bs-btn-active-color: #ffffff;
  --bs-btn-active-bg: #00366d;
  --bs-btn-active-border-color: #003262;
  --bs-btn-disabled-color: #ffffff;
  --bs-btn-disabled-bg: #004890;
  --bs-btn-disabled-border-color: #004890;
}

.btn-success {
  --bs-btn-color: #ffffff;
  --bs-btn-bg: #00a78d;
  --bs-btn-border-color: #00a78d;
  --bs-btn-hover-color: #ffffff;
  --bs-btn-hover-bg: #00947d;
  --bs-btn-hover-border-color: #008d77;
  --bs-btn-focus-shadow-rgb: 0, 167, 141;
  --bs-btn-active-color: #ffffff;
  --bs-btn-active-bg: #00816d;
  --bs-btn-active-border-color: #007565;
  --bs-btn-disabled-color: #ffffff;
  --bs-btn-disabled-bg: #00a78d;
  --bs-btn-disabled-border-color: #00a78d;
}

.btn-outline-primary {
  --bs-btn-color: #004890;
  --bs-btn-border-color: #004890;
  --bs-btn-hover-color: #ffffff;
  --bs-btn-hover-bg: #004890;
  --bs-btn-hover-border-color: #004890;
  --bs-btn-focus-shadow-rgb: 0, 72, 144;
  --bs-btn-active-color: #ffffff;
  --bs-btn-active-bg: #003a74;
  --bs-btn-active-border-color: #003a74;
  --bs-btn-disabled-color: #004890;
  --bs-btn-disabled-border-color: #004890;
}

.btn-outline-success {
  --bs-btn-color: #00a78d;
  --bs-btn-border-color: #00a78d;
  --bs-btn-hover-color: #ffffff;
  --bs-btn-hover-bg: #00a78d;
  --bs-btn-hover-border-color: #00a78d;
  --bs-btn-focus-shadow-rgb: 0, 167, 141;
  --bs-btn-active-color: #ffffff;
  --bs-btn-active-bg: #00816d;
  --bs-btn-active-border-color: #00816d;
  --bs-btn-disabled-color: #00a78d;
  --bs-btn-disabled-border-color: #00a78d;
}

html {
  scroll-behavior: smooth;
}

body {
  color: #2f3a45;
  background-color: #ffffff;
}

.py-xl-6 {
  padding-top: 6rem;
  padding-bottom: 6rem;
}

.tracking-wide {
  letter-spacing: 0.12em;
}

.bg-hero-gradient {
  background:
    radial-gradient(circle at 15% 20%, rgba(0, 167, 141, 0.14), transparent 30%),
    radial-gradient(circle at 90% 15%, rgba(0, 72, 144, 0.12), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, #eff5fb 100%);
}

.hero-image-shell {
  transform: rotate(-2deg);
}

.hero-image {
  min-height: 320px;
  max-height: 560px;
  object-fit: cover;
}

#site-navbar {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 180ms ease, transform 180ms ease;
}

.home-page #site-navbar {
  opacity: 0;
  transform: translateY(-18px);
  pointer-events: none;
}

.home-page #site-navbar.navbar-visible,
.content-page #site-navbar {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.icon-chip {
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 1.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
}

.icon-chip-large {
  width: 4.5rem;
  height: 4.5rem;
  font-size: 1.9rem;
}

.champion-avatar {
  width: 5rem;
  height: 5rem;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.18);
  display: grid;
  place-items: center;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.carousel-control-button {
  width: 3rem;
  height: 3rem;
}

.action-card {
  cursor: pointer;
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.action-card:hover,
.action-card:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 0.75rem 1.5rem rgba(0, 72, 144, 0.12) !important;
  border-color: rgba(0, 72, 144, 0.25) !important;
}

.map-shell {
  background: #ffffff;
}

.campaign-map {
  width: 100%;
  min-height: 440px;
}

.leaflet-container {
  font-family: "Inter", sans-serif;
}

.leaflet-touch .leaflet-control-layers,
.leaflet-touch .leaflet-bar {
  border: 1px solid #d5e1ec;
}

.map-legend-swatch {
  width: 1.1rem;
  height: 1.1rem;
  border-radius: 0.2rem;
  border: 1px solid #004890;
  background: rgba(0, 167, 141, 0.3);
  display: inline-block;
}

.content-copy p,
.content-copy li {
  color: #4d5a67;
  font-size: 1.0625rem;
  line-height: 1.75;
}

.content-copy h2,
.content-copy h3 {
  margin-top: 2rem;
  margin-bottom: 1rem;
  font-weight: 600;
}

.content-copy ul {
  padding-left: 1.2rem;
}

@media (max-width: 991.98px) {
  .home-page #site-navbar .navbar-collapse {
    background: #ffffff;
    margin-top: 1rem;
    padding: 1rem 0;
  }
}

@media (min-width: 1200px) {
  .display-3 {
    font-size: 4.2rem;
  }

  .campaign-map {
    min-height: 520px;
  }
}
