/*
  Snell Tech Consulting LLC
  Bootstrap-enhanced static SPA
  No build step. Cloudflare Pages ready.
*/

:root {
  --stc-primary: #145c7a;
  --stc-primary-rgb: 20, 92, 122;
  --stc-accent: #2f855a;
  --stc-page-wash: #eef6f9;
  --stc-card-shadow: 0 1.25rem 4rem rgba(20, 32, 51, 0.12);
  --stc-soft-shadow: 0 0.75rem 2rem rgba(20, 32, 51, 0.08);
}

[data-bs-theme="dark"] {
  --stc-primary: #79d0f2;
  --stc-primary-rgb: 121, 208, 242;
  --stc-accent: #7bdca6;
  --stc-page-wash: #0e1c23;
  --stc-card-shadow: 0 1.25rem 4rem rgba(0, 0, 0, 0.38);
  --stc-soft-shadow: 0 0.75rem 2rem rgba(0, 0, 0, 0.28);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  min-height: 100vh;
  background: linear-gradient(180deg, var(--stc-page-wash), var(--bs-body-bg) 22rem);
  overflow-wrap: break-word;
}

#app {
  min-height: calc(100vh - 154px);
  outline: none;
}

.site-navbar {
  background: rgba(var(--bs-body-bg-rgb), 0.94);
  backdrop-filter: blur(18px);
}

.brand-mark {
  display: block;
  width: 2.75rem;
  height: 2.75rem;
  flex: 0 0 auto;
}

.brand-mark img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.brand-subtitle {
  color: var(--bs-secondary-color);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
}

.nav-link.active {
  color: var(--stc-primary) !important;
  background: rgba(var(--stc-primary-rgb), 0.12);
  font-weight: 700;
}

.skip-link {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  z-index: 2000;
  padding: 0.6rem 0.9rem;
  border-radius: 999px;
  background: var(--bs-body-color);
  color: var(--bs-body-bg);
}

.hero {
  padding: clamp(3rem, 6vw, 5.5rem) 0;
}

.hero-title {
  max-width: 12ch;
  font-size: clamp(2.65rem, 6.2vw, 5.25rem);
  letter-spacing: 0;
  line-height: 0.95;
}

.hero-lede {
  max-width: 42rem;
  font-size: clamp(1.1rem, 2vw, 1.3rem);
}

.hero-brand-panel {
  display: grid;
  gap: 1.25rem;
  overflow: hidden;
  border: 1px solid var(--bs-border-color);
  border-radius: 0.5rem;
  padding: clamp(1.5rem, 4vw, 3rem);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(235, 245, 251, 0.96)),
    var(--bs-body-bg);
  box-shadow: var(--stc-card-shadow);
}

.hero-brand-image,
.wordmark-image {
  display: block;
  width: 100%;
  height: auto;
}

.hero-brand-image {
  max-width: 100%;
  object-fit: contain;
}

.wordmark-image {
  max-width: 24rem;
  aspect-ratio: 4 / 1;
  object-fit: contain;
}

.brand-values {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem 1.15rem;
  align-items: center;
  justify-content: center;
  border-radius: 0.5rem;
  padding: 1rem;
  color: #fff;
  background: linear-gradient(135deg, #061a31, #0d3c51);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.brand-values span {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
}

.brand-values span:not(:first-child)::before {
  content: "";
  width: 0.35rem;
  height: 0.35rem;
  border-radius: 999px;
  background: #1c78d8;
}

.kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  width: fit-content;
  border: 1px solid var(--bs-border-color);
  background: rgba(var(--bs-body-bg-rgb), 0.84);
  color: var(--stc-primary);
  font-size: 0.88rem;
  font-weight: 800;
}

.kicker::before {
  content: "";
  width: 0.55rem;
  height: 0.55rem;
  border-radius: 999px;
  background: var(--stc-accent);
}

.stc-card {
  border: 1px solid var(--bs-border-color);
  border-radius: 0.5rem;
  box-shadow: var(--stc-card-shadow);
  background: var(--bs-body-bg);
}

