﻿:root {
  --site-bg: #f4f1ec;
  --site-panel: #fffdfa;
  --site-panel-soft: #f8f5ef;
  --site-ink: #161616;
  --site-muted: #67615b;
  --site-line: #d9d2c8;
  --site-accent: #b3131b;
  --site-accent-deep: #8f0f16;
  --site-dark: #111111;
  --site-radius: 24px;
  --site-radius-sm: 16px;
  --site-shadow: 0 14px 40px rgba(17, 17, 17, 0.06);
  --legacy-categories-column: 230px;
  --font-body: "Manrope", sans-serif;
  --font-display: "Roboto Condensed", sans-serif;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body.site-body {
  margin: 0;
  background: var(--site-bg);
  color: var(--site-ink);
  font-family: var(--font-body);
  font-synthesis: none;
  overflow-x: hidden;
}

button,
input,
select,
textarea {
  font-family: var(--font-body);
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  max-width: 100%;
  display: block;
}

h1,
h2,
h3,
h4,
.brand-main {
  font-family: var(--font-display);
}

.mobile-only {
  display: none !important;
}

.desktop-only {
  display: block;
}

.visually-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.btn-brand {
  background: var(--site-accent);
  border-color: var(--site-accent);
  color: #fff;
}

.btn-brand:hover,
.btn-brand:focus {
  background: var(--site-accent-deep);
  border-color: var(--site-accent-deep);
  color: #fff;
}

.btn-icon-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  white-space: nowrap;
}

.btn-icon-label i {
  font-size: 0.92em;
}

.page-shell {
  min-height: 100vh;
  overflow-x: clip;
}

body.legacy-nav-body {
  background: #efefef;
}

.legacy-header {
  --legacy-header-edge-inset: 0.85rem;
  --legacy-search-edge-inset: 0.2rem;
  position: sticky;
  top: 0;
  z-index: 60;
  background: #000;
  color: #fff;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 14px 32px rgba(0, 0, 0, 0.16);
  backdrop-filter: blur(10px);
}

.legacy-topbar {
  background: #08090b;
  color: rgba(255, 255, 255, 0.86);
  font-size: 0.8rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.legacy-topbar-inner,
.legacy-topbar-links,
.legacy-brand-row,
.legacy-brand-side,
.legacy-header-tools,
.legacy-oem-strip,
.legacy-main-nav,
.legacy-search-shell,
.legacy-categories-toggle {
  display: flex;
  align-items: center;
}

.legacy-topbar-inner,
.legacy-brand-row {
  justify-content: space-between;
  gap: 1rem;
}

.legacy-topbar-inner {
  min-height: 34px;
}

.legacy-topbar-links {
  justify-content: flex-end;
  gap: 0.65rem;
  flex-wrap: wrap;
  margin-right: var(--legacy-header-edge-inset);
}

.legacy-topbar-copy {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  color: rgba(255, 255, 255, 0.88);
}

.legacy-topbar-eyebrow {
  display: inline-flex;
  align-items: center;
  min-height: 20px;
  padding: 0 0.45rem;
  border-radius: 999px;
  background: rgba(212, 0, 0, 0.18);
  color: #ffd7d7;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.legacy-topbar-links a,
.legacy-topbar-links span {
  color: rgba(255, 255, 255, 0.9);
}

.legacy-topbar-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  min-height: 24px;
  padding: 0 0.55rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.04);
  white-space: nowrap;
}

.legacy-topbar-pill-icon {
  width: 0.9rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.78rem;
  line-height: 1;
  flex: 0 0 auto;
}

.legacy-topbar-pill:hover {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.08);
}

.legacy-topbar-rating {
  color: #ffe596;
}

.legacy-topbar-rating .legacy-topbar-pill-icon {
  color: #ffdf2d;
}

.legacy-brand-row {
  padding: 1rem 0 1rem;
  position: relative;
}

.legacy-brand-side {
  gap: 1rem;
  min-width: 0;
  flex: 1;
}

.legacy-site-logo {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  min-height: 58px;
  margin-left: var(--legacy-header-edge-inset);
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.legacy-site-logo img {
  width: 228px;
  height: auto;
}

.legacy-oem-strip {
  flex: 1 1 auto;
  min-width: 0;
  justify-content: space-between;
  gap: clamp(0.85rem, 1.3vw, 1.5rem);
  flex-wrap: nowrap;
  min-height: 58px;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.legacy-oem-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 1 auto;
  opacity: 0.92;
  padding: 0;
  transition: opacity 0.18s ease, transform 0.18s ease;
}

.legacy-oem-link:hover {
  opacity: 1;
  transform: translateY(-1px);
}

.legacy-oem-link img {
  width: auto;
}

.legacy-header-tools {
  gap: 0.65rem;
  flex: 0 0 auto;
  margin-right: var(--legacy-header-edge-inset);
}

.legacy-tool-box {
  min-height: 58px;
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  padding: 0.7rem 1rem;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.04);
  color: #fff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
  transition: border-color 0.18s ease, background 0.18s ease, transform 0.18s ease;
}

.legacy-tool-box:hover {
  color: #fff;
  border-color: rgba(212, 0, 0, 0.5);
  background: rgba(255, 255, 255, 0.08);
  transform: translateY(-1px);
}

.legacy-tool-icon-wrap {
  position: relative;
  width: 34px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.legacy-tool-icon {
  width: auto;
  text-align: center;
  font-size: 1rem;
  line-height: 1;
}

.legacy-tool-badge {
  position: absolute;
  top: -7px;
  right: -7px;
  min-width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 0.25rem;
  border-radius: 999px;
  background: #d40000;
  color: #fff;
  font-size: 0.68rem;
  font-style: normal;
  font-weight: 800;
  line-height: 1;
  box-shadow: 0 6px 16px rgba(212, 0, 0, 0.32);
}

.legacy-tool-copy {
  display: grid;
  gap: 0.1rem;
}

.legacy-tool-copy strong,
.legacy-tool-copy small {
  line-height: 1.1;
}

.legacy-tool-copy small {
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.74rem;
}

.legacy-lang-switch {
  display: inline-flex;
  gap: 0.25rem;
  margin-left: 0.1rem;
  padding: 0.15rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.legacy-lang-switch a {
  min-width: 32px;
  min-height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 0.35rem;
  border-radius: 999px;
  color: rgba(255, 255, 255, 0.75);
}

.legacy-lang-switch a.active {
  color: #fff;
  background: rgba(255, 255, 255, 0.12);
}

.legacy-search-row {
  padding-bottom: 1rem;
}

.legacy-search-form {
  position: relative;
  margin-right: var(--legacy-search-edge-inset);
}

.legacy-search-shell {
  position: relative;
  gap: 0;
  padding: 0;
  border: 0;
  border-radius: 20px;
  background: transparent;
  box-shadow: none;
}

.legacy-search-shell input {
  width: 100%;
  min-width: 0;
  height: 56px;
  padding: 0 4.85rem 0 1.25rem;
  border: 0;
  outline: 0;
  border-radius: 18px;
  background: #fff;
  color: #111;
  box-shadow: inset 0 1px 1px rgba(17, 17, 17, 0.05);
}

.legacy-search-button {
  position: absolute;
  top: 50%;
  right: 0;
  width: 58px;
  height: 56px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 0 18px 18px 0;
  background: #d70000;
  color: #fff;
  font-size: 1rem;
  box-shadow: inset 1px 0 0 rgba(255, 255, 255, 0.14);
  transform: translateY(-50%);
  transition: background 0.18s ease, transform 0.18s ease;
}

.legacy-search-button:hover,
.legacy-search-button:focus {
  background: #b90000;
  transform: translateY(-50%);
}

.legacy-search-button i {
  transition: opacity 0.14s ease;
}

.legacy-search-button::after,
.live-search-shell:not(.legacy-search-shell)::after {
  content: "";
  position: absolute;
  width: 18px;
  height: 18px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 999px;
  opacity: 0;
  pointer-events: none;
  animation: liveSearchSpin 680ms linear infinite;
}

.legacy-search-button::after {
  inset: calc(50% - 9px) auto auto calc(50% - 9px);
}

.legacy-search-shell.is-loading .legacy-search-button i {
  opacity: 0;
}

.legacy-search-shell.is-loading .legacy-search-button::after {
  opacity: 1;
}

.live-search-shell:not(.legacy-search-shell) {
  position: relative;
}

.live-search-shell:not(.legacy-search-shell)::after {
  right: 1rem;
  top: calc(50% - 9px);
  color: var(--site-accent);
}

.live-search-shell:not(.legacy-search-shell).is-loading::after {
  opacity: 1;
}

@keyframes liveSearchSpin {
  to {
    transform: rotate(360deg);
  }
}

.legacy-search-form .search-suggestions {
  left: 0;
  right: 0;
  top: calc(100% + 0.35rem);
}

.legacy-nav-bar {
  display: grid;
  grid-template-columns: var(--legacy-categories-column) minmax(0, 1fr) auto;
  position: relative;
  background: #23252a;
  border-radius: 18px 18px 0 0;
  overflow: visible;
  box-shadow: 0 18px 35px rgba(0, 0, 0, 0.12);
}

.legacy-categories-nav,
.legacy-nav-dropdown {
  position: static;
}

.legacy-categories-toggle {
  width: 100%;
  justify-content: space-between;
  min-height: 48px;
  padding: 0 1.1rem;
  border: 0;
  background: #d40000;
  color: #fff;
  font-weight: 800;
  text-transform: none;
  border-radius: 18px 0 0 0;
  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.12);
}

.legacy-toggle-icon {
  min-width: 0.95rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.88rem;
  line-height: 1;
}

.legacy-main-nav {
  min-width: 0;
  position: static;
  gap: 0.1rem;
}

.legacy-nav-item {
  position: relative;
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  padding: 0 1rem;
  color: #fff;
  font-size: 0.92rem;
  font-weight: 700;
  white-space: nowrap;
  transition: color 0.18s ease, background 0.18s ease;
}

.legacy-nav-item::after {
  content: "";
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 0;
  height: 2px;
  border-radius: 999px;
  background: transparent;
  transition: background 0.18s ease;
  display: none;
}

.legacy-nav-item:hover,
.legacy-nav-item:focus,
.legacy-nav-item.active,
.legacy-nav-highlight,
.legacy-categories-nav.active > .legacy-categories-toggle,
.legacy-categories-nav.legacy-open > .legacy-categories-toggle,
.legacy-nav-dropdown.legacy-open > a {
  color: #ffdf2d;
}

.legacy-nav-item:hover,
.legacy-nav-item:focus,
.legacy-nav-dropdown.legacy-open > a {
  background: rgba(255, 255, 255, 0.04);
}

.legacy-nav-item:hover::after,
.legacy-nav-item:focus::after,
.legacy-nav-item.active::after,
.legacy-nav-highlight::after {
  background: #ffdf2d;
}

.legacy-caret {
  margin-left: 0.42rem;
  font-size: 0.68rem;
  line-height: 1;
  transform: translateY(1px);
}

.legacy-nav-gifts {
  gap: 0.18rem;
}

.legacy-nav-gift-badge {
  color: #e10000;
  font-size: 0.7rem;
  line-height: 1;
  margin-left: 0.18rem;
  transform: translateY(-0.48em);
}

.legacy-mobile-gift-icon {
  color: #e10000;
  font-size: 0.82em;
  margin-left: 0.25rem;
}

.legacy-mega,
.legacy-categories-mega {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  width: 100%;
  background: #fff;
  color: #161616;
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.18);
  border: 1px solid #d9d9d9;
  border-top: 0;
  border-radius: 0 0 18px 18px;
  z-index: 70;
}

.legacy-nav-dropdown.legacy-open > .legacy-mega,
.legacy-categories-nav.legacy-open > .legacy-categories-mega {
  display: grid;
}

.legacy-shared-mega-host {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  z-index: 75;
}

.legacy-shared-mega-host.legacy-open {
  display: block;
}

.legacy-shared-mega-host > .legacy-mega {
  display: none;
  position: static;
  width: 100%;
  margin: 0;
  border-top: 0;
  border-radius: 0 0 18px 18px;
}

.legacy-shared-mega-host > .legacy-mega.legacy-open {
  display: grid;
}

.legacy-mega-panel-shell {
  display: grid;
  gap: 1rem;
}

.legacy-mega-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-bottom: 0.8rem;
  border-bottom: 1px solid #e6e6e6;
}

.legacy-mega-head h3 {
  margin: 0;
  font-size: 1.1rem;
  color: #222;
}

.legacy-mega-more {
  color: #c10000;
  font-weight: 800;
  white-space: nowrap;
}

.legacy-categories-mega {
  width: 100%;
  grid-template-columns: var(--legacy-categories-column) minmax(0, 1fr);
  min-height: 520px;
  align-items: stretch;
  overflow: hidden;
}

.legacy-category-roots {
  display: grid;
  align-content: start;
  background: #f6f6f6;
  border-right: 1px solid #dddddd;
}

.legacy-root-link {
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0 1rem;
  border: 0;
  border-bottom: 1px solid #e7e7e7;
  background: transparent;
  text-align: left;
  color: #1b1b1b;
}

.legacy-root-link.active,
.legacy-root-link:hover {
  background: #fff;
  color: #d40000;
}

.legacy-arrow {
  color: #555;
  font-style: normal;
}

.legacy-category-panels {
  min-width: 0;
  min-height: 520px;
  max-height: 520px;
  padding: 1.2rem 1.35rem;
  background: #fff;
  overflow: auto;
}

.legacy-root-panel {
  display: none;
  column-count: 3;
  column-gap: 1.35rem;
  align-content: start;
  min-height: 100%;
}

.legacy-root-panel.active {
  display: block;
}

.legacy-category-group {
  display: inline-block;
  width: 100%;
  margin: 0 0 1rem;
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  page-break-inside: avoid;
}

.legacy-category-group h4 {
  margin: 0 0 0.65rem;
  padding-bottom: 0.55rem;
  border-bottom: 1px solid #dddddd;
  font-size: 1rem;
  color: #252525;
}

.legacy-category-group h4 a {
  color: inherit;
}

.legacy-category-group ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.4rem;
}

.legacy-category-group li a {
  color: #3a3a3a;
  font-size: 0.93rem;
}

.legacy-category-group li + li {
  margin-top: 0.15rem;
}

.legacy-brand-mega {
  width: 100%;
  padding: 1rem;
}

.legacy-brand-mega-grid {
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 0.85rem;
}

.legacy-brand-logo-item {
  min-height: 64px;
  display: grid;
  place-items: center;
  padding: 0.45rem;
  border: 1px solid #efefef;
}

.legacy-brand-logo-item img {
  max-width: 100%;
  max-height: 34px;
  object-fit: contain;
}

.legacy-brand-quick-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.legacy-brand-text-link {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0.55rem 0.8rem;
  border-radius: 999px;
  border: 1px solid #e7e7e7;
  background: #fafafa;
  color: #313131;
  font-size: 0.86rem;
  font-weight: 700;
}

.legacy-brand-text-link:hover,
.legacy-mega-more:hover {
  color: #d40000;
}

.legacy-models-mega {
  width: 100%;
  gap: 1.1rem;
  padding: 1rem 1.1rem;
}

.legacy-models-mega h3 {
  margin: 0 0 0.9rem;
  font-size: 1.1rem;
  color: #222;
}

.legacy-common-models-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 0.9rem;
}

.legacy-common-model {
  display: grid;
  gap: 0.45rem;
  text-align: center;
  color: #202020;
}

.legacy-common-model img,
.legacy-garage-card img {
  width: 100%;
  aspect-ratio: 1.5 / 1;
  object-fit: cover;
  background: #e9e9e9;
}

.legacy-common-model strong {
  font-size: 0.82rem;
}

.legacy-common-model span {
  color: #444;
  font-size: 0.8rem;
}

.legacy-top-model-columns {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 1rem;
}

.legacy-model-brand-col {
  display: grid;
  align-content: start;
  gap: 0.45rem;
}

.legacy-model-brand-col h4 {
  margin: 0 0 0.4rem;
  padding-bottom: 0.4rem;
  border-bottom: 1px solid #dddddd;
  font-size: 1rem;
}

.legacy-model-brand-col a {
  color: #333;
  font-size: 0.88rem;
}

.legacy-garage-mega {
  width: 100%;
  padding: 1rem 1.1rem;
}

