:root {
  --bs-body-font-family: "Roboto Mono", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, monospace;
}

html, body {
  height: 100%;
  font-family: var(--bs-body-font-family);
}

:root {
  --brand: #004a87;
  --brand-2: #25bdd3;
  --gradient: linear-gradient(135deg, var(--brand), var(--brand-2));
  --bs-primary: #004a87;
  --bs-secondary: #25bdd3;
  --bs-primary-rgb: 0, 74, 135;
  --bs-secondary-rgb: 37, 189, 211;
  --bs-nav-link-color: var(--bs-secondary) !important;
  --bs-navbar-active-color: var(--bs-primary) !important;
}

.fw-extrabold {
  font-weight: 800;
}

.brand-logo {
  width: 28px;
  height: 28px;
  background: var(--gradient);
  border-radius: 50%;
}

.hero {
  background: radial-gradient(1200px 400px at -10% -10%, rgba(13, 110, 253, 0.12), transparent 60%), radial-gradient(900px 300px at 110% 10%, rgba(111, 66, 193, 0.12), transparent 60%);
}

.text-gradient {
  background: var(--gradient);
  -webkit-background-clip: text;
  color: transparent;
}

.back-to-top {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  display: none;
  border-radius: 50%;
}

.brand-logo {
  width: 36px;
  height: 36px;
  background: linear-gradient(135deg, #556cff, #6ad7ff);
  display: inline-block;
}

.back-to-top {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  display: none;
  z-index: 1050;
}

.card-img-top {
  -o-object-fit: cover;
     object-fit: cover;
  height: 100%;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 90px;
}

/* Full-page snap behavior */
body {
  scroll-snap-type: y mandatory;
}

.section-fullscreen {
  scroll-snap-align: start;
}

/* Map sizing and rounded look to match the card aesthetic */
#map {
  height: 320px;
  min-height: 240px;
  border-radius: 0.5rem;
}

@media (min-width: 992px) {
  #map {
    height: 360px;
  }
}
/* Make major sections at least full viewport height. Default: top-aligned so long content flows naturally. */
.section-fullscreen {
  display: flex;
  align-items: flex-start;
}

.section-fullscreen .container {
  width: 100%;
}

/* Modifier to vertically center smaller sections */
.section-fullscreen.center {
  align-items: center;
}

/* Keep spacing consistent when content is taller than viewport */
@media (max-width: 767px) {
  .section-fullscreen {
    padding-top: 2rem;
    padding-bottom: 2rem;
  }
}
.product-card {
  position: relative;
  overflow: hidden;
}
.product-card .product-image {
  width: 100%;
  height: auto;
  max-width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transform-origin: top;
  transform: scale(1.1);
  aspect-ratio: 16/8;
  padding-bottom: 1.5rem;
}

#navContent .nav-link {
  color: var(--bs-secondary) !important;
}
#navContent .nav-link.active {
  color: var(--bs-primary) !important;
}
/*# sourceMappingURL=styles.css.map */
