/**
 * JAX Car Keys – Bootstrap 5 site styles
 * One framework (BS5), no page renames, content preserved.
 */

:root {
  --jax-font-body: "Manrope", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
  --jax-font-display: "Sora", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
}

body {
  font-family: var(--jax-font-body);
  font-size: 1rem;
  line-height: 1.6;
}

h1, h2, h3, h4, h5, h6,
.jax-hero-title,
.jax-hero-lead {
  font-family: var(--jax-font-display);
  letter-spacing: -0.01em;
}


/* Skip link (visually hidden until focused) */
.skip-link { position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden; }
.skip-link:focus, .visually-hidden-focusable:focus { position: static; width: auto; height: auto; margin: 0.5rem; padding: 0.5rem 1rem; background: #fff; color: #000; z-index: 1000; border-radius: 0.25rem; box-shadow: 0 2px 6px rgba(0,0,0,0.15); }


/* ---- Nav: fixed top + spacer ---- */
.jax-nav .navbar {
  box-shadow: 0 1px 0 rgba(0,0,0,0.08);
  min-height: 70px;
}
.jax-nav .navbar-brand {
  padding: 0.5rem 1rem;
}
.jax-nav .navbar-brand img {
  max-height: 46px;
  width: auto;
}
.jax-nav .nav-link {
  font-weight: 600;
  color: #333 !important;
  padding: 0.6rem 1rem !important;
}
.jax-nav .nav-link:hover,
.jax-nav .nav-link:focus {
  color: #2dc0e8 !important;
}
.jax-nav .dropdown-menu .dropdown-item:hover {
  color: #2dc0e8;
  background-color: #f8f9fa;
}
.jax-nav-cta .btn {
  background: #2dc0e8;
  color: #fff;
  font-weight: 600;
  border-radius: 0.375rem;
  padding: 0.5rem 1rem;
}
.jax-nav-cta .btn:hover {
  background: #25a8cc;
  color: #fff;
}
.jax-nav-spacer {
  min-height: 70px;
}

/* ---- Legacy grid compatibility: keep container/columns working ---- */
.container .sixteen.columns { width: 100%; }
.container .eight.columns.alpha { width: 48%; float: left; margin-right: 2%; }
.container .eight.columns.omega { width: 48%; float: left; margin-left: 0; }
.container .four.columns.alpha { width: 23%; float: left; margin-right: 2%; }
.container .four.columns { width: 23%; float: left; margin-right: 2%; }
.container .four.columns.omega { width: 23%; float: left; margin-left: 0; }
.container .six.columns.omega { width: 48%; float: left; }
.container .ten.columns.alpha { width: 62%; float: left; margin-right: 2%; }
.container::after { content: ""; display: table; clear: both; }
@media (max-width: 991px) {
  .container .eight.columns.alpha,
  .container .eight.columns.omega,
  .container .four.columns.alpha,
  .container .four.columns,
  .container .four.columns.omega,
  .container .six.columns.omega,
  .container .ten.columns.alpha { width: 100%; float: none; margin: 0 0 1rem 0; }
}

/* ---- Share icons (Feather) ---- */
.jax-share .bottom-icons { list-style: none; padding: 0; margin: 0; display: flex; gap: 0.5rem; }
.jax-share .bottom-icons li a { display: inline-flex; color: #888; }
.jax-share .bottom-icons li a:hover { color: #2dc0e8; }
.jax-share [data-feather] { stroke: currentColor; }
.jax-share a { display: inline-flex; color: #888; }
.jax-share a:hover { color: #2dc0e8; }

/* ---- Index: brand primary (BS5 override) ---- */
.jax-hero .btn-primary,
.jax-pricing-cards .btn-primary { background-color: #2dc0e8; border-color: #2dc0e8; }
.jax-hero .btn-primary:hover,
.jax-pricing-cards .btn-primary:hover { background-color: #25a8cc; border-color: #25a8cc; }
.jax-hero .btn-outline-primary { border-color: #2dc0e8; color: #2dc0e8; }
.jax-hero .btn-outline-primary:hover { background-color: #2dc0e8; color: #fff; }
.jax-hero .text-primary { color: #2dc0e8 !important; }

/* ---- Index: hero ---- */
.jax-hero { background: #fff; }
.jax-hero-lead { font-size: clamp(1.4rem, 3vw, 2.2rem); }
.jax-hero-title { font-size: clamp(1.75rem, 4.8vw, 3.25rem); }
.jax-img-rounded { border-radius: 1rem; }
.jax-trust-bullets { list-style: none; padding-left: 0; }
.jax-trust-bullets li { position: relative; padding-left: 1.25rem; margin-bottom: 0.35rem; }
.jax-trust-bullets li::before { content: ""; position: absolute; left: 0.15rem; top: 0.45rem; width: .5rem; height: .5rem; background: #2dc0e8; border-radius: 50%; }

/* ---- Index: why choose ---- */
.jax-why .opacity-90 { opacity: 0.9; }

/* ---- Index: services ---- */
.jax-services .text-primary { color: #2dc0e8 !important; }
.jax-services .card { border-radius: 0.75rem; }
.jax-services .card-body a:hover { text-decoration: underline; }

/* ---- Index: reviews ---- */
.jax-reviews { background: #333; }
.jax-review-card { background: rgba(255,255,255,0.08); padding: 1.5rem; border-radius: 0.75rem; }

/* ---- Index: pricing ---- */
.jax-price { color: #e69138; }
.jax-pricing-item { background: #fff; border-radius: 0.75rem; padding: 1.25rem 0.75rem; box-shadow: 0 4px 14px rgba(0,0,0,0.05); height: 100%; }

/* ---- Index: pricing cards ---- */
.jax-pricing-cards .text-primary { color: #2dc0e8 !important; }
.jax-pricing-cards .btn-warning { background-color: #f77825; border-color: #f77825; }
.jax-pricing-cards .card { border-radius: 0.85rem; }

/* ---- Index: contact ---- */
.jax-contact-feature { background: #fff; border-radius: 0.75rem; padding: 1rem; box-shadow: 0 6px 16px rgba(0,0,0,0.06); }
.jax-contact-icon { font-size: 0; display: inline-flex; align-items: center; justify-content: center; width: 1.75rem; height: 1.75rem; color: #2dc0e8; }
.jax-contact-icon svg { width: 1.75rem; height: 1.75rem; }

/* ---- Index: footer ---- */
.jax-footer a:hover { color: #fff !important; }

@media (min-width: 992px) {
  body { font-size: 1.05rem; }
  .jax-hero-title { font-size: clamp(2.5rem, 4.5vw, 3.75rem); }
  .jax-hero-lead { font-size: clamp(1.8rem, 2.8vw, 2.4rem); }
  .jax-services h3 { font-size: 1.15rem; }
  .jax-reviews .fs-5 { font-size: 1.35rem !important; }
  .jax-pricing-cards .fs-3 { font-size: 2rem !important; }
}