.legacy-garage-copy,
.legacy-garage-empty {
  margin-bottom: 0.9rem;
  color: #444;
}

.legacy-garage-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.legacy-garage-card {
  display: grid;
  gap: 0.35rem;
  color: #202020;
}

.legacy-garage-card strong {
  font-size: 0.82rem;
}

.legacy-garage-card span {
  font-size: 0.78rem;
  color: #555;
}

.legacy-clear-garage {
  margin-top: 1rem;
  display: inline-flex;
  padding: 0.6rem 0.9rem;
  background: #444;
  color: #fff;
}

.legacy-mobile-actions,
.legacy-mobile-shortcuts {
  display: none;
}

.legacy-mobile-icon-link {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  padding: 0;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.05);
  color: #fff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.legacy-mobile-icon {
  font-size: 1.05rem;
  line-height: 1;
}

.legacy-mobile-icon-link em {
  position: absolute;
  top: -6px;
  right: -6px;
  min-width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 0.25rem;
  border-radius: 999px;
  background: #d40000;
  color: #fff;
  font-size: 0.68rem;
  font-style: normal;
  font-weight: 800;
}

.legacy-mobile-toggle {
  min-height: 40px;
  padding: 0 1rem;
  border: 0;
  background: transparent;
  color: #fff;
}

.legacy-mobile-categories {
  display: grid;
  gap: 1rem;
}

.legacy-mobile-root,
.legacy-mobile-group-details {
  border: 1px solid #e7e1d8;
  border-radius: 14px;
  background: #fff;
}

.legacy-mobile-root summary,
.legacy-mobile-group-details summary {
  list-style: none;
  cursor: pointer;
}

.legacy-mobile-root summary::-webkit-details-marker,
.legacy-mobile-group-details summary::-webkit-details-marker {
  display: none;
}

.legacy-mobile-root > summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.9rem 1rem;
  color: #c10000;
  font-size: 0.95rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.legacy-mobile-root > summary::after,
.legacy-mobile-group-details > summary::after {
  content: "+";
  font-weight: 800;
  color: #67615b;
}

.legacy-mobile-root[open] > summary::after,
.legacy-mobile-group-details[open] > summary::after {
  content: "-";
}

.legacy-mobile-root-body {
  display: grid;
  gap: 0.7rem;
  padding: 0 0.85rem 0.85rem;
}

.legacy-mobile-group {
  display: grid;
  gap: 0.6rem;
}

.legacy-mobile-group-details > summary {
  padding: 0.8rem 0.9rem;
  font-size: 0.9rem;
  font-weight: 700;
}

.legacy-mobile-group-links {
  display: grid;
  gap: 0.35rem;
  padding: 0 0.85rem 0.85rem;
}

.legacy-mobile-group a,
.legacy-mobile-direct {
  display: block;
  padding: 0.2rem 0;
  color: #343434;
  font-size: 0.88rem;
}

.legacy-mobile-garage .legacy-garage-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.legacy-mobile-search-form {
  position: relative;
}

.legacy-mobile-search-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 44px;
  gap: 0.5rem;
}

.legacy-mobile-search-shell input {
  width: 100%;
  min-width: 0;
  height: 44px;
  padding: 0 0.9rem;
  border: 1px solid var(--site-line);
  border-radius: 12px;
}

.legacy-mobile-search-shell button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 12px;
  background: #d40000;
  color: #fff;
}

.legacy-mobile-shortcut {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.7rem 0.55rem;
  background: #17191d;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
  text-align: center;
  font-size: 0.78rem;
  font-weight: 700;
}

.legacy-mobile-brand-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.legacy-mobile-brand-pill {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0.55rem 0.8rem;
  border-radius: 999px;
  border: 1px solid var(--site-line);
  background: #fff;
  color: #343434;
  font-size: 0.84rem;
  font-weight: 700;
}

.legacy-mobile-model-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.legacy-mobile-common-model {
  display: grid;
  gap: 0.35rem;
  padding: 0.55rem;
  border-radius: 14px;
  border: 1px solid var(--site-line);
  background: #fff;
  color: #2b2b2b;
  text-align: center;
}

.legacy-mobile-common-model img {
  width: 100%;
  aspect-ratio: 1.45 / 1;
  object-fit: cover;
  background: #ececec;
}

.legacy-mobile-common-model strong {
  font-size: 0.78rem;
}

.legacy-mobile-common-model span {
  color: #666;
  font-size: 0.76rem;
}

.legacy-mobile-section-link {
  margin-top: 0.8rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0.65rem 0.9rem;
  border-radius: 12px;
  border: 1px solid var(--site-line);
  background: #fff;
  color: #2b2b2b;
  font-weight: 800;
}

.legacy-mobile-lang {
  display: inline-flex;
  gap: 0.5rem;
}

.legacy-mobile-lang a {
  min-width: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.65rem 0.8rem;
  border-radius: 999px;
  border: 1px solid var(--site-line);
  background: #fff;
  color: #3e3934;
  font-weight: 700;
}

.legacy-mobile-lang a.active {
  background: #111;
  border-color: #111;
  color: #fff;
}

.topbar {
  background: var(--site-dark);
  color: #f6f0e8;
  font-size: 0.9rem;
}

.topbar-inner {
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.topbar-actions {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(10px);
  background: rgba(244, 241, 236, 0.92);
  border-bottom: 1px solid rgba(217, 210, 200, 0.85);
}

.header-shell {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: center;
  padding: 1rem 0;
}

.brand-lockup,
.search-shell,
.account-summary,
.nav-mega,
.hero-card,
.section-panel,
.product-card,
.detail-shell,
.compatibility-panel,
.summary-card,
.auth-card,
.notice-card,
.empty-card,
.filters-card {
  background: var(--site-panel);
  border: 1px solid var(--site-line);
  border-radius: var(--site-radius);
  box-shadow: var(--site-shadow);
}

.brand-lockup {
  min-height: 108px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 1.15rem 1.25rem;
}

.brand-kicker,
.hero-card-eyebrow,
.eyebrow,
.nav-group-title,
.mobile-menu-title {
  color: var(--site-accent);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.73rem;
  font-weight: 800;
}

.brand-main {
  font-size: 2.6rem;
  line-height: 1;
}

.brand-sub {
  color: var(--site-muted);
  font-size: 0.95rem;
}

.search-shell {
  position: relative;
  padding: 1rem 1.1rem;
}

.search-shell label {
  display: block;
  margin-bottom: 0.5rem;
  color: var(--site-muted);
  font-size: 0.88rem;
  font-weight: 700;
}

.search-input-wrap {
  display: flex;
  gap: 0.75rem;
}

.search-input-wrap input {
  min-width: 0;
  flex: 1;
  height: 52px;
  padding: 0 1rem;
  border: 1px solid var(--site-line);
  border-radius: 14px;
  background: #fff;
}

.search-input-wrap .btn {
  min-width: 124px;
  border-radius: 14px;
}

.search-suggestions {
  position: absolute;
  left: 1rem;
  right: 1rem;
  top: calc(100% - 0.25rem);
  background: #fff;
  border: 1px solid var(--site-line);
  border-radius: 16px;
  box-shadow: 0 18px 40px rgba(17, 17, 17, 0.08);
  padding: 0.4rem;
  z-index: 20;
  color: var(--site-ink);
}

.live-search-shell {
  position: relative;
}

.search-suggestions-inline {
  left: 0;
  right: 0;
  top: calc(100% + 0.35rem);
}

.search-hit,
.search-empty {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.85rem 0.95rem;
  border-radius: 12px;
}

.search-hit:hover {
  background: var(--site-panel-soft);
}

.search-hit {
  color: var(--site-ink);
}

.search-hit-thumb {
  width: 56px;
  height: 56px;
  flex: 0 0 56px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: #f7f4ee;
  overflow: hidden;
}

.search-hit-thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.search-hit-copy {
  display: grid;
  gap: 0.2rem;
  min-width: 0;
  flex: 1 1 auto;
}

.search-hit-subline {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.search-hit-badge {
  display: inline-flex;
  align-items: center;
  min-height: 18px;
  padding: 0.08rem 0.35rem;
  border-radius: 999px;
  background: rgba(198, 13, 25, 0.08);
  color: var(--site-accent);
  font-size: 0.68rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.search-hit-copy strong {
  color: var(--site-ink);
  line-height: 1.3;
}

.search-hit-copy span,
.search-empty,
.account-copy,
.muted,
.page-intro,
.detail-meta,
.support-copy {
  color: var(--site-muted);
}

.search-hit-copy .search-hit-meta {
  font-size: 0.82rem;
  line-height: 1.35;
}

.search-hit em {
  font-style: normal;
  font-weight: 800;
  color: var(--site-accent);
  white-space: nowrap;
}

.bike-brand-sidebar .search-hit {
  align-items: flex-start;
}

.bike-brand-sidebar .search-hit-thumb {
  width: 48px;
  height: 48px;
  flex: 0 0 48px;
}

.bike-brand-sidebar .search-hit-copy {
  gap: 0.12rem;
}

.bike-brand-sidebar .search-hit-copy strong {
  font-size: 0.94rem;
  line-height: 1.3;
}

.bike-brand-sidebar .search-hit em {
  color: var(--site-muted);
  font-size: 0.78rem;
}

.header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.85rem;
}

.lang-switch {
  display: inline-flex;
  padding: 0.3rem;
  border-radius: 999px;
  background: #ebe5dc;
}

.lang-switch a {
  padding: 0.45rem 0.8rem;
  border-radius: 999px;
  font-weight: 800;
  font-size: 0.85rem;
}

.lang-switch a.active {
  background: #fff;
  color: var(--site-accent);
}

.account-summary {
  min-width: 220px;
  padding: 0.9rem 1rem;
}

.account-links {
  display: flex;
  gap: 0.85rem;
  margin-top: 0.35rem;
  flex-wrap: wrap;
}

.account-links a {
  color: var(--site-accent);
  font-weight: 800;
}

.cart-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.8rem 1rem;
  border-radius: 999px;
  background: var(--site-dark);
  color: #fff;
  font-weight: 800;
}

.cart-badge strong {
  display: inline-grid;
  place-items: center;
  min-width: 1.9rem;
  min-height: 1.9rem;
  padding: 0 0.35rem;
  border-radius: 999px;
  background: var(--site-accent);
}

.nav-mega {
  display: grid;
  grid-template-columns: 1fr 1fr 1.2fr;
  gap: 1rem;
  padding: 1rem;
  margin-bottom: 1rem;
}

.nav-group {
  min-width: 0;
}

.nav-chip-grid,
.chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.nav-chip-grid a,
.chip-row a {
  padding: 0.65rem 0.9rem;
  border-radius: 999px;
  background: var(--site-panel-soft);
  border: 1px solid var(--site-line);
  font-weight: 700;
}

.nav-model-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.7rem;
}

.nav-model-grid a {
  padding: 0.85rem 0.95rem;
  border-radius: 18px;
  background: var(--site-panel-soft);
  border: 1px solid var(--site-line);
}

.nav-model-grid a span {
  display: block;
  color: var(--site-muted);
  font-size: 0.82rem;
}

.browse-rail,
.browse-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.browse-rail {
  margin-bottom: 1rem;
}

.browse-rail a,
.browse-pill {
  padding: 0.8rem 1rem;
  border-radius: 999px;
  border: 1px solid var(--site-line);
  background: var(--site-panel);
  box-shadow: var(--site-shadow);
  font-weight: 800;
}

.browse-pill.active,
.browse-rail a:hover,
.nav-more-link:hover {
  color: var(--site-accent);
}

.nav-more-link {
  display: inline-flex;
  margin-top: 0.9rem;
  font-weight: 800;
}

.browse-grid,
.model-directory-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.browse-card,
.model-directory-card {
  display: grid;
  gap: 0.5rem;
  padding: 1rem 1.1rem;
  border-radius: 20px;
  border: 1px solid var(--site-line);
  background: var(--site-panel-soft);
}

.browse-card strong,
.model-directory-card strong {
  font-size: 1.05rem;
}

.catalog-branch-card {
  align-content: start;
}

.catalog-branch-icon {
  width: 2.7rem;
  height: 2.7rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.95rem;
  background: rgba(179, 19, 27, 0.08);
  color: var(--site-brand);
  font-size: 1.15rem;
}

.directory-filter-bar {
  display: grid;
  gap: 0.45rem;
  margin-bottom: 1rem;
}

.directory-filter-bar label {
  font-weight: 800;
  font-size: 0.92rem;
}

.directory-filter-bar input {
  min-height: 48px;
  padding: 0.8rem 0.95rem;
  border-radius: 16px;
  border: 1px solid var(--site-line);
  background: #fff;
}

.browse-count {
  color: var(--site-muted);
  font-size: 0.9rem;
}

.browse-empty-state {
  grid-column: 1 / -1;
  padding: 1rem 1.1rem;
  border-radius: 18px;
  border: 1px dashed var(--site-line);
  background: var(--site-panel-soft);
  color: var(--site-muted);
}

.brand-directory-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.brand-directory-card {
  display: grid;
  gap: 0.75rem;
  align-content: start;
  padding: 1rem 1.1rem;
  border-radius: 20px;
  border: 1px solid var(--site-line);
  background: var(--site-panel-soft);
}

.brand-directory-card-logo-only {
  gap: 0;
}

.brand-directory-card strong {
  font-size: 1.05rem;
}

.brand-directory-logo {
  min-height: 72px;
  display: grid;
  place-items: center;
  padding: 0.75rem;
  border-radius: 16px;
  background: #fff;
  border: 1px solid #ebe4db;
}

.brand-directory-logo img {
  max-width: 100%;
  max-height: 34px;
  object-fit: contain;
}