[data-bs-theme="dark"] .stc-card {
  background: var(--bs-body-bg);
}

.overview-item {
  border: 1px solid var(--bs-border-color);
  border-radius: 0.5rem;
  background: var(--bs-tertiary-bg);
}

.status-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: var(--stc-accent);
  background: rgba(47, 133, 90, 0.14);
  font-size: 0.8rem;
  font-weight: 800;
  white-space: nowrap;
}

.status-pill::before {
  content: "";
  width: 0.48rem;
  height: 0.48rem;
  border-radius: 999px;
  background: var(--stc-accent);
}

.section-pad {
  padding: clamp(3.5rem, 7vw, 6rem) 0;
}

.section-title {
  max-width: 12ch;
  font-size: clamp(2.35rem, 5vw, 4rem);
  letter-spacing: 0;
  line-height: 1;
}

.text-max {
  max-width: 48rem;
}

.icon-chip {
  display: inline-grid;
  width: 2.35rem;
  height: 2.35rem;
  place-items: center;
  border-radius: 0.5rem;
  color: var(--stc-primary);
  background: rgba(var(--stc-primary-rgb), 0.12);
  font-weight: 900;
}

.product-badge {
  width: fit-content;
  color: var(--stc-primary);
  background: rgba(var(--stc-primary-rgb), 0.12);
}

.btn-primary {
  --bs-btn-bg: #145c7a;
  --bs-btn-border-color: #145c7a;
  --bs-btn-hover-bg: #0d3c51;
  --bs-btn-hover-border-color: #0d3c51;
  --bs-btn-active-bg: #0d3c51;
  --bs-btn-active-border-color: #0d3c51;
}

[data-bs-theme="dark"] .btn-primary {
  --bs-btn-color: #06141a;
  --bs-btn-bg: #79d0f2;
  --bs-btn-border-color: #79d0f2;
  --bs-btn-hover-color: #06141a;
  --bs-btn-hover-bg: #9adcf4;
  --bs-btn-hover-border-color: #9adcf4;
  --bs-btn-active-color: #06141a;
  --bs-btn-active-bg: #9adcf4;
  --bs-btn-active-border-color: #9adcf4;
}

.footer-link {
  color: var(--bs-secondary-color);
  text-decoration: none;
  font-weight: 700;
}

.footer-link:hover,
.footer-link:focus-visible {
  color: var(--stc-primary);
  text-decoration: underline;
}

.theme-toggle {
  min-width: 5.25rem;
}

.fw-black {
  font-weight: 900;
}

.btn:focus-visible,
.nav-link:focus-visible,
.footer-link:focus-visible {
  box-shadow: 0 0 0 0.2rem rgba(var(--stc-primary-rgb), 0.24);
  outline: 0;
}

@supports (background: color-mix(in srgb, white 50%, black)) {
  .site-navbar {
    background: color-mix(in srgb, var(--bs-body-bg) 94%, transparent);
  }

  .kicker {
    background: color-mix(in srgb, var(--bs-body-bg) 84%, transparent);
  }

  .status-pill {
    background: color-mix(in srgb, var(--stc-accent) 14%, transparent);
  }
}

@media (max-width: 575.98px) {
  .hero {
    padding: 3.25rem 0 2.25rem;
  }

  .hero-title {
    max-width: 12ch;
    font-size: clamp(2.55rem, 15vw, 3.4rem);
  }

  .section-title {
    max-width: 14ch;
    font-size: clamp(2rem, 12vw, 2.6rem);
  }

  .navbar-brand {
    max-width: calc(100vw - 8.5rem);
  }

  .navbar-brand > span:last-child {
    min-width: 0;
  }

  .navbar-brand .d-block {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .brand-subtitle {
    display: none;
  }

  .theme-toggle {
    min-width: auto;
  }

  .wordmark-image {
    max-width: 100%;
  }
}