.brand-directory-logo-fallback {
  font-family: var(--font-display);
  font-size: 1.25rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.browse-common-models,
.browse-top-model-columns {
  margin-top: 0.35rem;
}

.browse-top-model-columns .legacy-model-brand-col {
  padding-right: 0.5rem;
}

.bike-brand-directory-layout {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

.bike-brand-sidebar,
.bike-brand-directory-main {
  min-width: 0;
}

.bike-brand-sidebar {
  overflow: visible;
  z-index: 8;
}

.bike-brand-sidebar .search-suggestions {
  max-height: min(420px, 70vh);
  overflow-y: auto;
}

.bike-brand-filter-form {
  display: grid;
  gap: 0.85rem;
}

.bike-brand-directory-main {
  display: grid;
  gap: 0.9rem;
  align-content: start;
  align-items: start;
}

.bike-cc-group {
  display: grid;
  gap: 0.85rem;
  align-content: start;
  align-items: start;
}

.bike-cc-head {
  margin-bottom: 0;
}

.bike-model-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cc-pill-nav {
  margin-bottom: 0;
  gap: 0.55rem;
  flex-wrap: wrap;
  align-items: flex-start;
  overflow: visible;
  padding-bottom: 0;
  scrollbar-width: auto;
}

.cc-pill-nav .browse-pill {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 0;
  padding: 0.58rem 0.82rem;
  white-space: nowrap;
}

.bike-model-grid .model-directory-card {
  align-content: start;
  min-height: 0;
}

.bike-brand-directory-layout > .filters-card,
.bike-brand-directory-layout > .section-panel {
  align-self: start;
}

.directory-search {
  display: flex;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.directory-search input {
  flex: 1;
  min-width: 0;
  height: 52px;
  padding: 0 1rem;
  border: 1px solid var(--site-line);
  border-radius: 14px;
  background: #fff;
}

.page-main {
  padding: 1.5rem 0 6rem;
}

.shell-home .page-main {
  padding-top: 0;
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr;
  gap: 1rem;
  margin-bottom: 1.25rem;
}

.hero-card {
  min-height: 250px;
  padding: 1.4rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.hero-card h1,
.hero-card h3,
.section-head h2,
.detail-copy h1,
.summary-card h2,
.auth-card h1,
.notice-card h1 {
  margin: 0.25rem 0 0.6rem;
}

.hero-card p {
  max-width: 44ch;
  line-height: 1.6;
}

.hero-card a {
  margin-top: 1rem;
  align-self: flex-start;
  padding: 0.8rem 1rem;
  border-radius: 999px;
  border: 1px solid var(--site-line);
  background: var(--site-panel-soft);
  font-weight: 800;
}

.legacy-home-block {
  margin-bottom: 1.25rem;
}

.legacy-home-block-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}

.legacy-home-hero-shell {
  --home-menu-extra-space: 0px;
  display: grid;
  grid-template-columns: var(--legacy-categories-column) minmax(0, 1fr);
  gap: 0;
  align-items: stretch;
  overflow: visible;
  margin-bottom: calc(1.25rem + var(--home-menu-extra-space));
}

.legacy-home-rail,
.legacy-home-hero-main,
.legacy-home-finder-card,
.legacy-home-info-card {
  background: #fff;
  border: 1px solid #dddddd;
  box-shadow: 0 14px 35px rgba(0, 0, 0, 0.08);
}

.legacy-home-rail {
  align-self: stretch;
  border-top: 0;
  border-right: 0;
  position: relative;
  z-index: 4;
  background: #f6f6f6;
}

.legacy-home-rail-links {
  display: grid;
  align-content: start;
  min-height: 100%;
  background: #fff;
}

.legacy-home-root-link {
  width: 100%;
  background: #fff;
}

.legacy-home-root-link:hover,
.legacy-home-root-link.active {
  color: #d40000;
  background: #fafafa;
}

.legacy-home-hero-main {
  position: relative;
  align-self: stretch;
  border-top: 0;
  overflow: visible;
}

.legacy-home-carousel {
  height: 100%;
  overflow: hidden;
}

.legacy-home-category-panels {
  display: none;
  position: absolute;
  top: 0;
  left: 0;
  width: min(78%, 780px);
  max-width: calc(100% - 0.35rem);
  min-height: 100%;
  height: auto;
  padding: 0;
  background: rgba(255, 255, 255, 0.97);
  border: 1px solid #dddddd;
  border-left: 0;
  box-shadow: 16px 0 34px rgba(0, 0, 0, 0.08);
  z-index: 3;
}

.legacy-home-hero-shell.legacy-home-menu-open .legacy-home-category-panels {
  display: block;
}

.legacy-home-root-panel {
  display: none;
  min-height: 100%;
  height: auto;
  padding: 1rem 1.15rem 1.1rem;
  overflow: visible;
}

.legacy-home-root-panel.active {
  display: grid;
  align-content: start;
}

.legacy-home-root-panel-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.85rem 1rem;
  align-content: start;
}

.legacy-home-root-panel .legacy-category-group h4 {
  margin-bottom: 0.45rem;
  padding-bottom: 0.42rem;
  font-size: 0.94rem;
}

.legacy-home-root-panel .legacy-category-group ul {
  gap: 0.3rem;
}

.legacy-home-root-panel .legacy-category-group li a {
  font-size: 0.84rem;
  line-height: 1.28;
}

.legacy-home-carousel,
.legacy-home-carousel .carousel-inner,
.legacy-home-slide,
.legacy-home-slide img {
  height: 100%;
}

.legacy-home-carousel {
  min-height: 330px;
}

.legacy-home-slide {
  position: relative;
  display: block;
  color: #fff;
}

.legacy-home-slide img {
  width: 100%;
  object-fit: cover;
}

.legacy-home-slide::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.05) 45%, rgba(0, 0, 0, 0.5));
}

.legacy-home-slide-copy {
  position: absolute;
  right: 1.5rem;
  bottom: 1.5rem;
  z-index: 2;
  max-width: 360px;
  display: grid;
  gap: 0.25rem;
  padding: 1rem 1.1rem;
  background: rgba(10, 10, 10, 0.74);
}

.legacy-home-slide-copy small,
.legacy-home-slide-copy em,
.legacy-home-slide-copy strong {
  display: block;
  font-style: normal;
}

.legacy-home-slide-copy small {
  color: #ffdf2d;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.legacy-home-slide-copy strong {
  font-family: var(--font-display);
  font-size: 1.75rem;
  line-height: 1.05;
}

.legacy-home-slide-copy em {
  color: rgba(255, 255, 255, 0.88);
  font-size: 0.95rem;
  line-height: 1.45;
}

.legacy-home-carousel .carousel-indicators {
  margin-bottom: 0.75rem;
  justify-content: flex-end;
  padding-right: 1rem;
}

.legacy-home-carousel .carousel-indicators [data-bs-target] {
  width: 10px;
  height: 10px;
  margin: 0 4px;
  border-radius: 999px;
  border: 0;
}

.legacy-home-latest-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

.legacy-home-finder-card {
  padding: 1rem;
}

.legacy-home-finder-card-horizontal {
  display: grid;
  grid-template-columns: minmax(180px, 0.65fr) repeat(2, minmax(190px, 0.7fr)) minmax(320px, 0.95fr);
  gap: 1rem;
  align-items: stretch;
  margin-bottom: 1rem;
}

.legacy-home-finder-head {
  margin-bottom: 1rem;
}

.legacy-home-finder-card-horizontal .legacy-home-finder-head {
  align-self: stretch;
  display: grid;
  grid-template-rows: minmax(52px, auto) 52px;
  align-content: start;
  gap: 0.55rem;
  margin-bottom: 0;
}

.legacy-home-finder-head h3 {
  margin: 0;
  font-size: 1.7rem;
}

.legacy-home-finder-card-horizontal .legacy-home-finder-head h3 {
  align-self: center;
}

.legacy-home-finder-head p,
.legacy-home-info-card p {
  margin: 0;
  color: #555;
  line-height: 1.55;
}

.legacy-home-finder-form {
  display: grid;
  gap: 0.85rem;
}

.legacy-home-finder-card-horizontal > .legacy-home-finder-form {
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: minmax(52px, auto) 52px;
  gap: 0.55rem;
  align-items: stretch;
  align-self: stretch;
}

.legacy-home-finder-card-horizontal > .legacy-home-finder-form .btn {
  min-height: 46px;
  white-space: nowrap;
}

.legacy-home-model-start-title {
  min-height: 52px;
  display: flex;
  align-items: flex-end;
  color: var(--site-ink);
  font-family: var(--font-display);
  font-size: 1.12rem;
  font-weight: 800;
  line-height: 1.1;
  padding-bottom: 0.18rem;
}

.legacy-home-finder-card-horizontal .legacy-home-finder-head .legacy-home-finder-form {
  gap: 0;
}

.legacy-home-finder-card-horizontal .legacy-home-finder-head .legacy-home-finder-form .field {
  min-width: 0;
}

.legacy-home-finder-card-horizontal .legacy-home-finder-head .live-search-shell {
  position: relative;
}

.legacy-home-finder-card-horizontal .legacy-home-finder-head .legacy-home-finder-form input[type="search"] {
  width: 100%;
  min-height: 52px;
  height: 52px;
  padding-right: 3.2rem;
  border-color: #d40000;
  background: linear-gradient(135deg, #d40000 0%, #a90812 100%);
  color: #fff;
  box-shadow: 0 14px 28px rgba(196, 15, 26, 0.2);
}

.legacy-home-finder-card-horizontal .legacy-home-finder-head .live-search-shell::after {
  content: "\f002";
  position: absolute;
  right: 1.08rem;
  top: 50%;
  transform: translateY(-50%);
  color: #ffe66b;
  font-family: "Font Awesome 6 Free";
  font-size: 1rem;
  font-weight: 900;
  line-height: 1;
  pointer-events: none;
}

.legacy-home-finder-card-horizontal .legacy-home-finder-head .legacy-home-finder-form input[type="search"]::placeholder {
  color: rgba(255, 255, 255, 0.78);
}

.legacy-home-finder-card-horizontal .legacy-home-finder-head .legacy-home-finder-form input[type="search"]:focus {
  border-color: #ffe66b;
  box-shadow: 0 0 0 3px rgba(255, 230, 107, 0.42), 0 16px 30px rgba(196, 15, 26, 0.28);
}

.legacy-home-finder-form select {
  width: 100%;
  min-height: 42px;
  border: 1px solid #d8d8d8;
  background: #fff;
  padding: 0 0.85rem;
}

.legacy-home-finder-models {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid #ececec;
  display: grid;
  gap: 0.8rem;
}

.legacy-home-finder-models strong,
.legacy-home-shortcuts strong {
  font-family: var(--font-display);
  font-size: 1.05rem;
}

.legacy-home-finder-links,
.legacy-home-shortcuts {
  display: grid;
  gap: 0.45rem;
}

.legacy-home-shortcuts {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid #ececec;
}

.legacy-home-finder-card-horizontal .legacy-home-shortcuts {
  grid-column: 2 / 5;
  grid-row: 1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.55rem;
  align-items: stretch;
  justify-content: center;
  justify-self: center;
  width: 100%;
  max-width: none;
  margin-top: 0;
  padding-top: 0;
  border-top: 0;
  counter-reset: homeShortcut;
}

.legacy-home-finder-card-horizontal .legacy-home-shortcuts strong {
  display: none;
}

.legacy-home-finder-links a,
.legacy-home-shortcuts a {
  color: #333;
  font-weight: 700;
}

.legacy-home-finder-card-horizontal .legacy-home-shortcuts a {
  position: relative;
  counter-increment: homeShortcut;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  justify-content: flex-start;
  min-height: 52px;
  padding: 0.62rem 3.1rem 0.62rem 2rem;
  border: 1px solid #f3c400;
  border-radius: 14px;
  background: linear-gradient(135deg, #ffe66b 0%, #ffd12a 100%);
  box-shadow: 0 12px 24px rgba(174, 119, 0, 0.12);
  font-size: 1.08rem;
  line-height: 1.15;
  width: 100%;
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.legacy-home-finder-card-horizontal .legacy-home-shortcuts a::after {
  content: counter(homeShortcut);
  position: absolute;
  top: -0.45rem;
  left: -0.45rem;
  display: inline-grid;
  width: 1.72rem;
  height: 1.72rem;
  place-items: center;
  border-radius: 999px;
  background: #111;
  color: #fff;
  border: 2px solid #fff;
  box-shadow: 0 10px 18px rgba(17, 17, 17, 0.18);
  font-family: var(--font-display);
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1;
}

.legacy-home-finder-card-horizontal .legacy-home-shortcuts i {
  position: absolute;
  right: 0.72rem;
  top: 50%;
  transform: translateY(-50%);
  display: inline-grid;
  width: 28px;
  height: 28px;
  flex: 0 0 28px;
  place-items: center;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.72);
  color: #c10f1a;
  font-size: 0.88rem;
  transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.legacy-home-shortcut-count {
  margin-left: 0;
  margin-right: 0.38rem;
  color: #c10f1a;
  font-family: var(--font-display);
  font-size: 1.24em;
  font-weight: 900;
  line-height: inherit;
}

.legacy-home-finder-links a:hover,
.legacy-home-shortcuts a:hover {
  color: #d40000;
}

.legacy-home-finder-card-horizontal .legacy-home-shortcuts a:hover,
.legacy-home-finder-card-horizontal .legacy-home-shortcuts a:focus {
  background: linear-gradient(135deg, #d40000 0%, #a90812 100%);
  border-color: #d40000;
  color: #fff;
  box-shadow: 0 16px 30px rgba(196, 15, 26, 0.24);
  transform: translateY(-1px);
}

.legacy-home-finder-card-horizontal .legacy-home-shortcuts a:hover .legacy-home-shortcut-count,
.legacy-home-finder-card-horizontal .legacy-home-shortcuts a:focus .legacy-home-shortcut-count {
  color: #ffe66b;
}

.legacy-home-finder-card-horizontal .legacy-home-shortcuts a:hover i,
.legacy-home-finder-card-horizontal .legacy-home-shortcuts a:focus i {
  background: rgba(255, 255, 255, 0.16);
  color: #ffe66b;
  transform: translateY(-50%) scale(1.04);
}

.legacy-home-products-shell,
.legacy-home-feature-panel {
  min-width: 0;
}

.legacy-home-carousel-head {
  align-items: center;
}

.legacy-home-carousel-controls {
  display: inline-flex;
  gap: 0.45rem;
  align-items: center;
}

.legacy-home-carousel-btn {
  display: inline-grid;
  width: 42px;
  height: 42px;
  place-items: center;
  border: 1px solid #ded6cc;
  border-radius: 999px;
  background: #fff;
  color: #202020;
  box-shadow: 0 10px 20px rgba(21, 18, 16, 0.06);
  transition: transform 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.legacy-home-carousel-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(193, 15, 26, 0.35);
  color: #c10f1a;
}

.legacy-home-product-carousel {
  position: relative;
  overflow: hidden;
  --home-carousel-items: 4;
  --home-carousel-gap: 1rem;
}

.legacy-home-product-carousel-track {
  display: flex;
  grid-template-columns: none;
  flex-wrap: nowrap;
  gap: var(--home-carousel-gap);
  overflow-x: auto;
  overflow-y: hidden;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  padding: 0 0 0.9rem;
}

.legacy-home-product-carousel-track::-webkit-scrollbar {
  display: none;
}

.legacy-home-product-carousel-track .product-card {
  flex: 0 0 calc((100% - (var(--home-carousel-items) - 1) * var(--home-carousel-gap)) / var(--home-carousel-items));
  min-width: 0;
  scroll-snap-align: start;
}

@media (max-width: 1199px) {
  .legacy-home-product-carousel {
    --home-carousel-items: 3;
  }
}

@media (max-width: 991px) {
  .legacy-home-product-carousel {
    --home-carousel-items: 2;
  }
}

@media (max-width: 767px) {
  .legacy-home-carousel-head {
    align-items: center;
    flex-direction: row;
  }

  .legacy-home-product-carousel {
    --home-carousel-items: 1;
  }
}

.legacy-home-product-grid .product-card {
  border-radius: 0;
  border: 1px solid #e4e4e4;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.05);
  background: #fff;
}

.legacy-home-feature-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.legacy-home-feature-tile {
  position: relative;
  overflow: hidden;
  min-height: 220px;
  display: block;
  color: #fff;
  background: #222;
}

.legacy-home-feature-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.62);
  transition: transform 0.25s ease, filter 0.25s ease;
}

.legacy-home-feature-tile span {
  position: absolute;
  inset: auto 1rem 1rem 1rem;
  z-index: 2;
  font-family: var(--font-display);
  font-size: 2rem;
  line-height: 1.05;
  text-align: center;
  text-wrap: balance;
}

.legacy-home-feature-tile:hover img {
  transform: scale(1.03);
  filter: brightness(0.5);
}

.legacy-home-model-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.legacy-home-model-card {
  padding: 0.75rem;
  background: #f7f7f7;
  border: 1px solid #e0e0e0;
  display: grid;
  gap: 0.5rem;
  justify-items: center;
  text-align: center;
}

.legacy-home-model-card img {
  width: 100%;
  aspect-ratio: 1 / 0.72;
  object-fit: cover;
  background: #ececec;
}

.legacy-home-model-card span {
  font-size: 0.82rem;
  color: #777;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.legacy-home-model-card strong {
  font-family: var(--font-display);
  font-size: 1.12rem;
  line-height: 1.1;
}

.legacy-home-info-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.legacy-home-info-card {
  padding: 1.25rem;
}

.legacy-home-info-card h3 {
  margin: 0 0 0.65rem;
  font-size: 1.6rem;
}

.section-stack {
  display: grid;
  gap: 1rem;
}

.section-panel,
.summary-card,
.auth-card,
.notice-card,
.empty-card,
.filters-card,
.compatibility-panel {
  padding: 1.3rem;
}

.summary-card {
  position: sticky;
  top: 7.5rem;
}

.section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}

.grid-products {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.grid-products.legacy-home-product-carousel-track {
  display: flex;
  grid-template-columns: none;
}

.product-card {
  overflow: hidden;
}

.product-media {
  position: relative;
  overflow: hidden;
  aspect-ratio: 1 / 1;
  background: #f0ebe3;
  text-align: center;
}

.product-media img {
  display: block;
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: calc(100% - 0.65rem);
  margin: 0.65rem auto 0;
}

.product-placeholder {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  color: var(--site-muted);
}

.product-body {
  padding: 1rem;
  display: grid;
  gap: 0.75rem;
}

.product-meta,
.summary-row,
.price-block,
.cart-actions,
.product-actions,
.product-price-row {
  display: flex;
  gap: 0.75rem;
}

.product-meta,
.summary-row,
.product-price-row {
  align-items: center;
  justify-content: space-between;
}

.product-meta {
  font-size: 0.84rem;
  color: var(--site-muted);
}

.product-title {
  font-weight: 800;
  line-height: 1.4;
  min-height: 3em;
}

.price-block {
  align-items: baseline;
  flex-wrap: wrap;
}

.price-current {
  font-size: 1.35rem;
  font-weight: 800;
}

.price-old {
  color: var(--site-muted);
  text-decoration: line-through;
}

.stock-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.38rem;
  min-height: 1.55rem;
  padding: 0.18rem 0.55rem;
  border: 1px solid transparent;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 800;
  line-height: 1.1;
  white-space: nowrap;
}

.stock-badge::before {
  content: "";
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 50%;
  background: currentColor;
  flex: 0 0 auto;
}

.stock-pill {
  display: grid;
  gap: 0.32rem;
  min-width: min(100%, 255px);
  padding: 0.7rem 0.95rem;
  border: 1px solid transparent;
  border-radius: 16px;
  background: #f5f5f5;
}

.stock-pill-top {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 800;
  line-height: 1.1;
}

.stock-pill-dot {
  width: 0.6rem;
  height: 0.6rem;
  border-radius: 50%;
  background: currentColor;
  flex: 0 0 auto;
}

.stock-pill-label {
  font-size: 0.96rem;
}

.stock-pill-copy {
  display: block;
  margin: 0;
  color: #5c5751;
  font-size: 0.82rem;
  line-height: 1.35;
}

.stock-state-available {
  color: #0d7a41;
  background: #eefaf3;
  border-color: #cde8d7;
}

.stock-state-low {
  color: #9a5a00;
  background: #fff6e5;
  border-color: #f0d9a7;
}

.stock-state-backorder {
  color: #245c95;
  background: #eef5fd;
  border-color: #cfe0f4;
}

.stock-state-contact {
  color: #5f4a85;
  background: #f4eefc;
  border-color: #ddd2ef;
}

.product-actions {
  flex-wrap: wrap;
}

.product-actions .btn,
.product-actions .btn-outline-dark {
  flex: 1 1 150px;
}

.product-actions-quick > .btn,
.product-actions-quick > .btn-outline-dark,
.product-actions .inline-cart-form-quick {
  flex: 1 1 100%;
}

.product-actions .inline-cart-form {
  margin: 0;
}

.product-actions .inline-cart-form .btn {
  width: 100%;
}

.inline-cart-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.7rem;
}

.cart-inline-form {
  margin: 0;
}

.catalog-product-card {
  display: flex;
  flex-direction: column;
  align-self: start;
  border-radius: 16px;
  border: 1px solid #e2e2e2;
  box-shadow: 0 8px 20px rgba(17, 17, 17, 0.045);
}

.catalog-product-card .product-media {
  background: #fff;
  display: grid;
  place-items: center;
  aspect-ratio: 1 / 0.72;
  padding: 0.12rem 0.22rem 0.2rem;
}

.catalog-product-brand {
    flex: 0 0 auto;
    height: 34px;
    min-height: 34px;
    max-height: 34px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
    padding: 0.45rem 0.75rem 0.4rem;
  background: #2c2f35;
  color: #fff;
  font-family: var(--font-display);
  font-size: 0.96rem;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  line-height: 1;
  font-weight: 700;
}

.catalog-product-brand-label {
    min-width: 0;
    flex: 1 1 auto;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    text-align: center;
    line-height: 1;
}

.catalog-product-brand-label-empty {
  visibility: hidden;
}

.catalog-product-card .product-media img {
  display: block;
  margin: 0;
  max-width: calc(100% - 0.1rem);
  max-height: calc(100% - 0.1rem);
  object-fit: contain;
}

.catalog-product-brand:empty {
  display: none;
}

.catalog-product-discount {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 58px;
  padding: 0.42rem 0.55rem 0.38rem;
  background: #d40000;
  color: #fff;
  font-size: 0.82rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0.02em;
  border-radius: 0 0 8px 0;
  box-shadow: 0 8px 18px rgba(154, 10, 10, 0.18);
}

.catalog-product-brand-discount {
  display: none;
}

.catalog-product-card .product-body {
  flex: 0 0 auto;
  align-content: start;
  gap: 0.38rem;
  padding: 0.72rem 0.82rem 0.82rem;
  grid-template-rows: auto 2.7em auto auto;
}

.catalog-product-card .product-meta {
  min-height: 1.1rem;
  font-size: 0.74rem;
  gap: 0.45rem;
  white-space: nowrap;
}

.catalog-product-card .product-meta-type {
  overflow: hidden;
  text-overflow: ellipsis;
}

.catalog-product-card .product-meta-stock {
  flex: 0 0 auto;
  max-width: 100%;
}

.catalog-product-card .product-meta-placeholder {
  visibility: hidden;
}

.catalog-product-card .product-title {
  height: 2.7em;
  min-height: 2.7em;
  max-height: 2.7em;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  text-align: center;
  font-size: 1rem;
  line-height: 1.35;
  margin: 0;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.catalog-product-card .stock-badge {
  max-width: 100%;
  padding-inline: 0.52rem;
}

.catalog-product-card .price-block {
  justify-content: center;
  min-height: 1.85rem;
  margin-top: 0.05rem;
}

.catalog-product-card .price-current {
  font-size: 1.22rem;
}

.catalog-product-card .product-actions {
  margin-top: 0.12rem;
}

.catalog-product-card .product-actions .btn,
.catalog-product-card .product-actions .btn-outline-dark {
  min-height: 42px;
  font-size: 0.95rem;
  padding-inline: 0.72rem;
  white-space: nowrap;
  line-height: 1.1;
}

.catalog-product-card .inline-cart-grid {
  gap: 0.6rem;
}

.catalog-product-card .inline-cart-grid .btn {
  font-size: 0.88rem;
  padding-inline: 0.55rem;
  white-space: nowrap;
}

.detail-mobile-stock {
  justify-self: start;
}

.cart-flash-toast {
  position: fixed;
  top: clamp(1rem, 3vw, 1.6rem);
  right: clamp(1rem, 3vw, 2rem);
  z-index: 140;
  width: min(440px, calc(100vw - 2rem));
  padding: 0.95rem;
  border-radius: 24px;
  border: 1px solid rgba(194, 22, 32, 0.16);
  background: rgba(255, 253, 250, 0.96);
  box-shadow: 0 24px 60px rgba(17, 17, 17, 0.18);
  backdrop-filter: blur(18px);
  animation: cartFlashEnter 180ms ease-out both;
}

.cart-flash-toast.is-leaving {
  pointer-events: none;
  animation: cartFlashLeave 220ms ease-in both;
}

.cart-flash-body {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.25rem 2rem 0.25rem 0.2rem;
}

.cart-flash-close {
  position: absolute;
  top: 0.6rem;
  right: 0.6rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border: 0;
  border-radius: 999px;
  background: rgba(17, 17, 17, 0.06);
  color: var(--site-ink);
  cursor: pointer;
}

.cart-flash-close:hover,
.cart-flash-close:focus {
  background: var(--site-accent);
  color: #fff;
}

.cart-flash-copy {
  display: grid;
  gap: 0.2rem;
}

.cart-flash-copy strong {
  font-size: 1rem;
}

.cart-flash-copy span {
  color: var(--site-muted);
}

.cart-flash-copy em {
  color: var(--site-ink);
  font-style: normal;
  font-weight: 700;
  margin-left: 0.35rem;
}

.cart-flash-actions {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}

@keyframes cartFlashEnter {
  from {
    opacity: 0;
    transform: translateY(-10px) scale(0.98);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes cartFlashLeave {
  from {
    opacity: 1;
    transform: translateY(0) scale(1);
  }

  to {
    opacity: 0;
    transform: translateY(-8px) scale(0.98);
  }
}

.catalog-layout {
  display: grid;
  grid-template-columns: 290px minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

.catalog-layout-no-sidebar {
  grid-template-columns: minmax(0, 1fr);
}

.catalog-layout .filters-card,
.bike-brand-directory-layout .filters-card {
  position: sticky;
  top: 6.9rem;
  align-self: start;
}

.filters-card form,
.field,
.option-list,
.summary-list {
  display: grid;
  gap: 0.85rem;
}

.field label {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--site-muted);
}

.field input,
.field textarea,
.field select,
.qty-input {
  width: 100%;
  border: 1px solid var(--site-line);
  border-radius: 14px;
  background: #fff;
  padding: 0.9rem 1rem;
}

.field-hidden {
  display: none !important;
}

.catalog-breadcrumbs {
  margin-bottom: 1rem;
  color: var(--site-muted);
  font-size: 0.92rem;
}

.catalog-page-breadcrumbs {
  margin-bottom: 0.7rem;
}

.catalog-breadcrumb-list {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 0.3rem 0.55rem;
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
}

.catalog-breadcrumb-item {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  min-height: 28px;
}

.catalog-breadcrumb-item + .catalog-breadcrumb-item::before {
  content: "/";
  color: rgba(103, 97, 91, 0.55);
  font-weight: 600;
}

.catalog-breadcrumb-link,
.catalog-breadcrumb-current {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 0.1rem;
}

.catalog-breadcrumb-link {
  color: var(--site-muted);
  transition: color 0.18s ease;
}

.catalog-breadcrumb-link:hover {
  color: var(--site-accent);
}

.catalog-breadcrumb-item.home .catalog-breadcrumb-link {
  font-weight: 700;
}

.catalog-breadcrumb-current {
  color: var(--site-ink);
  font-weight: 700;
}

.catalog-summary-row {
  align-items: center;
}

.catalog-summary-copy {
  display: grid;
  gap: 0.2rem;
}


.catalog-summary-kicker {
  color: #6e675f;
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.catalog-sort-form {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  margin-left: auto;
}

.catalog-sort-form label {
  font-size: 0.86rem;
  font-weight: 800;
  color: var(--site-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.catalog-sort-form select {
  min-width: 190px;
  min-height: 42px;
  border: 1px solid var(--site-line);
  border-radius: 12px;
  background: #fff;
  padding: 0 0.9rem;
}

.catalog-active-filters {
  margin-bottom: 0.8rem;
}

.catalog-results-active-filters {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  flex-wrap: wrap;
}

.catalog-active-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
}

.catalog-active-pill-label {
  display: block;
}

.catalog-active-pill-remove {
  width: 1.2rem;
  height: 1.2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.16);
  font-size: 0.72rem;
  line-height: 1;
  flex: 0 0 auto;
}

.catalog-active-filters .browse-pill.active {
  border-color: #111;
  background: #111;
  color: #fff;
  box-shadow: none;
}

.catalog-active-filters .browse-pill.active:hover {
  border-color: #d40000;
  background: #d40000;
  color: #fff;
}

.catalog-active-filters .browse-pill.active:hover .catalog-active-pill-remove {
  background: rgba(255, 255, 255, 0.2);
}

.filter-check {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-weight: 700;
}

.filters-mobile-toggle {
  display: none;
  margin: 0.2rem 0 1rem;
}

.filters-mobile-collapse {
  display: block;
}

.catalog-side-group {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--site-line);
}

.catalog-price-filter {
  display: grid;
  gap: 0.85rem;
  padding: 1rem;
  border-radius: 18px;
  border: 1px solid #e4ddd3;
  background: #fbfaf8;
}

.catalog-price-summary {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.catalog-price-summary strong {
  font-family: var(--font-display);
  font-size: 1rem;
  letter-spacing: 0.01em;
}

.catalog-price-summary span {
  color: #5e5852;
  font-size: 0.9rem;
  font-weight: 700;
}

.catalog-price-slider-shell {
  position: relative;
  height: 2.9rem;
}

.catalog-price-slider-track,
.catalog-price-slider-active {
  position: absolute;
  top: 50%;
  height: 0.38rem;
  border-radius: 999px;
  transform: translateY(-50%);
}

.catalog-price-slider-track {
  left: 0;
  right: 0;
  background: #dfd7cd;
}

.catalog-price-slider-active {
  background: var(--site-accent);
}

.catalog-price-slider-shell input[type="range"] {
  position: absolute;
  inset: 0;
  width: 100%;
  margin: 0;
  background: transparent;
  pointer-events: none;
  -webkit-appearance: none;
  appearance: none;
}

.catalog-price-slider-shell input[type="range"]::-webkit-slider-runnable-track {
  height: 0.38rem;
  background: transparent;
}

.catalog-price-slider-shell input[type="range"]::-webkit-slider-thumb {
  width: 1.15rem;
  height: 1.15rem;
  border: 3px solid #fff;
  border-radius: 50%;
  background: #111;
  box-shadow: 0 4px 14px rgba(17, 17, 17, 0.2);
  cursor: pointer;
  pointer-events: auto;
  -webkit-appearance: none;
  appearance: none;
  margin-top: -0.38rem;
}

.catalog-price-slider-shell input[type="range"]::-moz-range-track {
  height: 0.38rem;
  background: transparent;
}

.catalog-price-slider-shell input[type="range"]::-moz-range-thumb {
  width: 1.15rem;
  height: 1.15rem;
  border: 3px solid #fff;
  border-radius: 50%;
  background: #111;
  box-shadow: 0 4px 14px rgba(17, 17, 17, 0.2);
  cursor: pointer;
  pointer-events: auto;
}

.catalog-price-slider-shell input[type="range"]:disabled::-webkit-slider-thumb,
.catalog-price-slider-shell input[type="range"]:disabled::-moz-range-thumb {
  opacity: 0.5;
  cursor: default;
}

.catalog-price-bounds {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  color: #5e5852;
  font-size: 0.84rem;
  font-weight: 700;
}

.catalog-price-values {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.catalog-price-values input {
  width: 100%;
}

.catalog-side-group strong {
  margin-bottom: 0.7rem;
  font-family: var(--font-display);
  font-size: 1rem;
}

.catalog-side-links {
  display: grid;
  gap: 0.45rem;
}

.catalog-side-links a {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.45rem 0;
  border-bottom: 1px solid #efebe5;
  font-weight: 700;
  color: #2a2a2a;
}

.catalog-side-links a:last-child {
  border-bottom: 0;
}

.catalog-side-links a:hover {
  color: var(--site-accent);
}

.catalog-side-links small {
  color: var(--site-muted);
  font-size: 0.8rem;
}

.catalog-side-chip-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.catalog-side-chip-links a {
  border-bottom: 0;
  padding: 0;
}

.catalog-side-chip-links .browse-pill {
  min-height: 0;
  padding: 0.48rem 0.78rem;
  border-radius: 999px;
  background: #fff;
  box-shadow: none;
  font-size: 0.84rem;
  font-weight: 800;
  line-height: 1.1;
}

.catalog-side-chip-links .browse-pill.active {
  background: #d40000;
  border-color: #d40000;
  color: #fff;
}

.catalog-bike-card {
  display: grid;
  gap: 0.85rem;
  padding: 1rem;
  margin-bottom: 1rem;
  border-radius: 20px;
  background: #f7f3ed;
  border: 1px solid #e6ddd2;
}

.catalog-bike-card-media {
  overflow: hidden;
  border-radius: 16px;
  background: #ece7df;
}

.catalog-bike-card-media img {
  width: 100%;
  aspect-ratio: 1.35 / 1;
  object-fit: cover;
}

.catalog-bike-card-copy h3 {
  margin: 0.15rem 0 0.3rem;
  font-size: 1.55rem;
}

.catalog-bike-card-copy p {
  margin: 0;
}

.catalog-bike-card-links {
  display: grid;
  gap: 0.45rem;
}

.catalog-bike-card-links a {
  color: #2b2b2b;
  font-weight: 700;
}

.catalog-entry-guide {
  display: grid;
  gap: 0.9rem;
  padding: 0.95rem;
  margin-top: 0.25rem;
  border-radius: 20px;
  background: #fbfaf8;
  border: 1px solid #e6ddd2;
  border-top: 3px solid #d40000;
}

.catalog-entry-guide strong {
  font-family: var(--font-display);
  font-size: 1.2rem;
}

.catalog-entry-guide p {
  margin: 0;
  color: #5e5852;
  line-height: 1.6;
}

.catalog-entry-links {
  display: grid;
  gap: 0.45rem;
}

.catalog-entry-links a {
  color: #262626;
  font-weight: 700;
}

.catalog-guide-brand-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.catalog-guide-brand-pills .browse-pill {
  padding: 0.55rem 0.8rem;
  background: #fff;
  box-shadow: none;
}

.catalog-guide-brand-pill {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0.55rem 0.8rem;
  border-radius: 999px;
  border: 1px solid #e4ddd3;
  background: #fff;
  color: #313131;
  font-size: 0.83rem;
  font-weight: 800;
}

.catalog-entry-model-group {
  margin-top: 0.15rem;
}

.catalog-guide-model-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.catalog-guide-model-card {
  display: grid;
  gap: 0.4rem;
  padding: 0.55rem;
  border-radius: 14px;
  border: 1px solid #e2dacc;
  background: #fff;
  color: #242424;
  text-align: center;
}

.catalog-guide-model-card img {
  width: 100%;
  aspect-ratio: 1.45 / 1;
  object-fit: cover;
  background: #ececec;
}

.catalog-guide-model-card strong {
  font-size: 0.8rem;
}

.catalog-guide-model-card span {
  color: #666;
  font-size: 0.77rem;
}

.catalog-model-facet-links a {
    align-items: flex-start;
}

.catalog-model-facet-links {
    overflow-x: hidden;
    padding-right: 0;
}

.catalog-model-facet-links .catalog-filter-option {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 0.5rem;
}

.catalog-model-facet-links .catalog-filter-option-main {
    gap: 0.6rem;
}

.catalog-model-facet-links .catalog-filter-option-label {
    font-size: 0.88rem;
    line-height: 1.25;
    overflow-wrap: anywhere;
}

.catalog-model-facet-links .catalog-filter-option-count {
    min-width: 1.4rem;
    padding-left: 0.2rem;
    font-size: 0.76rem;
    line-height: 1.2;
}

.catalog-summary-row {
    display: flex;
    align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.catalog-hero-panel {
  padding: 1.05rem 1.15rem 1rem;
  margin-bottom: 1.15rem;
}

.catalog-hero-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.9fr);
  gap: 1rem 1.25rem;
  align-items: end;
}

.catalog-hero-main,
.catalog-hero-side {
  display: grid;
  gap: 0.75rem;
}

.catalog-page-title {
    margin: 0.05rem 0 0;
}

.catalog-page-count {
    display: inline-block;
    margin-left: 0.55rem;
    font-size: 0.42em;
    line-height: 1;
    font-weight: 800;
    color: #5d554c;
    vertical-align: super;
    white-space: nowrap;
}

.catalog-page-count-number,
.catalog-page-count-label {
    display: inline-block;
    vertical-align: baseline;
}

.catalog-page-count-number {
    font-size: 1.18em;
    font-weight: 900;
    color: #342d26;
}

.catalog-page-count-label {
    margin-left: 0.3rem;
    font-size: 0.9em;
    letter-spacing: 0.01em;
}

.catalog-seo-heading {
  margin: 0;
  font-size: clamp(1.2rem, 1.8vw, 2rem);
  line-height: 1.12;
  text-align: right;
  justify-self: end;
  max-width: 28ch;
}

.catalog-page-intro {
  max-width: 42ch;
  justify-self: end;
  text-align: right;
  margin: 0;
}

.catalog-brand-story-actions {
  display: flex;
  justify-content: flex-end;
}

.catalog-brand-story-actions .btn {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.catalog-brand-modal {
  border-radius: 22px;
}

.catalog-brand-modal-body {
  display: grid;
  gap: 1rem;
  padding-top: 0.35rem;
}

.catalog-brand-modal-logo {
  display: grid;
  justify-items: start;
}

.catalog-brand-modal-logo img {
  display: block;
  max-width: min(220px, 100%);
  max-height: 72px;
  object-fit: contain;
}

.catalog-brand-modal-heading {
  margin: 0;
  font-size: clamp(1.1rem, 1.5vw, 1.6rem);
  line-height: 1.15;
}

.catalog-brand-modal-copy {
  margin: 0;
  color: var(--site-text);
}

.catalog-brand-modal-copy p {
  margin: 0;
  color: #3e3833;
  line-height: 1.72;
}

.catalog-brand-modal-copy p + p {
  margin-top: 0.95rem;
}

.catalog-summary-row .catalog-sort-form {
  margin-left: auto;
}

.catalog-hero-panel {
  padding: 0.95rem 1.15rem 0.9rem;
}

.catalog-quick-toggle-panel {
  padding: 0.7rem 1rem;
  margin-bottom: 1rem;
}

.catalog-quick-toggle-form {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.85rem;
  flex-wrap: wrap;
}

.catalog-price-filter-inline {
  flex: 1 1 420px;
  min-width: min(100%, 420px);
  margin: 0;
  padding: 0.65rem 0.9rem;
  background: #fff;
  display: grid;
  grid-template-columns: auto minmax(180px, 1fr) auto;
  align-items: center;
  gap: 0.35rem 0.85rem;
}

.catalog-price-filter-inline .catalog-price-summary {
  grid-column: 1;
  gap: 0.5rem;
  margin: 0;
  flex-wrap: nowrap;
  align-items: center;
  white-space: nowrap;
}

.catalog-price-filter-inline .catalog-price-summary strong {
  font-size: 0.82rem;
}

.catalog-price-filter-inline .catalog-price-summary span {
  font-size: 0.78rem;
}

.catalog-price-filter-inline .catalog-price-slider-shell {
  grid-column: 2;
  height: 1.95rem;
  min-width: 0;
}

.catalog-price-filter-inline .catalog-price-bounds {
  grid-column: 3;
  gap: 0.45rem;
  font-size: 0.74rem;
  white-space: nowrap;
}

.catalog-hero-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.9fr);
  gap: 0.75rem 1.1rem;
  align-items: start;
}

.catalog-hero-main,
.catalog-hero-side {
  display: grid;
  gap: 0.5rem;
}

.catalog-hero-main-brand {
  align-content: start;
}

.catalog-page-title {
    margin: 0.05rem 0 0;
}

.catalog-page-count {
    margin-left: 0.4rem;
}

.catalog-page-intro {
  max-width: 42ch;
  justify-self: end;
  text-align: right;
  margin: 0;
}

.catalog-hero-side {
  justify-items: end;
  align-content: start;
}

.catalog-hero-side-brand {
  justify-items: end;
}

.catalog-hero-side-brand .catalog-seo-heading {
  text-align: right;
  justify-self: end;
  max-width: none;
}

.catalog-hero-main-brand .catalog-brand-story-actions {
  justify-content: flex-start;
  margin-top: 0.15rem;
}

.catalog-summary-row .catalog-sort-form {
  margin-left: auto;
}

.catalog-summary-row {
    align-items: end;
    gap: 0.75rem 1rem;
}

.catalog-hero-quick-filters {
    grid-column: 1 / -1;
}

.catalog-hero-quick-filters .catalog-quick-toggle-form {
    margin-top: 0.8rem;
    padding-top: 0.8rem;
    border-top: 1px solid rgba(31, 26, 21, 0.12);
    display: flex;
    align-items: center;
    gap: 0.8rem;
    flex-wrap: nowrap;
}


.catalog-mobile-actions {
  display: none;
  gap: 0.65rem;
  width: 100%;
}

.catalog-mobile-actions .btn {
  flex: 1 1 0;
}

.catalog-sidebar-card {
  min-width: 0;
  padding: 1rem;
}

.catalog-results-panel {
  padding: 1rem;
}

.catalog-filter-shell-copy {
  margin: 0.35rem 0 0;
  color: #5f5952;
  line-height: 1.55;
}

.catalog-filters-stack {
  display: grid;
  gap: 0.85rem;
}

.catalog-filter-shell {
  display: grid;
  gap: 0.85rem;
}

.catalog-filter-shell-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
}

.catalog-filter-shell-head h2 {
  margin: 0.2rem 0 0;
  font-size: 1.35rem;
}

.catalog-filter-reset-link {
  font-size: 0.86rem;
  font-weight: 800;
  color: var(--site-accent);
  white-space: nowrap;
}

.catalog-results-active-filters .catalog-filter-reset-link {
  border-color: rgba(179, 19, 27, 0.18);
  background: #fff7f7;
  color: var(--site-accent);
  box-shadow: none;
}

.catalog-results-active-filters .catalog-filter-reset-link:hover {
  border-color: var(--site-accent);
  background: var(--site-accent);
  color: #fff;
}

.catalog-filter-form {
  display: grid;
}

.catalog-filter-block {
  border: 1px solid #e5ddd3;
  border-radius: 18px;
  background: #fff;
  overflow: hidden;
}

.catalog-filter-block + .catalog-filter-block {
  margin-top: 0;
}

.catalog-filter-block summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1rem 0.95rem;
  cursor: pointer;
  list-style: none;
}

.catalog-filter-block summary::-webkit-details-marker {
  display: none;
}

.catalog-filter-block summary::after {
  content: "+";
  flex: 0 0 auto;
  width: 1.6rem;
  height: 1.6rem;
  display: grid;
  place-items: center;
  border-radius: 999px;
  border: 1px solid #e6ddd2;
  background: #faf7f2;
  color: #38332d;
  font-weight: 800;
  line-height: 1;
}

.catalog-filter-block[open] summary::after {
  content: "-";
}

.catalog-filter-title {
  display: block;
  font-family: var(--font-display);
  font-size: 1rem;
  line-height: 1.1;
}

.catalog-filter-meta {
  display: block;
  margin-top: 0.16rem;
  color: #6b645d;
  font-size: 0.8rem;
  font-weight: 700;
}

.catalog-filter-content {
  display: grid;
  gap: 0.9rem;
  padding: 0 1rem 1rem;
  border-top: 1px solid #f0ebe5;
}

.catalog-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.9rem;
  padding: 0.9rem 0.95rem;
  border-radius: 16px;
  border: 1px solid #ebe3d8;
  background: #fbfaf8;
}

.catalog-toggle-row-compact {
    min-width: 0;
    flex: 0 0 220px;
    padding: 0.7rem 0.9rem;
    background: #fff;
}

.catalog-toggle-row-compact .catalog-toggle-copy strong {
  font-size: 0.88rem;
}

.catalog-toggle-row.is-disabled {
    opacity: 0.65;
}

.catalog-hero-quick-filters .catalog-price-filter-inline {
    flex: 1 1 auto;
    min-width: 0;
}

.catalog-toggle-copy {
  display: grid;
  gap: 0.14rem;
}

.catalog-toggle-copy strong {
  font-size: 0.95rem;
}

.catalog-toggle-switch {
  position: relative;
  display: inline-flex;
  flex: 0 0 auto;
}

.catalog-toggle-switch input {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
}

.catalog-toggle-switch em {
  position: relative;
  width: 46px;
  height: 28px;
  border-radius: 999px;
  background: #d9d0c5;
  transition: background 0.2s ease;
}

.catalog-toggle-switch em::after {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 2px 8px rgba(17, 17, 17, 0.18);
  transition: transform 0.2s ease;
}

.catalog-toggle-switch input:checked + em {
  background: var(--site-accent);
}

.catalog-toggle-switch input:checked + em::after {
  transform: translateX(18px);
}

.catalog-filter-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.catalog-filter-actions .btn {
  min-height: 44px;
}

.catalog-facet-search-field {
  margin-top: 0.35rem;
  margin-bottom: 0.45rem;
}

.catalog-facet-search-field input {
  width: 100%;
  min-width: 0;
  min-height: 42px;
  padding: 0 0.85rem;
  border: 1px solid #ddd3c6;
  border-radius: 12px;
  background: #faf7f2;
  color: #1f1f1f;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
}

.catalog-facet-search-field input:focus {
  outline: 0;
  border-color: rgba(179, 19, 27, 0.35);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(179, 19, 27, 0.08);
}

.catalog-filter-options {
  display: grid;
}

.catalog-filter-options-scrollable {
  max-height: 24rem;
  overflow-x: hidden;
  overflow-y: auto;
  padding-right: 0.2rem;
}

.catalog-model-facet-links.catalog-filter-options-scrollable {
  max-height: 28rem;
}

.catalog-filter-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.85rem;
  padding: 0.78rem 0;
  border-bottom: 1px solid #f1ece6;
  color: #242424;
}

.catalog-filter-option:last-child {
  border-bottom: 0;
}

.catalog-filter-option[hidden] {
  display: none !important;
}

.catalog-filter-option-main {
  display: flex;
  align-items: flex-start;
  gap: 0.7rem;
  min-width: 0;
}

.catalog-filter-option-check {
  position: relative;
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  margin-top: 0.12rem;
  border-radius: 5px;
  border: 1.5px solid #cfc6ba;
  background: #fff;
}

.catalog-filter-option-label {
  display: block;
  color: inherit;
  font-size: 0.92rem;
  font-weight: 700;
  line-height: 1.35;
}

.catalog-filter-option-count {
  flex: 0 0 auto;
  min-width: 2.2rem;
  text-align: right;
  color: #7a7269;
  font-size: 0.82rem;
  font-weight: 800;
}

.catalog-filter-option:hover {
  color: var(--site-accent);
}

.catalog-filter-option.active {
  color: #111;
}

.catalog-filter-option.active .catalog-filter-option-check {
  border-color: var(--site-accent);
  background: var(--site-accent);
}

.catalog-filter-option.active .catalog-filter-option-check::after {
    content: "";
    position: absolute;
    left: 5px;
    top: 2px;
  width: 5px;
  height: 9px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.catalog-filter-option.is-pending,
.catalog-active-pill.is-pending {
    pointer-events: none;
}

.catalog-filter-option.is-pending {
    opacity: 0.92;
}

.catalog-facet-empty {
  padding: 0.9rem 0;
  color: #736b63;
  font-size: 0.88rem;
  font-weight: 700;
}

.catalog-sidebar-mobile-head {
  display: none;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  padding-bottom: 0.9rem;
  border-bottom: 1px solid var(--site-line);
}

.catalog-sidebar-mobile-head strong {
  font-family: var(--font-display);
  font-size: 1.3rem;
}

.catalog-sidebar-close {
  width: 42px;
  height: 42px;
  border: 1px solid var(--site-line);
  border-radius: 12px;
  background: #fff;
  color: #1f1f1f;
  font-size: 1.8rem;
  line-height: 1;
}

.catalog-mobile-overlay {
  display: none;
}

body.catalog-sidebar-open {
  overflow: auto;
}

.catalog-relative-panel {
  display: grid;
  gap: 1rem;
  border-top: 3px solid #d40000;
}

.catalog-relative-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.catalog-results-panel {
  display: grid;
  gap: 1rem;
  padding: 0.8rem 0.85rem 0.9rem;
  align-self: start;
  min-height: 0;
}

.catalog-results-grid {
  margin-top: 0;
  align-items: start;
  align-content: start;
  grid-auto-rows: max-content;
}

.catalog-results-grid > .catalog-product-card {
  height: auto;
}

.catalog-shell {
  display: grid;
  gap: 1rem;
}

.catalog-shell.is-loading {
  opacity: 0.62;
  transition: opacity 0.18s ease;
}

.catalog-lazy-more {
  display: grid;
  justify-items: center;
  gap: 0.55rem;
  padding: 0.55rem 0.25rem 0.05rem;
  border-top: 1px solid #ece7df;
}

.catalog-lazy-copy {
  display: grid;
  gap: 0.2rem;
  justify-items: center;
  text-align: center;
}

.catalog-lazy-copy strong {
  font-family: var(--font-display);
  font-size: 1rem;
}

.catalog-lazy-more.is-complete [data-catalog-load-more] {
  display: none;
}

.catalog-lazy-sentinel {
  width: 100%;
  height: 1px;
}

.catalog-relative-groups {
  display: grid;
  gap: 0.9rem;
}

.catalog-relative-group {
  display: grid;
  gap: 0.65rem;
  padding-top: 0.9rem;
  border-top: 1px solid var(--site-line);
}

.catalog-relative-group:first-child {
  padding-top: 0;
  border-top: 0;
}

.catalog-relative-group strong,
.catalog-side-group strong {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.96rem;
}

.catalog-relative-group strong::after,
.catalog-side-group strong::after {
  content: "";
  width: 38px;
  height: 2px;
  background: var(--site-accent);
}

.catalog-relative-links {
  margin-bottom: 0;
}

.catalog-clear-pill {
  background: #f6f1ea;
}

.summary-row.total {
  padding-top: 0.8rem;
  border-top: 1px solid var(--site-line);
  font-weight: 800;
  font-size: 1.08rem;
}

.detail-shell {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 1.25rem;
    padding: 1.4rem;
    margin-bottom: 0;
}

.detail-top-layout {
    display: grid;
    gap: 1rem;
    margin-bottom: 1rem;
}

.detail-media-column {
    display: grid;
    gap: 1rem;
    align-content: start;
}

.detail-media-shell {
  display: grid;
  gap: 0.85rem;
}

.detail-media {
  display: grid;
  place-items: center;
  padding: 1rem;
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
  min-height: 420px;
  align-content: center;
  border: 1px solid var(--site-line);
}

.detail-media.is-video {
  align-items: stretch;
}

.detail-media-frame {
  width: 100%;
  min-height: 380px;
  display: grid;
  place-items: center;
  text-decoration: none;
}

.detail-media img {
  width: auto;
  max-width: 100%;
  height: auto;
  max-height: 560px;
  object-fit: contain;
}

.detail-media-thumbs {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(76px, 1fr));
  gap: 0.65rem;
}

.detail-media-thumb {
  appearance: none;
  background: #fff;
  border: 1px solid var(--site-line);
  border-radius: 16px;
  padding: 0.45rem;
  min-height: 78px;
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.detail-media-thumb:hover {
  transform: translateY(-1px);
  border-color: rgba(196, 19, 31, 0.32);
}

.detail-media-thumb.is-active {
  border-color: rgba(196, 19, 31, 0.55);
  box-shadow: 0 0 0 2px rgba(196, 19, 31, 0.12);
}

.detail-media-thumb-media {
  position: relative;
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
}

.detail-media-thumb img {
  width: auto;
  max-width: 100%;
  max-height: 64px;
  object-fit: contain;
}

.detail-media-thumb-badge {
  position: absolute;
  right: 0.25rem;
  bottom: 0.25rem;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(17, 17, 17, 0.8);
  color: #fff;
  font-size: 0.72rem;
}

.detail-video-stage {
  width: 100%;
  display: grid;
  gap: 0.9rem;
  align-content: start;
}

.detail-video-embed {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  overflow: hidden;
  border-radius: 16px;
  background: #0f1013;
}

.detail-video-embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.detail-video-launch {
  justify-self: start;
}

.detail-docs-panel {
    display: grid;
    gap: 0.9rem;
    padding: 1.1rem 1.15rem;
    margin: 0;
}

.detail-docs-slot {
  min-width: 0;
}

.detail-docs-head {
  margin-bottom: 0;
}

.detail-docs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.7rem;
}

.detail-doc-card {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    height: 100%;
    padding: 0.85rem 0.95rem;
    border: 1px solid var(--site-line);
  border-radius: 16px;
  background: var(--site-panel-soft);
  color: inherit;
  text-decoration: none;
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.detail-doc-card:hover {
  transform: translateY(-1px);
  border-color: rgba(196, 19, 31, 0.24);
  box-shadow: 0 10px 24px rgba(17, 17, 17, 0.08);
}

.detail-doc-icon {
  width: 2.6rem;
  height: 2.6rem;
  flex: 0 0 2.6rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: #fff;
  color: var(--site-accent);
  border: 1px solid var(--site-line);
  font-size: 1rem;
}

.detail-doc-copy {
  min-width: 0;
  display: grid;
  gap: 0.18rem;
  flex: 1 1 auto;
}

.detail-doc-copy strong {
  font-size: 0.95rem;
  line-height: 1.35;
}

.detail-doc-copy span {
  font-size: 0.82rem;
  color: var(--site-muted);
}

.detail-doc-arrow {
  color: var(--site-muted);
  font-size: 0.9rem;
}

.detail-copy {
    display: grid;
    gap: 0.9rem;
    align-content: start;
}

.product-lightbox-open {
    overflow: hidden;
}

.product-lightbox {
    position: fixed;
    inset: 0;
    z-index: 2000;
    display: grid;
    place-items: center;
    padding: 2rem;
    background: rgba(10, 10, 10, 0.92);
}

.product-lightbox[hidden] {
    display: none !important;
}

.product-lightbox-stage {
    width: min(92vw, 1200px);
    height: min(86vh, 900px);
    display: grid;
    place-items: center;
}

.product-lightbox-stage img {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
}

.product-lightbox-close,
.product-lightbox-nav {
    position: absolute;
    border: 0;
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    width: 3rem;
    height: 3rem;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.18s ease, transform 0.18s ease;
}

.product-lightbox-close:hover,
.product-lightbox-nav:hover {
    background: rgba(255, 255, 255, 0.2);
    transform: translateY(-1px);
}

.product-lightbox-close {
    top: 1rem;
    right: 1rem;
}

.product-lightbox-prev {
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
}

.product-lightbox-next {
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
}

.product-lightbox-prev:hover,
.product-lightbox-next:hover {
    transform: translateY(-50%) translateY(-1px);
}

.detail-head {
  display: grid;
  gap: 0.65rem;
  padding-bottom: 0.15rem;
}

.detail-route-eyebrow {
  display: flex;
  align-items: center;
  gap: 0.35rem 0.55rem;
  flex-wrap: wrap;
}

.detail-route-link {
  color: inherit;
}

.detail-route-link:hover {
  color: var(--site-accent);
}

.detail-route-divider {
  color: var(--site-muted);
}

.detail-page-title {
  margin: 0;
  line-height: 1.14;
}

.detail-meta-row {
  display: flex;
  align-items: center;
  gap: 0.55rem 1rem;
  flex-wrap: wrap;
}

.detail-meta {
    margin: 0;
}

.detail-route-links {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem 0.55rem;
}

.detail-route-links .browse-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 0;
    padding: 0.42rem 0.74rem;
    border-radius: 999px;
    background: #fff;
    box-shadow: none;
    font-size: 0.82rem;
    font-weight: 800;
    line-height: 1.1;
    white-space: nowrap;
}

.detail-route-links .browse-pill:hover {
    border-color: rgba(196, 19, 31, 0.28);
    color: var(--site-accent);
}

.detail-quick-links {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.detail-buy-panel {
  display: grid;
  grid-template-columns: minmax(120px, 150px) minmax(0, 1fr) minmax(0, 1fr);
  align-items: end;
  gap: 0.75rem;
  padding: 0.85rem;
  border: 1px solid var(--site-line);
  border-radius: 22px;
  background: linear-gradient(135deg, #fff 0%, var(--site-panel-soft) 100%);
}

.detail-buy-panel .btn {
  min-height: 52px;
  justify-content: center;
}

.detail-buy-qty {
  display: grid;
  gap: 0.35rem;
  margin: 0;
  color: var(--site-muted);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.detail-buy-qty .qty-input {
  min-height: 52px;
  padding: 0.75rem 0.9rem;
}

.detail-quick-card {
  display: grid;
  gap: 0.25rem;
  padding: 0.9rem 1rem;
  border-radius: 18px;
  border: 1px solid var(--site-line);
  background: var(--site-panel-soft);
  color: inherit;
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.detail-quick-card strong {
  font-size: 0.96rem;
}

.detail-quick-card span {
  color: var(--site-muted);
  font-size: 0.88rem;
}

.detail-quick-card:hover {
  transform: translateY(-1px);
  border-color: rgba(189, 0, 15, 0.2);
  box-shadow: 0 12px 28px rgba(30, 24, 19, 0.08);
}

.detail-specs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.detail-specs div,
.compat-card,
.option-card {
  padding: 0.95rem 1rem;
  border-radius: 18px;
  border: 1px solid var(--site-line);
  background: var(--site-panel-soft);
}

.detail-description {
  line-height: 1.7;
}

.product-story-section {
  display: grid;
  gap: 1rem;
}

.product-story-head {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding-bottom: 0.9rem;
  border-bottom: 1px solid var(--site-line);
}

.product-story-logo {
  flex: 0 0 auto;
  width: 120px;
  min-height: 72px;
  display: grid;
  place-items: center;
  padding: 0.8rem;
  border-radius: 16px;
  border: 1px solid #ebe4db;
  background: #fff;
}

.product-story-logo img {
  max-width: 100%;
  max-height: 48px;
  object-fit: contain;
}

.product-story-heading-copy {
  display: grid;
  gap: 0.25rem;
}

.product-story-heading-copy h2 {
  margin: 0;
}

.product-story-preview,
.product-story-body {
  color: #3e3833;
  line-height: 1.72;
}

.product-story-preview p,
.product-story-body p {
  margin: 0;
}

.product-story-body p + p {
  margin-top: 0.95rem;
}

.product-story-preview.is-hidden {
  display: none;
}

.product-story-accordion {
  display: grid;
  gap: 0.85rem;
}

.product-story-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  cursor: pointer;
  list-style: none;
  color: var(--site-accent);
  font-weight: 800;
}

.product-story-toggle::-webkit-details-marker {
  display: none;
}

.product-story-toggle::after {
  content: "\f078";
  font-family: "Font Awesome 7 Free";
  font-weight: 900;
  font-size: 0.78rem;
  transition: transform 0.18s ease;
}

.product-story-accordion[open] .product-story-toggle::after {
  transform: rotate(180deg);
}

.product-story-toggle-less,
.product-story-accordion[open] .product-story-toggle-more {
  display: none;
}

.product-story-accordion[open] .product-story-toggle-less {
  display: inline;
}

.product-story-body-static {
  padding-top: 0.1rem;
}

@media (max-width: 767px) {
  .product-story-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .product-story-logo {
    width: min(140px, 100%);
  }
}

.compat-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.8rem;
}

.compat-groups {
  display: grid;
  gap: 1rem;
}

.compat-refine {
  display: grid;
  gap: 0.45rem;
  margin-bottom: 0.9rem;
}

.compat-refine-label {
  font-size: 0.82rem;
  font-weight: 800;
  color: var(--site-muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.compat-refine-input {
  width: 100%;
  min-height: 46px;
  border: 1px solid #ddd3c6;
  border-radius: 14px;
  padding: 0.8rem 0.95rem;
  background: #fff;
  box-shadow: inset 0 1px 2px rgba(33, 27, 23, 0.04);
}

.compat-group {
  display: grid;
  gap: 0.75rem;
  padding: 1rem 1.05rem;
  border-radius: 20px;
  border: 1px solid var(--site-line);
  background: #fbfaf8;
}

.compat-group h3 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.15rem;
}

.compat-group-heading {
  margin: 0;
}

.compat-group-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.15rem;
}

.compat-group-header,
.compat-group-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.7rem;
}

.compat-group-summary {
  cursor: pointer;
  list-style: none;
}

.compat-group-summary::-webkit-details-marker {
  display: none;
}

.compat-group-heading-line {
  display: inline-flex;
  align-items: flex-start;
  gap: 0.18rem;
  flex-wrap: wrap;
}

.compat-group-count-sup {
  display: inline-block;
  margin-left: 0.02rem;
  font-size: 0.6em;
  line-height: 1;
  font-weight: 900;
  color: #4f4840;
  vertical-align: super;
}

.compat-group-count-label {
    display: inline-block;
    margin-left: 0.28rem;
  color: var(--site-muted);
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.2;
    white-space: nowrap;
}

.compat-group-section-label {
    flex: 0 0 auto;
    color: var(--site-muted);
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    white-space: nowrap;
}

.compat-group-accordion .compat-links {
  margin-top: 0.85rem;
}

.compat-subgroups {
    display: flex;
    flex-wrap: wrap;
    gap: 0.48rem;
    align-items: flex-start;
}

.compat-subgroups.has-compat-subgroup-menu {
  display: grid;
  gap: 0.72rem;
}

.compat-subgroup {
    display: contents;
    min-width: 0;
}

.compat-subgroups.has-compat-subgroup-menu .compat-subgroup {
  display: block;
  min-width: 0;
}

.compat-subgroups.has-compat-subgroup-menu .compat-subgroup:not([open]) {
  display: none;
}

.compat-subgroup[open] {
    grid-column: auto;
}

.compat-subgroup-menu {
  display: flex;
  flex-wrap: wrap;
  gap: 0.48rem;
  align-items: center;
}

.compat-subgroup-summary {
    order: 1;
    display: inline-flex;
    align-items: center;
  gap: 0.35rem;
  min-height: 38px;
  padding: 0.55rem 0.82rem;
  border: 1px solid #e0d5c8;
  border-radius: 999px;
  background: #fff;
  box-shadow: 0 8px 18px rgba(26, 21, 18, 0.04);
  cursor: pointer;
  list-style: none;
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

.compat-subgroup-menu-item {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  min-height: 38px;
  padding: 0.55rem 0.82rem;
  border: 1px solid #e0d5c8;
  border-radius: 999px;
  background: #fff;
  color: var(--site-ink);
  box-shadow: 0 8px 18px rgba(26, 21, 18, 0.04);
  cursor: pointer;
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

.compat-subgroup-menu-item.is-active,
.compat-subgroup-menu-item:hover,
.compat-subgroup-menu-item:focus-visible {
  border-color: #2b2f35;
  background: #2b2f35;
  color: #fff;
  box-shadow: 0 12px 26px rgba(26, 21, 18, 0.12);
}

.compat-subgroup-menu-item:focus-visible {
  outline: 3px solid rgba(179, 19, 27, 0.18);
  outline-offset: 2px;
}

.compat-subgroups.has-compat-subgroup-menu .compat-subgroup-summary {
  display: none;
}

.compat-subgroup-summary::-webkit-details-marker {
  display: none;
}

.compat-subgroup-summary::after {
  content: none;
}

.compat-subgroup[open] > .compat-subgroup-summary {
  border-color: #2b2f35;
  background: #2b2f35;
  color: #fff;
  box-shadow: 0 12px 26px rgba(26, 21, 18, 0.12);
}

.compat-subgroup .compat-links {
    order: 2;
    flex: 1 0 100%;
    margin-top: 0.35rem;
    padding: 0.85rem;
    border: 1px solid #e6ddd0;
    border-radius: 18px;
    background: #fff;
}

.compat-subgroups.has-compat-subgroup-menu .compat-subgroup .compat-links {
  margin-top: 0;
}

.compat-subgroups-nested {
  margin-top: 0.8rem;
}

.compat-subgroups-nested .compat-subgroup {
  border-radius: 0;
}

.compat-subgroup-title {
  font-size: 1rem;
}

.compat-group-count {
  color: var(--site-muted);
  font-size: 0.88rem;
  white-space: nowrap;
}

.compat-links {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.7rem;
}

.compat-link {
  display: grid;
  gap: 0.18rem;
  padding: 0.7rem 0.78rem;
  border-radius: 14px;
  border: 1px solid #e4ddd3;
  background: #fff;
  color: #202020;
  transition: border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.compat-link:hover {
  transform: translateY(-1px);
  border-color: rgba(179, 19, 27, 0.22);
  box-shadow: 0 12px 24px rgba(26, 21, 18, 0.06);
}

.compat-link-name {
  display: block;
  font-weight: 800;
  line-height: 1.25;
}

.compat-link-meta {
  display: block;
  color: var(--site-muted);
  font-size: 0.82rem;
  line-height: 1.25;
}

.compat-search-empty {
  margin: 0;
  padding: 0.85rem 0.95rem;
  border-radius: 14px;
  border: 1px dashed #d8cdc0;
  color: var(--site-muted);
  background: #fff;
}

.compat-all-models-note {
  padding: 1.05rem 1.15rem;
  border-radius: 18px;
  border: 1px solid var(--site-line);
  background: #fbfaf8;
}

.compat-all-models-note strong {
  display: block;
  margin-bottom: 0.35rem;
  font-family: var(--font-display);
  font-size: 1.05rem;
}

.detail-mobile-bar {
  display: none;
}

.table-shell {
  width: 100%;
  border-collapse: collapse;
}

.table-shell th,
.table-shell td {
  padding: 0.95rem 0.75rem;
  border-bottom: 1px solid var(--site-line);
  vertical-align: top;
}

.cart-product {
  display: flex;
  gap: 0.95rem;
}

.cart-thumb {
  width: 88px;
  height: 88px;
  border-radius: 18px;
  overflow: hidden;
  background: #efe9df;
  flex-shrink: 0;
}

.cart-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cart-qty-input {
  max-width: 126px;
}

.cart-qty-input.is-saving {
  opacity: 0.72;
  box-shadow: 0 0 0 3px rgba(193, 15, 26, 0.08);
}

.cart-qty-input.has-error {
  border-color: #c10f1a;
}

.cart-actions-row {
  align-items: center;
  justify-content: space-between;
  padding-top: 0.9rem;
}

.cart-actions-left,
.cart-actions-right {
  display: flex;
  align-items: center;
  gap: 0.8rem;
}

.cart-actions-right {
  margin-left: auto;
}

.cart-subtotal-row {
  min-width: 190px;
  justify-content: flex-end;
  gap: 0.65rem;
  font-size: 1.08rem;
}

.cart-actions-row .btn {
  min-width: 150px;
}

.checkout-grid,
.auth-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.85fr;
  gap: 1rem;
}

.field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.checkout-helper-card {
  margin-bottom: 1rem;
  padding: 1rem 1.1rem;
  border-radius: 20px;
  border: 1px solid var(--site-line);
  background: linear-gradient(180deg, #fffcf8 0%, #f8f4ee 100%);
}

.checkout-helper-card h3 {
  margin: 0.2rem 0 0.45rem;
}

.checkout-helper-card .muted {
  margin-bottom: 0.45rem;
}

.checkout-helper-actions {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-top: 0.85rem;
}

.checkout-account-inline {
  margin-top: 1rem;
  display: grid;
  gap: 0.9rem;
}

.checkout-account-toggle {
  background: linear-gradient(180deg, #fffdf8 0%, #f8f4ee 100%);
}

.checkout-account-toggle em {
  display: block;
  margin-top: 0.25rem;
  color: var(--site-muted);
  font-style: normal;
  line-height: 1.5;
}

.checkout-account-fields {
  padding: 1rem 1rem 0;
  border-top: 1px solid var(--site-line);
}

.checkout-option-list {
  gap: 0;
}

.checkout-choice-card {
  display: grid;
  gap: 0.55rem;
  padding: 0.95rem 0;
  border-top: 1px solid var(--site-line);
}

.checkout-choice-card:first-child {
  padding-top: 0;
  border-top: none;
}

.checkout-choice-card .option-card span {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.35rem 0.75rem;
  width: 100%;
}

.checkout-choice-card .option-card em {
  color: var(--site-muted);
  font-style: normal;
  font-weight: 700;
}

.checkout-choice-help,
.checkout-choice-check {
  margin-left: 2.1rem;
}

.checkout-choice-help {
  color: var(--site-muted);
  font-size: 0.95rem;
  line-height: 1.55;
}

.checkout-payonline-shell {
  margin-left: 2.1rem;
  padding: 1rem 1.1rem;
  border: 1px solid var(--site-line);
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(248, 244, 239, 0.96) 100%);
}

.checkout-payonline-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1rem 1.15rem;
  align-items: start;
}

.checkout-payonline-title {
  margin-bottom: 0.65rem;
  color: var(--site-accent);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.checkout-paypal-button-stack {
  min-height: 46px;
}

.checkout-paypal-button-stack:empty {
  display: none;
}

.checkout-paypal-button-stack > * {
  min-height: 46px;
}

.checkout-wallet-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-bottom: 0.55rem;
}

.checkout-wallet-badges span {
  display: inline-flex;
  align-items: center;
  gap: 0.34rem;
  padding: 0.4rem 0.62rem;
  border: 1px solid var(--site-line);
  border-radius: 999px;
  background: #fff;
  color: var(--site-ink);
  font-size: 0.84rem;
  font-weight: 800;
  line-height: 1;
}

.checkout-wallet-hint {
  margin-bottom: 0.7rem;
  font-size: 0.88rem;
}

.checkout-wallet-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 0.85rem;
  margin-top: 0.85rem;
}

.checkout-wallet-card,
.checkout-card-fields-shell {
  padding: 0.9rem 1rem;
  border: 1px solid var(--site-line);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.96);
}

.checkout-wallet-title {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0.6rem;
  font-size: 0.92rem;
  font-weight: 700;
}

.checkout-wallet-title i {
  color: var(--site-ink);
}

.checkout-card-fields-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem 1rem;
}

.checkout-card-field {
  min-height: 50px;
  padding: 0.4rem 0.85rem;
  border: 1px solid var(--site-line);
  border-radius: 16px;
  background: #fff;
  display: flex;
  align-items: center;
}

.checkout-payonline-note {
  margin-top: 0.85rem;
  font-size: 0.9rem;
}

.checkout-payment-under-summary {
  margin-top: 1.1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--site-line);
}

.checkout-payment-under-summary .section-head {
  margin-bottom: 0.35rem;
}

.checkout-shipping-under-payment {
  margin-top: 1rem;
  padding-top: 0.85rem;
  border-top: 1px solid var(--site-line);
}

.checkout-shipping-under-payment .section-head.hidden + .checkout-option-list.hidden {
  display: none !important;
}

.checkout-payment-under-summary .checkout-choice-help,
.checkout-payment-under-summary .checkout-choice-check,
.checkout-payment-under-summary .checkout-payonline-shell {
  margin-left: 0;
}

.checkout-summary-actions {
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(0, 1fr);
  gap: 0.65rem;
}

.checkout-online-busy {
  pointer-events: none;
}

.checkout-online-busy .checkout-payonline-shell {
  opacity: 0.72;
}

.checkout-choice-help-pre {
  white-space: pre-line;
}

.checkout-choice-check {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  color: #4f4944;
  font-size: 0.94rem;
  line-height: 1.55;
}

.checkout-choice-check input {
  margin-top: 0.22rem;
}

.checkout-form-shell {
  display: block;
}

.checkout-coupon-panel {
  margin-bottom: 1rem;
  padding: 0.95rem 1rem;
  border-radius: 20px;
  border: 1px solid var(--site-line);
  background: var(--site-panel-soft);
}

.checkout-coupon-label {
  display: block;
  margin-bottom: 0.55rem;
  font-size: 0.9rem;
  font-weight: 800;
}

.coupon-field-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 0.6rem;
  align-items: center;
}

.coupon-field-row input {
  min-width: 0;
}

.coupon-feedback {
  margin: 0.7rem 0 0;
  padding: 0.75rem 0.85rem;
  border-radius: 16px;
  font-size: 0.92rem;
  line-height: 1.5;
}

.coupon-feedback.success {
  border: 1px solid rgba(28, 126, 74, 0.16);
  background: rgba(227, 245, 235, 0.95);
  color: #0f6a39;
}

.coupon-feedback.warning {
  border: 1px solid rgba(181, 111, 11, 0.16);
  background: rgba(255, 243, 222, 0.98);
  color: #a46307;
}

.coupon-feedback.error {
  border: 1px solid rgba(184, 41, 41, 0.14);
  background: rgba(255, 234, 234, 0.95);
  color: #a62f2f;
}

.coupon-row-hidden {
  display: none;
}

.summary-row.hidden,
.checkout-choice-help.hidden,
.checkout-choice-check.hidden,
.checkout-payonline-shell.hidden,
.checkout-wallet-card.hidden {
  display: none !important;
}

.field-full {
  grid-column: 1 / -1;
}

.option-card {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
}

.form-errors {
  padding: 0.9rem 1rem;
  border-radius: 16px;
  background: #ffe9ea;
  border: 1px solid #f3c6c9;
  color: #8f0f16;
  margin-bottom: 1rem;
}

.form-warning {
  padding: 0.9rem 1rem;
  border-radius: 16px;
  background: rgba(255, 243, 222, 0.98);
  border: 1px solid rgba(181, 111, 11, 0.16);
  color: #8a5905;
  margin-bottom: 1rem;
}

.form-success {
  padding: 0.9rem 1rem;
  border-radius: 16px;
  background: rgba(227, 245, 235, 0.95);
  border: 1px solid rgba(28, 126, 74, 0.16);
  color: #0f6a39;
  margin-bottom: 1rem;
}

.auth-link-row {
  margin: -0.15rem 0 0.35rem;
}

.auth-inline-link {
  color: var(--site-accent);
  font-size: 0.92rem;
  font-weight: 700;
  text-decoration: none;
}

.auth-inline-link:hover {
  color: var(--site-accent-deep);
  text-decoration: underline;
}

.site-footer {
  margin-top: 2.6rem;
  padding: 3rem 0 6rem;
  background: #f2f2f2;
  border-top: 1px solid #ded8cf;
}

.legacy-footer-inner {
  display: grid;
  gap: 1.9rem;
}

.legacy-footer-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(2rem, 4vw, 5rem);
}

.legacy-footer-panel {
  min-width: 0;
  display: grid;
  align-content: start;
  gap: 0.9rem;
}

.legacy-footer-panel h3,
.legacy-newsletter-form > label {
  margin: 0;
  color: #292d34;
  font-family: var(--font-display);
  font-size: clamp(1.55rem, 2vw, 2rem);
  font-weight: 800;
  letter-spacing: 0.01em;
}

.legacy-footer-panel p {
  margin: 0;
  color: #2f3034;
  font-size: 0.96rem;
  line-height: 1.62;
}

.legacy-footer-more {
  width: max-content;
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 1.05rem;
  border: 1px solid #d4d4d4;
  background: #fff;
  color: #25272d;
  font-size: 0.92rem;
  font-weight: 800;
  transition: border-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.legacy-footer-more:hover {
  border-color: var(--site-accent);
  color: var(--site-accent);
  transform: translateY(-1px);
}

.legacy-footer-logo {
  width: 155px;
  height: auto;
  margin-top: 0.35rem;
}

.legacy-newsletter-form {
  display: grid;
  gap: 0.55rem;
  margin-top: 1rem;
}

.legacy-newsletter-label {
  color: #2d2f35;
  font-size: 0.92rem;
  font-weight: 800;
}

.legacy-newsletter-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.5rem;
}

.legacy-newsletter-row input {
  min-width: 0;
  height: 46px;
  padding: 0 0.95rem;
  border: 1px solid #bdbdbd;
  background: #fff;
  color: #202020;
  outline: 0;
}

.legacy-newsletter-row input:focus {
  border-color: var(--site-accent);
  box-shadow: 0 0 0 3px rgba(179, 19, 27, 0.12);
}

.legacy-newsletter-row button {
  min-height: 46px;
  padding: 0 1rem;
  border: 0;
  background: #d40000;
  color: #fff;
  font-weight: 800;
}

.legacy-footer-contact-lines {
  display: grid;
  gap: 0.3rem;
  color: #25272d;
  font-size: 0.95rem;
  line-height: 1.5;
}

.legacy-footer-contact-lines a {
  font-weight: 800;
}

.legacy-footer-socials {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 0.25rem;
}

.legacy-footer-social {
  width: 34px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: #2f333a;
  color: #fff;
  transition: background 0.18s ease, transform 0.18s ease;
}

.legacy-footer-social:hover {
  background: var(--site-accent);
  color: #fff;
  transform: translateY(-1px);
}

.legacy-footer-links {
  display: grid;
  gap: 0.35rem;
  margin-top: 0.25rem;
}

.legacy-footer-links a {
  width: max-content;
  color: #2f3034;
  font-size: 0.94rem;
  font-weight: 700;
}

.legacy-footer-links a:hover {
  color: var(--site-accent);
}

.legacy-footer-copyright {
  padding-top: 1.6rem;
  border-top: 1px solid #d8d8d8;
  color: #24262b;
  font-size: 0.92rem;
  text-align: center;
}

.legacy-footer-copyright a {
  font-weight: 800;
}

@media (max-width: 991px) {
  .legacy-footer-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}

@media (max-width: 575px) {
  .site-footer {
    margin-top: 1.8rem;
    padding-top: 2.1rem;
  }

  .legacy-newsletter-row {
    grid-template-columns: 1fr;
  }

  .legacy-newsletter-row button {
    width: 100%;
  }

  .legacy-footer-links a {
    width: 100%;
  }
}

.mobile-menu-section + .mobile-menu-section {
  margin-top: 1rem;
}

.mobile-menu-quick-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.65rem;
}

.mobile-menu-quick-link {
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 0.8rem;
  border: 1px solid var(--site-line);
  border-radius: 14px;
  background: #fff;
  color: #222;
  font-size: 0.88rem;
  font-weight: 700;
  text-align: center;
}

.mobile-links {
  display: grid;
  gap: 0.55rem;
}

.mobile-links a {
  padding: 0.75rem 0.9rem;
  border: 1px solid var(--site-line);
  border-radius: 14px;
  background: var(--site-panel-soft);
}

.site-dock {
  position: fixed;
  left: 0.7rem;
  right: 0.7rem;
  bottom: calc(env(safe-area-inset-bottom, 0px) + 0.7rem);
  z-index: 40;
  display: none !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.35rem;
  padding: 0.45rem;
  background: rgba(255, 253, 250, 0.94);
  border: 1px solid rgba(31, 31, 31, 0.08);
  border-radius: 24px;
  box-shadow: 0 18px 38px rgba(17, 17, 17, 0.14);
  backdrop-filter: blur(14px);
}

.site-dock a {
  min-height: 58px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
  position: relative;
  padding: 0.45rem 0.25rem;
  text-align: center;
  font-size: 0.72rem;
  line-height: 1.05;
  color: #4a4540;
  border-radius: 18px;
  font-weight: 800;
  transition: background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.site-dock-icon {
  font-size: 1rem;
  line-height: 1;
}

.site-dock a span {
  display: block;
  max-width: 100%;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.site-dock-badge {
  position: absolute;
  top: 0.32rem;
  right: 0.65rem;
  min-width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 0.28rem;
  border-radius: 999px;
  background: var(--site-accent);
  color: #fff;
  font-size: 0.67rem;
  font-style: normal;
  font-weight: 800;
  line-height: 1;
}

.site-dock a.active {
  background: linear-gradient(180deg, rgba(212, 0, 0, 0.1), rgba(212, 0, 0, 0.04));
  color: var(--site-accent);
  box-shadow: inset 0 0 0 1px rgba(212, 0, 0, 0.14);
}

.content-shell {
  display: grid;
  gap: 1.5rem;
  padding: 1.4rem 0 2.4rem;
}

.page-header-block {
  display: grid;
  gap: 0.45rem;
}

.page-header-block h1 {
  margin: 0;
  font-size: clamp(2rem, 2.8vw, 3.1rem);
}

.page-subtext {
  max-width: 72ch;
  margin: 0;
  color: var(--site-muted);
  line-height: 1.65;
}

.page-header-inline {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 1rem;
}

.info-shell {
  max-width: 980px;
  margin: 0 auto;
}

.info-hero,
.info-content {
  display: grid;
  gap: 1rem;
}

.info-hero {
  min-height: 0;
  justify-content: start;
  justify-items: start;
  align-content: start;
  align-items: start;
  text-align: left;
  padding: 1.65rem 1.8rem;
}

.info-hero h1 {
  width: 100%;
}

.info-hero p,
.info-content p {
  max-width: 82ch;
  margin: 0;
  color: #37312c;
  line-height: 1.72;
}

.info-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 0.4rem;
}

.info-about-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 300px);
  gap: 1.2rem;
  align-items: start;
}

.info-about-copy {
  display: grid;
  gap: 0.95rem;
}

.info-about-card {
  display: grid;
  gap: 0.75rem;
  padding: 1rem;
  border: 1px solid var(--site-line);
  border-radius: 20px;
  background: #fff;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.07);
}

.info-about-card img {
  max-width: 170px;
  height: auto;
}

.info-about-card strong {
  font-family: var(--font-display);
  font-size: 1.35rem;
  letter-spacing: 0.03em;
}

.info-about-card span {
  color: #514a44;
  line-height: 1.55;
}

.info-faq {
  display: grid;
  gap: 0.7rem;
}

.legacy-contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, 340px);
  gap: 1.5rem;
}

.contact-intro-stack {
  display: grid;
  gap: 0.8rem;
}

.contact-intro-stack p {
  margin: 0;
  line-height: 1.7;
}

.contact-meta-list {
  display: grid;
  gap: 0.35rem;
  color: #35322f;
}

.contact-cta-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.contact-cta-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0.8rem 0.95rem;
  border-radius: 16px;
  border: 1px solid var(--site-line);
  background: var(--site-panel-soft);
  font-weight: 700;
}

.contact-tabs {
  margin-top: 1.25rem;
  border-bottom-color: var(--site-line);
}

.contact-tabs .nav-link {
  color: #403b36;
  border-top-left-radius: 14px;
  border-top-right-radius: 14px;
  font-weight: 700;
}

.contact-tabs .nav-link.active {
  color: var(--site-accent);
}

.contact-tab-content {
  padding-top: 1rem;
}

.faq-accordion .accordion-item,
.blog-card {
  border: 1px solid var(--site-line);
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 10px 28px rgba(17, 17, 17, 0.05);
}

.faq-accordion .accordion-item + .accordion-item {
  margin-top: 0.75rem;
}

.faq-accordion .accordion-button {
  font-weight: 700;
  background: #fff;
  color: #1d1b19;
}

.faq-accordion .accordion-button:not(.collapsed) {
  background: #fff7f7;
  color: var(--site-accent);
  box-shadow: none;
}

.faq-accordion .accordion-button:focus {
  box-shadow: none;
  border-color: rgba(179, 19, 27, 0.2);
}

.faq-accordion .accordion-body {
  color: #3e3833;
  line-height: 1.7;
}

.contact-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.contact-form-actions {
  display: flex;
  justify-content: flex-start;
}

.contact-sidebar-card {
  display: grid;
  align-content: start;
  gap: 1rem;
}

.contact-sidebar-card h3 {
  margin: 0;
}

.contact-map-frame {
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid var(--site-line);
  min-height: 280px;
}

.contact-map-frame iframe {
  width: 100%;
  height: 100%;
  min-height: 280px;
  border: 0;
}

.contact-quick-links {
  display: grid;
  gap: 0.65rem;
}

.contact-quick-links a {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0.8rem 0.95rem;
  border-radius: 14px;
  background: var(--site-panel-soft);
  border: 1px solid var(--site-line);
}

.blog-list-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.25rem;
}

.blog-card {
  display: grid;
  grid-template-rows: auto 1fr;
}

.blog-card-media {
  display: block;
  background: #e8e4dd;
}

.blog-card-media img {
  width: 100%;
  aspect-ratio: 16 / 8;
  object-fit: cover;
}

.blog-card-media-fallback {
  min-height: 220px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #141414, #404348);
  color: #fff;
  font-family: var(--font-display);
  font-size: 2rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.blog-card-body {
  display: grid;
  gap: 0.8rem;
  padding: 1rem 1.05rem 1.1rem;
}

.blog-card-meta {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  color: var(--site-muted);
  font-size: 0.82rem;
}

.blog-card-body h3 {
  margin: 0;
  font-size: 1.45rem;
  line-height: 1.2;
}

.blog-card-body p {
  margin: 0;
  color: #413c37;
  line-height: 1.7;
}

.blog-card-footer {
  display: flex;
  justify-content: flex-start;
}

@media (max-width: 1199px) {
  .header-shell {
    grid-template-columns: 220px minmax(0, 1fr);
  }

  .header-actions {
    grid-column: 1 / -1;
    justify-content: space-between;
  }

  .grid-products {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .browse-grid,
  .brand-directory-grid,
  .model-directory-grid,
  .blog-list-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  .desktop-only {
    display: none !important;
  }

  .mobile-only {
    display: inline-flex !important;
  }

  .legacy-topbar {
    display: none;
  }

  .legacy-brand-row {
    padding: 0.75rem 0 0.55rem;
    gap: 0.85rem;
  }

  .legacy-brand-side {
    justify-content: space-between;
  }

  .legacy-site-logo,
  .legacy-oem-strip {
    min-height: 0;
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
  }

  .legacy-site-logo img {
    width: 132px;
  }

  .legacy-header-tools,
  .legacy-nav-bar {
    display: none !important;
  }

  .site-dock {
    display: grid !important;
  }

  .page-main {
    padding-bottom: 7.5rem;
  }

  .legacy-mobile-actions {
    display: flex !important;
    gap: 0.55rem;
    margin-left: auto;
  }

  .legacy-search-row {
    padding-bottom: 0.65rem;
  }

  .legacy-search-shell {
    padding: 0;
    border-radius: 18px;
  }

  .legacy-search-shell input {
    height: 48px;
    padding-right: 3.75rem;
    border-radius: 14px;
  }

  .legacy-search-button {
    right: 0;
    width: 48px;
    height: 48px;
    border-radius: 0 14px 14px 0;
  }

  .legacy-mobile-shortcuts {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.55rem;
    padding-bottom: 0.8rem;
  }

  #mobileNav {
    width: min(92vw, 380px);
    border-left: 1px solid var(--site-line);
  }

  #mobileNav .offcanvas-header {
    border-bottom: 1px solid var(--site-line);
  }

  #mobileNav .offcanvas-body {
    background: #f6f3ee;
  }

  .catalog-product-card .product-actions-quick {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 0.55rem;
    align-items: stretch;
  }

  .catalog-product-card .product-actions-quick > .btn,
  .catalog-product-card .product-actions-quick > .btn-outline-dark,
  .catalog-product-card .product-actions-quick .inline-cart-form-quick {
    width: 100% !important;
    flex: 1 1 100% !important;
    max-width: 100%;
  }

  .catalog-product-card .product-actions-quick .inline-cart-grid {
    grid-template-columns: 1fr !important;
    gap: 0.55rem;
  }

  .catalog-product-card .product-actions-quick .btn {
    width: 100% !important;
  }

  .hero-grid,
  .legacy-home-hero-shell,
  .legacy-home-latest-shell,
  .catalog-layout,
  .bike-brand-directory-layout,
  .detail-shell,
  .detail-top-layout,
  .compat-grid,
  .checkout-grid,
  .auth-grid,
  .footer-grid,
  .legacy-home-info-grid,
  .browse-grid,
  .brand-directory-grid,
  .model-directory-grid,
  .legacy-contact-layout,
  .blog-list-grid,
  .page-header-inline {
    grid-template-columns: 1fr;
  }

  .detail-top-layout {
    grid-template-columns: 1fr;
  }

  .detail-docs-slot-mobile.mobile-only {
    display: block !important;
  }

  .detail-docs-grid {
    grid-template-columns: 1fr;
  }

  .detail-media-thumbs {
    grid-template-columns: repeat(auto-fill, minmax(68px, 1fr));
  }

  .detail-media-frame {
    min-height: 280px;
  }

  .product-lightbox {
    padding: 1rem;
  }

  .product-lightbox-close,
  .product-lightbox-nav {
    width: 2.7rem;
    height: 2.7rem;
  }

  .product-lightbox-prev {
    left: 0.5rem;
  }

  .product-lightbox-next {
    right: 0.5rem;
  }

  .legacy-home-hero-shell {
    gap: 1rem;
  }

  .legacy-home-finder-card-horizontal {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .legacy-home-finder-card-horizontal > .legacy-home-finder-form {
    grid-column: auto;
    grid-row: auto;
    grid-template-columns: 1fr;
  }

  .legacy-home-finder-card-horizontal .legacy-home-shortcuts {
    grid-column: auto;
    grid-row: auto;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-content: flex-start;
    max-width: none;
  }

  .legacy-home-finder-card-horizontal .legacy-home-shortcuts strong {
    text-align: left;
  }

  .legacy-home-rail {
    display: none;
  }

  .legacy-home-slide-copy {
    right: 1rem;
    left: 1rem;
    bottom: 1rem;
    max-width: none;
  }

  .legacy-home-feature-grid,
  .legacy-home-model-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .grid-products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .bike-model-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .cc-pill-nav {
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 0.25rem;
    scrollbar-width: thin;
  }

  .cc-pill-nav .browse-pill {
    min-height: 42px;
    padding: 0.58rem 0.82rem;
  }

  .catalog-sort-form {
    width: 100%;
    justify-content: space-between;
    margin-left: 0;
  }

  .field-grid,
    .contact-form-grid,
    .detail-specs,
    .detail-quick-links,
    .contact-cta-grid {
      grid-template-columns: 1fr;
    }

    .detail-buy-panel {
      grid-template-columns: 1fr 1fr;
    }

    .detail-buy-qty {
      grid-column: 1 / -1;
    }

    .detail-route-links {
      gap: 0.35rem 0.45rem;
    }

    .detail-route-links .browse-pill {
      padding: 0.36rem 0.62rem;
      font-size: 0.74rem;
      line-height: 1.05;
    }

  .checkout-helper-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .checkout-choice-help,
  .checkout-choice-check,
  .checkout-payonline-shell {
    margin-left: 0;
  }

  .checkout-payonline-grid {
    grid-template-columns: 1fr;
  }

  .checkout-wallet-row,
  .checkout-card-fields-grid {
    grid-template-columns: 1fr;
  }

  .site-footer {
    padding-bottom: 2rem;
  }

  .summary-card {
    position: static;
  }

  .coupon-field-row {
    grid-template-columns: 1fr;
  }

  .detail-mobile-bar {
    position: sticky;
    bottom: 0.75rem;
    z-index: 15;
    display: grid;
    gap: 0.75rem;
    padding: 0.9rem 1rem;
    border-radius: 18px;
    border: 1px solid rgba(21, 18, 16, 0.08);
    background: rgba(255, 253, 250, 0.98);
    box-shadow: 0 18px 30px rgba(22, 18, 13, 0.12);
  }

  .detail-mobile-price {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    align-items: center;
  }

  .detail-mobile-price strong {
    font-size: 1.15rem;
  }

  .detail-mobile-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.7rem;
  }

  .compat-links {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .compat-subgroups {
      gap: 0.45rem;
    }

  .catalog-layout .filters-card,
  .bike-brand-directory-layout .filters-card {
    position: static;
  }

  .catalog-layout {
    grid-template-columns: 1fr;
  }

  .catalog-layout > .catalog-results-panel {
    order: 1;
  }

  .catalog-layout > .catalog-sidebar-card {
    order: 2;
  }

  .catalog-mobile-actions {
    display: flex !important;
  }

  .catalog-hero-shell {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .catalog-hero-quick-filters .catalog-quick-toggle-form {
    margin-top: 0.65rem;
    padding-top: 0.65rem;
    flex-wrap: wrap;
  }

  .catalog-toggle-row-compact {
    flex: 1 1 min(100%, 250px);
  }

  .catalog-page-intro {
    max-width: none;
    justify-self: start;
    text-align: left;
  }

  .catalog-page-count {
    display: block;
    margin: 0.28rem 0 0;
    font-size: 0.38em;
    vertical-align: baseline;
  }

  .catalog-page-count-label {
      margin-left: 0.26rem;
  }

  .catalog-seo-heading {
    justify-self: start;
    text-align: left;
    max-width: none;
  }

  .catalog-brand-story {
    justify-items: start;
  }

  .catalog-hero-main-brand .catalog-brand-story-actions {
    justify-content: flex-start;
  }

  .catalog-summary-row .catalog-sort-form {
    margin-left: 0;
    width: 100%;
  }

  .catalog-relative-head {
    align-items: flex-start;
  }

  .catalog-relative-head .page-intro {
    display: none;
  }

  .catalog-relative-links {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 0.2rem;
  }

  .catalog-relative-links .browse-pill {
    padding: 0.68rem 0.9rem;
    box-shadow: none;
    white-space: nowrap;
  }

  .catalog-sidebar-mobile-head {
    display: flex;
  }

  .catalog-sidebar-card {
    display: none;
    position: fixed !important;
    left: 0;
    right: 0;
    bottom: 0;
    top: auto;
    z-index: 1200;
    width: 100vw;
    max-width: none;
    min-height: auto;
    max-height: 88vh;
    align-content: start;
    padding: 1rem 1rem calc(1.2rem + env(safe-area-inset-bottom, 0px));
    overflow-y: auto;
    transform: translateY(100%);
    transition: transform 0.24s ease;
    border-radius: 22px 22px 0 0;
    box-shadow: 0 -12px 34px rgba(0, 0, 0, 0.18);
  }

  body.catalog-sidebar-open .catalog-sidebar-card {
    display: grid;
    transform: translateY(0);
  }

  .catalog-mobile-overlay {
    position: fixed;
    inset: 0;
    z-index: 1190;
    display: none !important;
    background: transparent;
    pointer-events: none;
  }

  body.catalog-sidebar-open .catalog-mobile-overlay {
    display: none !important;
  }

  .catalog-filter-shell-head {
    align-items: center;
  }

  .catalog-filter-shell-head h2 {
    font-size: 1.2rem;
  }

  .catalog-filter-actions {
    position: sticky;
    bottom: -1rem;
    margin: 0 -1rem -1rem;
    padding: 0.9rem 1rem calc(0.95rem + env(safe-area-inset-bottom, 0px));
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(8px);
    border-top: 1px solid #ece5db;
  }
}

@media (min-width: 768px) {
  .detail-mobile-bar {
    display: none !important;
  }
}

@media (max-width: 767px) {
  .topbar-inner,
  .search-input-wrap,
  .cart-actions,
  .product-actions,
  .section-head,
  .summary-row,
  .header-actions,
  .directory-search,
  .browse-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .header-shell {
    grid-template-columns: 1fr;
  }

  .brand-lockup {
    min-height: auto;
  }

  .inline-cart-grid {
    grid-template-columns: 1fr;
  }

  .cart-flash-body,
  .cart-flash-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .cart-flash-toast {
    top: auto;
    right: 0.75rem;
    bottom: calc(5rem + env(safe-area-inset-bottom, 0px));
    width: calc(100vw - 1.5rem);
  }

  .grid-products {
    grid-template-columns: 1fr;
  }

  .compat-links {
      grid-template-columns: 1fr;
    }

    .compat-subgroups {
      gap: 0.42rem;
    }

    .compat-subgroup-summary,
    .compat-subgroup-menu-item {
      min-height: 34px;
      padding: 0.48rem 0.7rem;
    }

  .brand-directory-grid,
  .bike-model-grid,
  .catalog-guide-model-grid {
    grid-template-columns: 1fr;
  }

  .legacy-home-slide-copy {
    padding: 0.85rem 0.95rem;
  }

  .legacy-home-slide-copy strong {
    font-size: 1.3rem;
  }

  .legacy-home-feature-grid,
  .legacy-home-model-grid,
  .legacy-home-info-grid {
    grid-template-columns: 1fr;
  }

  .catalog-sort-form {
    flex-direction: column;
    align-items: stretch;
  }

  .catalog-price-values {
    grid-template-columns: 1fr;
  }

  .catalog-sort-form select {
    min-width: 0;
    width: 100%;
  }

  .catalog-price-filter-inline {
    min-width: 100%;
    grid-template-columns: 1fr;
    gap: 0.3rem;
  }

  .catalog-price-filter-inline .catalog-price-summary,
  .catalog-price-filter-inline .catalog-price-slider-shell,
  .catalog-price-filter-inline .catalog-price-bounds {
    grid-column: auto;
  }

  .catalog-price-filter-inline .catalog-price-summary {
    flex-wrap: wrap;
    white-space: normal;
  }

  .legacy-home-feature-tile {
    min-height: 190px;
  }

  .legacy-home-feature-tile span {
    font-size: 1.5rem;
  }

  .legacy-mobile-shortcuts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mobile-menu-quick-grid {
    grid-template-columns: 1fr;
  }

  .legacy-mobile-model-grid {
    grid-template-columns: 1fr;
  }

  .legacy-mobile-icon-link {
    width: 40px;
    height: 40px;
  }

  .filters-mobile-collapse {
    margin-top: 0.2rem;
  }

  .table-shell,
  .table-shell thead,
  .table-shell tbody,
  .table-shell tr,
  .table-shell td,
  .table-shell th {
    display: block;
    width: 100%;
  }

  .table-shell thead {
    display: none;
  }

  .table-shell tr {
    padding: 1rem 0;
    border-bottom: 1px solid var(--site-line);
  }

  .table-shell td {
    padding: 0.45rem 0;
    border: 0;
  }

  .table-shell td::before {
    content: attr(data-label);
    display: block;
    margin-bottom: 0.3rem;
    color: var(--site-muted);
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
  }

  .table-shell td:first-child::before {
    margin-bottom: 0.5rem;
  }

  .cart-actions-left,
  .cart-actions-right {
    width: 100%;
    align-items: stretch;
  }

  .cart-actions-right {
    margin-left: 0;
    flex-direction: column;
  }

  .cart-subtotal-row {
    min-width: 0;
    justify-content: space-between;
  }

  .cart-actions-row .btn {
    width: 100%;
  }
}
