/**
 * DealerCanada extended UI components
 * Brand colors: #00aed9 (blue), #79797c (gray), #ffffff (white), #fcb844 (orange)
 * Font: Inter (geometric sans)
 */
:root {
  --cv-primary: #00aed9;
  --cv-primary-hover: #0099c4;
  --cv-primary-dark: #0088b0;
  --cv-primary-light: rgba(0,174,217,0.12);
  --cv-gray: #79797c;
  --cv-gray-light: #d4d4d6;
  --cv-gray-bg: #F2F5F8;
  --cv-gold: #fcb844;
  --cv-gold-hover: #f5a623;
  --cv-text: #2d2d2d;
  --cv-text-light: #79797c;
  --cv-white: #ffffff;
  --cv-black: #000000;
  --cv-radius: 4px;
  --cv-radius-lg: 8px;
  --cv-radius-xl: 16px;
  --cv-radius-pill: 999px;
  --cv-green: #00a878;
  --cv-green-hover: #009168;
  --cv-font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --cv-shadow: 0 2px 8px rgba(0,0,0,0.08);
  --cv-shadow-lg: 0 4px 24px rgba(0,0,0,0.12);
  --cv-header-height: 64px;
  --cv-max-width: 1280px;
  --cv-teal: #007685;
  --cv-dark-blue: #1a2b48;
}

/* Override base */
body.cv-theme {
  margin: 0;
  padding: 0;
  font-family: var(--cv-font);
  font-size: 16px;
  line-height: 1.5;
  color: var(--cv-text);
  background: var(--cv-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
:root {
  --bg: var(--cv-white);
  --card: var(--cv-white);
  --text: var(--cv-text);
  --muted: var(--cv-gray);
  --line: var(--cv-gray-light);
  --primary: var(--cv-primary);
  --dark: var(--cv-text);
}

/* ========== HEADER ========== */
.cv-header {
  background: var(--cv-white);
  border-bottom: 1px solid var(--cv-gray-light);
  position: sticky;
  top: 0;
  z-index: 1000;
}
.cv-header-inner {
  max-width: var(--cv-max-width);
  margin: 0 auto;
  padding: 0 24px;
}
.cv-header-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 0;
  gap: 20px;
  min-height: 48px;
}
.cv-logo {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--cv-primary);
  text-decoration: none;
  letter-spacing: -0.02em;
}
.cv-logo:hover { color: var(--cv-primary-hover); }
.cv-logo img {
  height: 26px;
  max-height: 26px;
  width: auto;
  display: block;
  object-fit: contain;
}
.cv-logo-text {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--cv-primary);
  letter-spacing: -0.02em;
  text-transform: uppercase;
}

/* dealercanada logo: black bg, outlined text, red bar over "erca" */
.cv-logo-dealercanada {
  background: #000000;
  padding: 8px 14px 10px;
  border-radius: 4px;
  color: inherit;
}
.cv-logo-dealercanada:hover { color: inherit; opacity: 0.95; }
.cv-logo-dealercanada .cv-logo-inner {
  position: relative;
  display: inline-block;
}
.cv-logo-dealercanada .cv-logo-bar {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -6px;
  width: 2.2em;
  height: 3px;
  background: #D10000;
  border-radius: 1px;
}
.cv-logo-dealercanada .cv-logo-text {
  position: relative;
  display: inline-block;
  font-size: 1.05rem;
  font-weight: 600;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: transparent;
  -webkit-text-fill-color: transparent;
  -webkit-text-stroke: 1px #FFFFFF;
  paint-order: stroke fill;
  letter-spacing: -0.08em;
  text-transform: lowercase;
}

/* Main nav: Search Cars | Sell/Trade | Financing - left beside logo */
.cv-nav-main {
  display: none;
  align-items: center;
  gap: 4px;
  margin-left: 24px;
}
.cv-nav-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--cv-text);
  text-decoration: none;
  white-space: nowrap;
  border-radius: var(--cv-radius);
  transition: color 0.2s, background 0.2s;
}
.cv-nav-link.cv-nav-search {
  background: var(--cv-primary-light);
  color: var(--cv-primary);
}
.cv-nav-link.cv-nav-search:hover {
  background: rgba(0,174,217,0.2);
  color: var(--cv-primary-dark);
}
.cv-nav-link:not(.cv-nav-search):hover {
  color: var(--cv-primary);
}
.cv-nav-icon {
  font-size: 0.95rem;
  opacity: 0.85;
}
.cv-icon-search { font-size: 1rem; }

/* Right: Favorites + Account */
.cv-header-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.cv-cta-icon {
  padding: 6px 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius-lg);
  background: var(--cv-white);
  color: var(--cv-text);
  text-decoration: none;
  transition: border-color 0.2s, color 0.2s;
}
.cv-cta-icon:hover {
  border-color: var(--cv-primary);
  color: var(--cv-primary);
}
.cv-icon-heart { font-size: 1.1rem; line-height: 1; }

/* Account menu - light gray pill, compact */
.cv-account-wrap { position: relative; }
.cv-account-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  background: var(--cv-gray-bg);
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius-pill);
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--cv-text);
  cursor: pointer;
  font-family: inherit;
}
.cv-account-btn:hover {
  border-color: var(--cv-primary);
  color: var(--cv-primary);
}
.cv-account-icon { font-size: 1rem; }
.cv-account-menu-icon { font-size: 0.9rem; opacity: 0.7; }
.cv-account-dropdown {
  display: none;
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: 8px;
  min-width: 200px;
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius-lg);
  box-shadow: var(--cv-shadow-lg);
  z-index: 1001;
  padding: 8px 0;
}
.cv-account-dropdown.is-open { display: block; }
.cv-account-dropdown a {
  display: block;
  padding: 12px 20px;
  font-size: 0.95rem;
  color: var(--cv-text);
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
}
.cv-account-dropdown a:hover {
  background: var(--cv-gray-bg);
  color: var(--cv-primary);
}

.cv-nav-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  background: var(--cv-gray-bg);
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius-lg);
  font-size: 1.1rem;
  cursor: pointer;
  padding: 0;
  color: var(--cv-text);
  min-width: 36px;
  height: 36px;
}
.cv-nav-toggle:hover {
  border-color: var(--cv-primary);
  color: var(--cv-primary);
}

.cv-nav-mobile {
  display: none;
  flex-direction: column;
  padding: 16px 0;
  border-top: 1px solid var(--cv-gray-light);
  gap: 2px;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}
.cv-nav-mobile.is-open {
  max-height: 400px;
  overflow-y: auto;
}
.cv-nav-mobile a {
  padding: 14px 16px;
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--cv-text);
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
}
.cv-nav-mobile a:hover {
  background: var(--cv-gray-bg);
  color: var(--cv-primary);
}

@media (min-width: 1024px) {
  .cv-nav-main { display: flex !important; }
  .cv-nav-toggle { display: none !important; }
  .cv-nav-mobile { display: none !important; }
}
@media (max-width: 1023px) {
  .cv-nav-main { display: none !important; }
  .cv-nav-toggle { display: flex !important; }
  .cv-nav-mobile { display: flex !important; }
  .cv-account-wrap { display: none; }
  .cv-header-top { flex-wrap: wrap; }
}

/* Hide non-theme elements */
body.cv-theme .topbar,
body.cv-theme .credit-report-banner,
body.cv-theme .breadcrumbs { display: none !important; }
.cv-hidden { display: none !important; }

/* ========== HERO ========== */
.cv-hero {
  background: linear-gradient(135deg, var(--cv-primary) 0%, var(--cv-primary-dark) 100%);
  color: white;
  padding: 48px 24px 56px;
  text-align: center;
  position: relative;
}
.cv-hero-with-bg {
  background-size: cover;
  background-position: center;
  min-height: 420px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cv-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.3) 0%, rgba(0,0,0,0.5) 100%);
  pointer-events: none;
}
.cv-hero-content {
  position: relative;
  z-index: 1;
  width: 100%;
}
.cv-hero h1 {
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 800;
  margin: 0 0 12px;
  line-height: 1.1;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}
.cv-hero p {
  font-size: 1.25rem;
  margin: 0 0 28px;
  opacity: 0.95;
}
.cv-hero-search {
  max-width: 560px;
  margin: 0 auto 24px;
}
.cv-hero-search .cv-search-form {
  display: flex;
  align-items: stretch;
  background: white;
  border: 2px solid rgba(255,255,255,0.5);
  border-radius: 8px;
  overflow: hidden;
  max-width: 560px;
  margin: 0 auto;
}
.cv-search-icon {
  display: flex;
  align-items: center;
  padding: 0 16px;
  color: var(--cv-text-light);
}
.cv-hero-search .cv-search-form input {
  flex: 1;
  padding: 14px 16px;
  border: none;
  font-size: 1rem;
  font-family: inherit;
  color: var(--cv-text);
}
.cv-hero-search .cv-search-form input:focus { outline: none; }
.cv-hero-search .cv-search-form input::placeholder { color: var(--cv-text-light); }
.cv-search-go {
  padding: 14px 20px;
  border: none;
  background: var(--cv-teal);
  color: white;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
}
.cv-search-go:hover { background: #006674; }

/* Value Tracker Banner - dark blue */
.cv-value-banner {
  background: var(--cv-dark-blue);
  padding: 16px 24px;
}
.cv-value-banner-inner {
  max-width: var(--cv-max-width);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.cv-value-logo {
  display: flex;
  align-items: center;
  gap: 8px;
}
.cv-value-v {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--cv-primary);
  font-style: italic;
}
.cv-value-text {
  font-size: 1rem;
  font-weight: 700;
  color: white;
  letter-spacing: 0.02em;
}
.cv-value-tagline {
  font-size: 1rem;
  color: white;
  margin: 0;
  flex: 1;
  text-align: center;
}
.cv-value-btn {
  padding: 10px 24px;
  background: white;
  color: var(--cv-teal);
  font-size: 0.9rem;
  font-weight: 700;
  text-decoration: none;
  border: 2px solid var(--cv-primary);
  border-radius: 4px;
  letter-spacing: 0.02em;
  transition: background 0.2s, color 0.2s;
}
.cv-value-btn:hover {
  background: var(--cv-primary-light);
  color: var(--cv-teal);
}

/* ========== POPULAR VEHICLE STYLES ========== */
.cv-section {
  max-width: var(--cv-max-width);
  margin: 0 auto;
  padding: 40px 24px;
}
.cv-section-title {
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0 0 24px;
  color: var(--cv-dark-blue);
}
.cv-styles-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 12px;
}
.cv-style-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 20px 16px;
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius-lg);
  text-decoration: none;
  color: var(--cv-text);
  font-weight: 600;
  font-size: 0.95rem;
  transition: border-color 0.2s, box-shadow 0.2s, color 0.2s;
}
.cv-style-card:hover {
  border-color: var(--cv-primary);
  box-shadow: var(--cv-shadow);
  color: var(--cv-primary);
}

/* Style cards with vehicle images - 2x6 grid */
.cv-styles-with-images {
  grid-template-columns: repeat(6, 1fr);
  gap: 16px;
}
.cv-style-with-img {
  flex-direction: column;
  padding: 16px;
  min-height: 140px;
}
.cv-style-img {
  flex: 1;
  min-height: 80px;
  background: var(--cv-gray-bg);
  border-radius: 8px;
  margin-bottom: 12px;
  background-size: 60%;
  background-repeat: no-repeat;
  background-position: center;
}
.cv-style-suv { background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 60"><rect x="15" y="35" width="70" height="15" rx="3" fill="%23007685"/><rect x="20" y="25" width="60" height="15" rx="2" fill="%23007685"/><circle cx="30" cy="50" r="6" fill="%23333"/><circle cx="70" cy="50" r="6" fill="%23333"/></svg>'); }
.cv-style-sedan { background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 60"><rect x="10" y="38" width="80" height="12" rx="2" fill="%23007685"/><rect x="25" y="28" width="50" height="15" rx="2" fill="%23007685"/><circle cx="28" cy="50" r="5" fill="%23333"/><circle cx="72" cy="50" r="5" fill="%23333"/></svg>'); }
.cv-style-truck { background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 60"><rect x="5" y="35" width="50" height="18" rx="2" fill="%23007685"/><rect x="55" y="30" width="40" height="23" rx="2" fill="%23007685"/><circle cx="25" cy="53" r="6" fill="%23333"/><circle cx="75" cy="53" r="6" fill="%23333"/></svg>'); }
.cv-style-ev { background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 60"><rect x="15" y="35" width="70" height="15" rx="3" fill="%23007685"/><rect x="25" y="22" width="50" height="18" rx="2" fill="%23007685"/><circle cx="35" cy="50" r="5" fill="%23333"/><circle cx="65" cy="50" r="5" fill="%23333"/><circle cx="50" cy="28" r="4" fill="%2300a878"/></svg>'); }
.cv-style-hybrid { background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 60"><rect x="12" y="36" width="76" height="14" rx="2" fill="%23007685"/><rect x="22" y="26" width="56" height="14" rx="2" fill="%23007685"/><circle cx="32" cy="50" r="5" fill="%23333"/><circle cx="68" cy="50" r="5" fill="%23333"/><text x="50" y="22" font-size="10" fill="%2300a878" text-anchor="middle">H</text></svg>'); }
.cv-style-coupe { background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 60"><rect x="15" y="38" width="70" height="12" rx="2" fill="%23007685"/><path d="M25 38 L35 22 L65 22 L75 38 Z" fill="%23007685"/><circle cx="30" cy="50" r="5" fill="%23333"/><circle cx="70" cy="50" r="5" fill="%23333"/></svg>'); }
.cv-style-hatchback { background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 60"><rect x="12" y="36" width="76" height="14" rx="2" fill="%23007685"/><rect x="22" y="24" width="56" height="16" rx="2" fill="%23007685"/><rect x="55" y="18" width="18" height="22" rx="1" fill="%23007685"/><circle cx="32" cy="50" r="5" fill="%23333"/><circle cx="68" cy="50" r="5" fill="%23333"/></svg>'); }
.cv-style-wagon { background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 60"><rect x="10" y="36" width="80" height="14" rx="2" fill="%23007685"/><rect x="18" y="24" width="64" height="16" rx="2" fill="%23007685"/><rect x="50" y="18" width="28" height="22" rx="1" fill="%23007685"/><circle cx="28" cy="50" r="5" fill="%23333"/><circle cx="72" cy="50" r="5" fill="%23333"/></svg>'); }
.cv-style-convertible { background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 60"><rect x="15" y="38" width="70" height="12" rx="2" fill="%23007685"/><path d="M28 38 L38 18 L62 18 L72 38 Z" fill="%23007685" stroke="%23007685"/><circle cx="30" cy="50" r="5" fill="%23333"/><circle cx="70" cy="50" r="5" fill="%23333"/></svg>'); }
.cv-style-minivan { background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 60"><rect x="8" y="34" width="84" height="18" rx="2" fill="%23007685"/><rect x="15" y="22" width="70" height="16" rx="2" fill="%23007685"/><circle cx="28" cy="52" r="6" fill="%23333"/><circle cx="72" cy="52" r="6" fill="%23333"/></svg>'); }
.cv-style-plugin { background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 60"><rect x="12" y="36" width="76" height="14" rx="2" fill="%23007685"/><rect x="22" y="24" width="56" height="16" rx="2" fill="%23007685"/><circle cx="32" cy="50" r="5" fill="%23333"/><circle cx="68" cy="50" r="5" fill="%23333"/><circle cx="50" cy="20" r="5" fill="%2300a878"/></svg>'); }
.cv-style-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--cv-text);
}
.cv-style-shop-all {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cv-teal);
  font-weight: 700;
}
.cv-style-shop-all:hover { color: var(--cv-primary); }
@media (max-width: 900px) {
  .cv-styles-with-images { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 600px) {
  .cv-styles-with-images { grid-template-columns: repeat(2, 1fr); }
}

/* Primary CTA Cards - Finance + Sell (large with images) */
.cv-cta-cards-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.cv-cta-card {
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: 12px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  display: block;
  transition: box-shadow 0.2s, border-color 0.2s;
}
.cv-cta-card:hover {
  box-shadow: var(--cv-shadow-lg);
  border-color: var(--cv-primary);
}
.cv-cta-card-img {
  aspect-ratio: 16/9;
  background: var(--cv-gray-bg);
  background-size: cover;
  background-position: center;
}
.cv-cta-finance-img { background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 400 225" fill="%23e5e7eb"><rect width="400" height="225" fill="%23f3f4f6"/><rect x="80" y="60" width="240" height="140" rx="8" fill="%23d1d5db"/><rect x="120" y="100" width="160" height="80" rx="4" fill="%23e5e7eb"/><circle cx="200" cy="140" r="20" fill="%2300aed9"/></svg>'); }
.cv-cta-sell-img { background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 400 225" fill="%23e5e7eb"><rect width="400" height="225" fill="%23f3f4f6"/><rect x="60" y="80" width="280" height="80" rx="4" fill="%23d1d5db"/><circle cx="200" cy="120" r="25" fill="%2300aed9"/></svg>'); }
.cv-cta-card-body {
  padding: 24px;
}
.cv-cta-card h3 {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--cv-dark-blue);
  margin: 0 0 8px;
}
.cv-cta-card p {
  font-size: 0.95rem;
  color: var(--cv-text-light);
  margin: 0 0 20px;
  line-height: 1.5;
}
.cv-cta-card-btn {
  display: block;
  padding: 14px 24px;
  background: var(--cv-teal);
  color: white;
  font-size: 0.95rem;
  font-weight: 700;
  text-align: center;
  border-radius: 4px;
  letter-spacing: 0.02em;
  transition: background 0.2s;
}
.cv-cta-card:hover .cv-cta-card-btn { background: #006674; }
@media (max-width: 768px) {
  .cv-cta-cards-grid { grid-template-columns: 1fr; }
}

/* Price Drop Banner - light green gradient */
.cv-price-drop-banner {
  background: linear-gradient(135deg, #d1fae5 0%, #f0fdf4 50%, white 100%);
  padding: 32px 24px;
  border-top: 1px solid #a7f3d0;
  border-bottom: 1px solid #a7f3d0;
}
.cv-price-drop-inner {
  max-width: var(--cv-max-width);
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}
.cv-price-drop-icon {
  width: 64px;
  height: 64px;
  background: var(--cv-green);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  flex-shrink: 0;
}
.cv-price-drop-content { flex: 1; min-width: 200px; }
.cv-price-drop-text {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--cv-dark-blue);
  margin: 0 0 12px;
}
.cv-price-drop-btn {
  display: inline-block;
  padding: 12px 24px;
  background: white;
  color: var(--cv-teal);
  font-size: 0.9rem;
  font-weight: 700;
  text-decoration: none;
  border: 2px solid var(--cv-teal);
  border-radius: 4px;
  letter-spacing: 0.02em;
  transition: background 0.2s, color 0.2s;
}
.cv-price-drop-btn:hover {
  background: var(--cv-teal);
  color: white;
}
.cv-price-drop-car {
  width: 120px;
  height: 80px;
  background: var(--cv-gray-bg);
  border-radius: 8px;
  flex-shrink: 0;
}

/* Affordable Cars - with icons */
.cv-affordable-with-icons {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.cv-affordable-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 24px 16px;
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: 12px;
  text-decoration: none;
  color: var(--cv-dark-blue);
  font-weight: 600;
  font-size: 0.95rem;
  text-align: center;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.cv-affordable-card:hover {
  border-color: var(--cv-teal);
  box-shadow: var(--cv-shadow);
  color: var(--cv-teal);
}
.cv-affordable-icon {
  font-size: 2rem;
  line-height: 1;
}
@media (max-width: 768px) {
  .cv-affordable-with-icons { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .cv-affordable-with-icons { grid-template-columns: 1fr; }
}

/* Value Tracker + Insurance - split cards (colored top, white bottom) */
.cv-home-cards-split {
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.cv-home-card-split {
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: 12px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  display: block;
  transition: box-shadow 0.2s, border-color 0.2s;
}
.cv-home-card-split:hover {
  box-shadow: var(--cv-shadow-lg);
  border-color: var(--cv-primary);
}
.cv-home-card-top {
  height: 120px;
  background: var(--cv-dark-blue);
  display: flex;
  align-items: center;
  justify-content: center;
}
.cv-home-value-top::before {
  content: 'V';
  font-size: 3rem;
  font-weight: 800;
  color: var(--cv-primary);
  font-style: italic;
}
.cv-home-insurance-top {
  background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%);
  color: white;
}
.cv-home-insurance-top::before {
  content: '🚗';
  font-size: 2.5rem;
}
.cv-home-card-bottom {
  padding: 24px;
}
.cv-home-card-split h3 {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--cv-dark-blue);
  margin: 0 0 12px;
}
.cv-home-card-split p {
  font-size: 0.95rem;
  color: var(--cv-text-light);
  margin: 0 0 16px;
  line-height: 1.5;
}
.cv-home-card-split .cv-home-card-cta {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--cv-teal);
  letter-spacing: 0.02em;
}
@media (max-width: 768px) {
  .cv-home-cards-split { grid-template-columns: 1fr; }
}

/* ========== AFFORDABLE CARS ========== */
.cv-affordable {
  background: var(--cv-gray-bg);
  padding: 32px 24px;
}
.cv-affordable-title {
  font-size: 1.25rem;
  font-weight: 700;
  margin: 0 0 20px;
  text-align: center;
  color: var(--cv-text);
}
.cv-affordable-inner {
  max-width: var(--cv-max-width);
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
}
.cv-affordable a {
  padding: 12px 20px;
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius-lg);
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--cv-text);
  text-decoration: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.cv-affordable a:hover {
  border-color: var(--cv-primary);
  box-shadow: var(--cv-shadow);
  color: var(--cv-primary);
}

/* ========== VALUE TRACKER / TRUST CARDS ========== */
.cv-trust-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
  margin-top: 32px;
}
.cv-trust-card {
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius-lg);
  padding: 24px;
  transition: box-shadow 0.2s;
}
.cv-trust-card:hover { box-shadow: var(--cv-shadow); }
.cv-trust-link {
  text-decoration: none;
  color: inherit;
  display: block;
}
.cv-trust-link:hover { border-color: var(--cv-primary); }
.cv-trust-link h3 { color: var(--cv-primary); }
.cv-trust-card h3 {
  font-size: 1.1rem;
  margin: 0 0 8px;
  color: var(--cv-text);
}
.cv-trust-card p {
  margin: 0 0 12px;
  font-size: 0.9rem;
  color: var(--cv-text-light);
  line-height: 1.5;
}
.cv-trust-card a {
  font-weight: 600;
  color: var(--cv-primary);
  text-decoration: none;
}
.cv-trust-card a:hover { text-decoration: underline; }

/* ========== SHOP POPULAR MODELS ========== */
.cv-models-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.cv-model-pill {
  padding: 10px 18px;
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: 24px;
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--cv-text);
  text-decoration: none;
  transition: border-color 0.2s, color 0.2s;
}
.cv-model-pill:hover {
  border-color: var(--cv-primary);
  color: var(--cv-primary);
}
.cv-model-pill-more { font-weight: 600; color: var(--cv-primary); }
.cv-model-pill-more:hover { background: var(--cv-primary-light); }
.cv-section-subtitle {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--cv-text-light);
  margin: -8px 0 16px;
}

/* Value Tracker + Insurance cards */
.cv-home-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 24px;
}
.cv-home-card {
  padding: 28px 24px;
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: 12px;
  text-decoration: none;
  color: inherit;
  display: block;
  transition: box-shadow 0.2s, border-color 0.2s;
}
.cv-home-card:hover {
  box-shadow: var(--cv-shadow);
  border-color: var(--cv-primary);
}
.cv-home-card h3 {
  font-size: 1.25rem;
  font-weight: 700;
  color: #1a2b48;
  margin: 0 0 12px;
}
.cv-home-card p {
  font-size: 0.95rem;
  color: var(--cv-text-light);
  margin: 0 0 16px;
  line-height: 1.5;
}
.cv-home-card-cta {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--cv-primary);
}
.cv-home-card:hover .cv-home-card-cta { text-decoration: underline; }
.cv-browse-section { padding-top: 0; }

/* ========== VEHICLE CARDS ========== */
.cv-vehicle-card {
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius-lg);
  overflow: hidden;
  transition: box-shadow 0.2s, border-color 0.2s;
}
.cv-vehicle-card:hover {
  box-shadow: var(--cv-shadow-lg);
  border-color: var(--cv-primary);
}
.cv-vehicle-card a { text-decoration: none; color: inherit; display: block; }
.cv-vehicle-thumb {
  aspect-ratio: 16/10;
  background: var(--cv-gray-bg);
  overflow: hidden;
}
.cv-vehicle-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.cv-vehicle-body {
  padding: 16px;
}
.cv-vehicle-title {
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 8px;
  color: var(--cv-text);
  line-height: 1.3;
}
.cv-vehicle-meta {
  font-size: 0.85rem;
  color: var(--cv-text-light);
  margin: 0 0 8px;
}
.cv-vehicle-price {
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--cv-primary);
  margin: 0;
}
.cv-vehicle-payment {
  font-size: 0.85rem;
  color: var(--cv-text-light);
  margin: 4px 0 0;
}

/* Archive grid override */
body.cv-theme .archive-card {
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius-lg);
  overflow: hidden;
}
body.cv-theme .archive-card:hover {
  box-shadow: var(--cv-shadow-lg);
  border-color: var(--cv-primary);
}
body.cv-theme .archive-thumb { border-radius: 0; }
body.cv-theme .archive-body { padding: 16px; }
body.cv-theme .archive-price { color: var(--cv-primary); font-weight: 800; }
body.cv-theme .archive-title { font-weight: 700; }

/* ========== FOOTER ========== */
.cv-footer {
  background: #1B365D;
  color: white;
  padding: 0;
  margin-top: 48px;
}
.cv-footer-inner {
  max-width: var(--cv-max-width);
  margin: 0 auto;
  padding: 0 24px;
}
.cv-footer-back-top {
  display: block;
  text-align: center;
  padding: 14px 0;
  color: rgba(255,255,255,0.95);
  text-decoration: none;
  font-size: 0.9rem;
  background: #244265;
  margin: 0 -24px 0;
  transition: background 0.2s;
}
.cv-footer-back-top:hover {
  background: #2d4f75;
  color: white;
}
.cv-footer-browse {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 32px 24px;
  padding: 40px 0 24px;
  max-width: 1200px;
  margin: 0 auto;
}
.cv-footer-section {
  margin: 0;
}
.cv-footer-heading {
  font-size: 0.85rem;
  font-weight: 700;
  margin: 0 0 14px;
  color: white;
  letter-spacing: 0.02em;
}
.cv-footer-links {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.cv-footer-links a {
  color: rgba(255,255,255,0.85);
  text-decoration: none;
  font-size: 0.9rem;
  transition: color 0.2s, text-decoration 0.2s;
}
.cv-footer-links a:hover {
  color: white;
  text-decoration: underline;
}
.cv-footer-support-icon {
  display: inline-block;
  margin-right: 4px;
  font-size: 0.95em;
  opacity: 0.9;
}
.cv-footer-other {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.15);
}
.cv-footer-other-heading {
  font-size: 0.85rem;
  font-weight: 700;
  margin: 0 0 10px;
  color: white;
  letter-spacing: 0.02em;
}
.cv-footer-other a {
  display: block;
  color: rgba(255,255,255,0.85);
  text-decoration: none;
  font-size: 0.9rem;
  margin-bottom: 4px;
}
.cv-footer-other a:hover {
  color: white;
  text-decoration: underline;
}
.cv-footer-secondary {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 4px 8px;
  padding: 16px 0;
  border-top: 1px solid rgba(255,255,255,0.1);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.02em;
}
.cv-footer-secondary a {
  color: rgba(255,255,255,0.9);
  text-decoration: none;
}
.cv-footer-secondary a:hover {
  color: white;
  text-decoration: underline;
}
.cv-footer-sep {
  color: rgba(255,255,255,0.4);
  user-select: none;
}
.cv-footer-social {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 16px 0;
}
.cv-footer-social-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,0.15);
  color: white;
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
}
.cv-footer-social-icon:hover {
  background: rgba(255,255,255,0.25);
  color: white;
}
.cv-footer-social-icon svg {
  flex-shrink: 0;
}
.cv-footer-legal {
  padding: 20px 0 16px;
  border-top: 1px solid rgba(255,255,255,0.1);
  font-size: 0.8rem;
  color: rgba(255,255,255,0.6);
  text-align: center;
}
.cv-footer-legal-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 4px 8px;
  margin-top: 12px;
}
.cv-footer-legal-links a {
  color: rgba(255,255,255,0.8);
  text-decoration: none;
  white-space: nowrap;
}
.cv-footer-legal-links a:hover {
  color: white;
  text-decoration: underline;
}
.cv-footer-copyright {
  margin: 0;
  font-size: 0.8rem;
  color: rgba(255,255,255,0.7);
}
.cv-footer-address {
  margin: 12px 0 0;
  font-size: 0.75rem;
  color: rgba(255,255,255,0.5);
  text-align: center;
}
@media (max-width: 1024px) {
  .cv-footer-browse { grid-template-columns: repeat(2, 1fr); gap: 28px 20px; padding: 32px 0 24px; }
}
@media (max-width: 768px) {
  .cv-footer-browse { grid-template-columns: 1fr; gap: 24px; padding: 24px 0; }
  .cv-footer-secondary { font-size: 0.75rem; gap: 4px 6px; }
  .cv-footer-legal-links { font-size: 0.75rem; }
}

/* Replace default footer */
body.cv-theme .footer {
  background: #1B365D;
  color: white;
  border-top: none;
}
body.cv-theme .footer-main { background: transparent; }
body.cv-theme .footer a { color: rgba(255,255,255,0.9); }
body.cv-theme .footer a:hover { color: white; }

/* ========== BUTTONS ========== */
body.cv-theme .btn.primary,
body.cv-theme .btn.blue {
  background: var(--cv-primary);
  border-color: var(--cv-primary);
}
body.cv-theme .btn.primary:hover,
body.cv-theme .btn.blue:hover {
  background: var(--cv-primary-hover);
  border-color: var(--cv-primary-hover);
}

/* ========== PAGE BACKGROUNDS ========== */
body.cv-theme { background: var(--cv-white); }
main.container { max-width: var(--cv-max-width); }
body.cv-theme main.page-home { padding: 0; max-width: none; }
body.cv-theme main.page-vehicles { background: var(--cv-gray-bg); padding: 0; max-width: none; min-height: 100vh; }
body.cv-theme main.page-vehicle { padding: 0; max-width: none; overflow-x: hidden; background: var(--cv-white); }
body.cv-theme .page-vehicles .catalog-layout { background: transparent; }
body.cv-theme .page-vehicles .filters-amazon .filters-form {
  border-color: var(--cv-gray-light);
  border-radius: var(--cv-radius-lg);
}
body.cv-theme .page-vehicles .filter-apply-btn,
body.cv-theme .filters-amazon .filter-apply-btn {
  background: var(--cv-primary);
  border-color: var(--cv-primary);
}
body.cv-theme .page-vehicles .filter-apply-btn:hover,
body.cv-theme .filters-amazon .filter-apply-btn:hover {
  background: var(--cv-primary-hover);
  border-color: var(--cv-primary-hover);
}
body.cv-theme .filter-price-link.is-active,
body.cv-theme .filters-amazon .filter-price-link.is-active {
  color: var(--cv-primary);
}
body.cv-theme .page-vehicles h1 {
  font-family: var(--cv-font);
  font-weight: 700;
  color: var(--cv-text);
}

/* ========== PREAPPROVAL / HOMEPAGE ========== */
body.cv-theme .preapproval-intro-wrap {
  text-align: center;
  padding: 24px 24px 8px;
}
body.cv-theme .preapproval-intro {
  font-size: 1.1rem;
  color: var(--cv-text-light);
  margin: 0;
}
body.cv-theme .preapproval-pill-wrap {
  text-align: center;
  padding: 0 24px 32px;
}
body.cv-theme .preapproval-pill {
  background: var(--cv-gold);
  color: var(--cv-black);
  border: none;
  padding: 14px 28px;
  font-size: 1rem;
  font-weight: 700;
  border-radius: var(--cv-radius-lg);
  cursor: pointer;
  font-family: inherit;
  transition: background 0.2s;
}
body.cv-theme .preapproval-pill:hover {
  background: var(--cv-gold-hover);
}
body.cv-theme .archive-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px;
}

/* ========== FINANCING PAGE ========== */
body.page-finance-body main.container,
body.cm-theme main.page-finance { padding: 0; max-width: none; width: 100%; }
.cv-finance-page {
  background: var(--cv-white);
  font-family: var(--cv-font);
}
.cv-finance-hero {
  background: linear-gradient(135deg, #1a2b48 0%, #2d4a6f 100%);
  color: white;
  padding: 48px 24px 56px;
  text-align: center;
}
.cv-finance-hero-inner {
  max-width: var(--cv-max-width);
  margin: 0 auto;
}
.cv-finance-hero-title {
  font-size: 1.75rem;
  font-weight: 800;
  margin: 0 0 24px;
  letter-spacing: -0.02em;
}
.cv-finance-hero-payment {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
}
.cv-finance-payment-label {
  font-size: 0.9rem;
  font-weight: 500;
  opacity: 0.9;
}
.cv-finance-payment-amount {
  font-size: 2.5rem;
  font-weight: 800;
  letter-spacing: -0.02em;
}
.cv-finance-hero-disclaimer {
  font-size: 0.8rem;
  opacity: 0.8;
  margin: 0;
}
.cv-finance-cta-section {
  text-align: center;
  padding: 48px 24px;
  max-width: var(--cv-max-width);
  margin: 0 auto;
}
.cv-finance-section-title {
  font-size: 1.5rem;
  font-weight: 800;
  color: #1a2b48;
  margin: 0 0 16px;
  letter-spacing: 0.02em;
}
.cv-finance-section-desc {
  font-size: 1.1rem;
  color: var(--cv-text-light);
  margin: 0 0 24px;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}
.cv-finance-cta-btn {
  display: inline-block;
  padding: 14px 32px;
  background: var(--cv-primary);
  color: white;
  font-size: 1rem;
  font-weight: 700;
  border-radius: var(--cv-radius-pill);
  text-decoration: none;
  font-family: inherit;
  transition: background 0.2s;
}
.cv-finance-cta-btn:hover {
  background: var(--cv-primary-hover);
  color: white;
}
.cv-finance-cta-btn-large {
  padding: 18px 40px;
  font-size: 1.1rem;
}
.cv-finance-value-props {
  background: var(--cv-gray-bg);
  padding: 48px 24px;
}
.cv-finance-value-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 24px;
  max-width: var(--cv-max-width);
  margin: 0 auto 32px;
}
.cv-finance-value-card {
  background: var(--cv-white);
  padding: 28px 24px;
  border-radius: 12px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
  border: 1px solid var(--cv-gray-light);
}
.cv-finance-value-card h3 {
  font-size: 1.1rem;
  font-weight: 700;
  color: #1a2b48;
  margin: 0 0 12px;
}
.cv-finance-value-card p {
  font-size: 0.95rem;
  color: var(--cv-text-light);
  margin: 0;
  line-height: 1.5;
}
.cv-finance-shop-link {
  display: block;
  text-align: center;
  font-size: 1rem;
  font-weight: 600;
  color: var(--cv-primary);
  text-decoration: none;
  max-width: var(--cv-max-width);
  margin: 0 auto;
}
.cv-finance-shop-link:hover { text-decoration: underline; }
.cv-finance-steps {
  padding: 56px 24px;
  max-width: var(--cv-max-width);
  margin: 0 auto;
}
.cv-finance-steps-inner {
  text-align: center;
}
.cv-finance-steps-header {
  margin-bottom: 40px;
}
.cv-finance-steps-header h2 {
  font-size: 1.75rem;
  font-weight: 800;
  color: #1a2b48;
  margin: 0 0 20px;
}
.cv-finance-steps-payment {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  margin-bottom: 8px;
}
.cv-finance-steps-label { font-size: 0.9rem; font-weight: 500; color: var(--cv-text-light); }
.cv-finance-steps-amount { font-size: 2rem; font-weight: 800; color: #1a2b48; }
.cv-finance-steps-disclaimer { font-size: 0.8rem; color: var(--cv-text-light); margin: 0; }
.cv-finance-steps-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 32px;
  margin-bottom: 40px;
  text-align: left;
}
.cv-finance-step {
  position: relative;
  padding: 24px;
  background: var(--cv-gray-bg);
  border-radius: 12px;
  border: 1px solid var(--cv-gray-light);
}
.cv-finance-step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: var(--cv-primary);
  color: white;
  font-size: 1.1rem;
  font-weight: 800;
  border-radius: 50%;
  margin-bottom: 16px;
}
.cv-finance-step h3 {
  font-size: 1.1rem;
  font-weight: 700;
  color: #1a2b48;
  margin: 0 0 8px;
}
.cv-finance-step p {
  font-size: 0.95rem;
  color: var(--cv-text-light);
  margin: 0;
  line-height: 1.5;
}
.cv-finance-reviews {
  background: var(--cv-gray-bg);
  padding: 56px 24px;
}
.cv-finance-reviews-title {
  font-size: 1.5rem;
  font-weight: 800;
  color: #1a2b48;
  text-align: center;
  margin: 0 0 32px;
}
.cv-finance-reviews-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 24px;
  max-width: var(--cv-max-width);
  margin: 0 auto;
}
.cv-finance-review {
  background: var(--cv-white);
  padding: 28px 24px;
  border-radius: 12px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
  border: 1px solid var(--cv-gray-light);
  margin: 0;
}
.cv-finance-review p {
  font-size: 0.95rem;
  color: var(--cv-text);
  line-height: 1.6;
  margin: 0 0 16px;
  font-style: italic;
}
.cv-finance-review footer {
  font-size: 0.9rem;
  font-weight: 600;
  color: #1a2b48;
}
.cv-finance-review footer span { font-weight: 400; color: var(--cv-text-light); }
.cv-finance-review cite {
  display: block;
  font-size: 0.8rem;
  color: var(--cv-text-light);
  font-style: normal;
  margin-top: 4px;
}
.cv-finance-apply-cta {
  text-align: center;
  padding: 56px 24px;
  max-width: var(--cv-max-width);
  margin: 0 auto;
}
.cv-finance-apply-cta h2 {
  font-size: 1.75rem;
  font-weight: 800;
  color: #1a2b48;
  margin: 0 0 12px;
}
.cv-finance-apply-cta p {
  font-size: 1.1rem;
  color: var(--cv-text-light);
  margin: 0 0 24px;
}
.cv-finance-legal {
  font-size: 0.8rem;
  color: var(--cv-text-light);
  margin: 24px 0 0 !important;
  max-width: 560px;
  margin-left: auto !important;
  margin-right: auto !important;
}
.cv-finance-help {
  text-align: center;
  padding: 48px 24px 64px;
  background: var(--cv-gray-bg);
}
.cv-finance-help h2 {
  font-size: 1.25rem;
  font-weight: 700;
  color: #1a2b48;
  margin: 0 0 8px;
}
.cv-finance-help p {
  font-size: 0.95rem;
  color: var(--cv-text-light);
  margin: 0 0 16px;
}
.cv-finance-help-link {
  font-size: 1rem;
  font-weight: 600;
  color: var(--cv-primary);
  text-decoration: none;
}
.cv-finance-help-link:hover { text-decoration: underline; }
@media (max-width: 768px) {
  .cv-finance-hero { padding: 32px 16px 40px; }
  .cv-finance-hero-title { font-size: 1.4rem; }
  .cv-finance-payment-amount { font-size: 2rem; }
  .cv-finance-cta-section { padding: 32px 16px; }
  .cv-finance-value-props { padding: 32px 16px; }
  .cv-finance-value-grid { grid-template-columns: 1fr; }
  .cv-finance-steps { padding: 40px 16px; }
  .cv-finance-steps-header h2 { font-size: 1.4rem; }
  .cv-finance-reviews { padding: 40px 16px; }
  .cv-finance-reviews-grid { grid-template-columns: 1fr; }
  .cv-finance-apply-cta { padding: 40px 16px; }
  .cv-finance-apply-cta h2 { font-size: 1.4rem; }
}

/* ========== CM-FINANCE PAGE (Reference layout: hero 2-col, value props, steps, reviews, final CTA) ========== */
.cm-finance-page {
  background: var(--cv-white);
  font-family: var(--cv-font);
}
.cm-finance-hero {
  position: relative;
  background: var(--cv-white);
  min-height: 420px;
  display: flex;
  align-items: center;
  overflow: hidden;
}
.cm-finance-hero-bg {
  position: absolute;
  top: 0;
  right: 0;
  width: 55%;
  height: 100%;
  background: linear-gradient(135deg, #002D5B 0%, #1a4a7a 100%);
  clip-path: polygon(30% 0, 100% 0, 100% 100%, 0 100%);
  z-index: 0;
}
.cm-finance-hero-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 48px;
  max-width: var(--cv-max-width);
  margin: 0 auto;
  padding: 48px 24px 56px;
  width: 100%;
}
.cm-finance-hero-left {
  display: flex;
  justify-content: center;
  align-items: center;
}
.cm-finance-car-wrap {
  position: relative;
  max-width: 520px;
}
.cm-finance-car-img {
  width: 100%;
  height: auto;
  display: block;
  filter: drop-shadow(0 8px 24px rgba(0,0,0,0.15));
}
.cm-finance-badge {
  position: absolute;
  top: 12%;
  right: 8%;
  left: auto;
  background: rgba(0, 45, 91, 0.85);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.5);
  border-radius: 8px;
  padding: 12px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  color: var(--cv-white);
  box-shadow: 0 4px 16px rgba(0,0,0,0.2);
  max-width: 45%;
}
.cm-finance-badge-text {
  font-size: 0.8rem;
  font-weight: 500;
  opacity: 0.95;
}
.cm-finance-badge-amount {
  font-size: 1.5rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  display: flex;
  align-items: center;
  gap: 8px;
}
.cm-finance-badge-amount svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}
.cm-finance-hero-right {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.cm-finance-cta-card {
  background: var(--cv-white);
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.12);
  padding: 40px 36px;
  max-width: 400px;
  border: none;
}
.cm-finance-cta-title {
  font-size: 1.5rem;
  font-weight: 800;
  color: #002D5B;
  margin: 0 0 16px;
  letter-spacing: 0.02em;
}
.cm-finance-cta-desc {
  font-size: 1.05rem;
  color: #374151;
  margin: 0 0 24px;
  line-height: 1.5;
}
.cm-finance-cta-btn {
  display: block;
  width: 100%;
  padding: 14px 24px;
  background: #116ACC;
  color: var(--cv-white);
  font-size: 1rem;
  font-weight: 700;
  border-radius: var(--cv-radius-pill);
  text-decoration: none;
  text-align: center;
  font-family: inherit;
  transition: background 0.2s;
  border: none;
  cursor: pointer;
}
.cm-finance-cta-btn:hover {
  background: #0d5ab5;
  color: var(--cv-white);
}
.cm-finance-cta-btn-large {
  padding: 18px 40px;
  font-size: 1.1rem;
  width: auto;
  display: inline-block;
}
.cm-finance-value {
  padding: 56px 24px 48px;
  background: var(--cv-white);
  text-align: center;
}
.cm-finance-value-title {
  font-size: 1.75rem;
  font-weight: 800;
  color: #002D5B;
  margin: 0 0 12px;
}
.cm-finance-value-sub {
  font-size: 1.05rem;
  color: var(--cv-text-light);
  margin: 0 auto 40px;
  max-width: 560px;
  line-height: 1.5;
}
.cm-finance-value-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: var(--cv-max-width);
  margin: 0 auto 32px;
  text-align: left;
}
.cm-finance-value-card {
  background: var(--cv-white);
  padding: 28px 24px;
  border-radius: 12px;
  border: 1px solid var(--cv-gray-light);
  position: relative;
  padding-top: 72px;
}
.cm-finance-value-icon {
  position: absolute;
  top: 24px;
  left: 24px;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cv-primary);
}
.cm-finance-value-icon svg {
  width: 28px;
  height: 28px;
}
.cm-finance-icon-check svg { stroke: var(--cv-primary); }
.cm-finance-icon-star { color: var(--cv-primary); }
.cm-finance-icon-calc svg { stroke: var(--cv-primary); }
.cm-finance-value-card h3 {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--cv-dark-blue);
  margin: 0 0 12px;
}
.cm-finance-value-card p {
  font-size: 0.95rem;
  color: var(--cv-text-light);
  margin: 0;
  line-height: 1.5;
}
.cm-finance-shop-btn {
  display: inline-block;
  padding: 12px 28px;
  border: 2px solid var(--cv-primary);
  color: var(--cv-primary);
  background: transparent;
  font-size: 1rem;
  font-weight: 700;
  border-radius: var(--cv-radius-pill);
  text-decoration: none;
  font-family: inherit;
  transition: all 0.2s;
}
.cm-finance-shop-btn:hover {
  background: var(--cv-primary-light);
  color: var(--cv-primary);
}
.cm-finance-steps {
  background: var(--cv-gray-bg);
  padding: 56px 24px;
}
.cm-finance-steps-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
  max-width: var(--cv-max-width);
  margin: 0 auto;
}
.cm-finance-steps-left {
  display: flex;
  justify-content: center;
}
.cm-finance-cards-illus {
  position: relative;
  width: 320px;
  height: 220px;
}
.cm-finance-card-fake {
  position: absolute;
  width: 200px;
  height: 140px;
  background: var(--cv-white);
  border-radius: 8px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.12);
  border: 1px solid var(--cv-gray-light);
  overflow: hidden;
}
.cm-finance-card-fake::before {
  content: '';
  display: block;
  height: 70px;
  background: linear-gradient(135deg, #e5e7eb 0%, #d1d5db 100%);
}
.cm-finance-card-fake.has-img::before { display: none; }
.cm-finance-card-1 { left: 0; top: 16px; transform: rotate(-6deg); z-index: 1; }
.cm-finance-card-2 { left: 60px; top: 32px; transform: rotate(2deg); z-index: 2; }
.cm-finance-card-3 { left: 120px; top: 48px; transform: rotate(6deg); z-index: 1; }
.cm-finance-card-badge {
  position: absolute;
  bottom: -8px;
  right: 12px;
  background: var(--cv-green);
  color: var(--cv-white);
  font-size: 0.9rem;
  font-weight: 700;
  padding: 6px 12px;
  border-radius: 6px;
}
.cm-finance-steps-right h2 {
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--cv-dark-blue);
  margin: 0 0 32px;
}
.cm-finance-timeline {
  list-style: none;
  margin: 0 0 32px;
  padding: 0;
  counter-reset: step;
}
.cm-finance-timeline li {
  position: relative;
  padding-left: 48px;
  margin-bottom: 24px;
  font-size: 1rem;
  color: var(--cv-text);
  line-height: 1.6;
}
.cm-finance-timeline li::before {
  content: '';
  position: absolute;
  left: 11px;
  top: 0;
  bottom: -24px;
  width: 2px;
  background: var(--cv-primary);
}
.cm-finance-timeline li:last-child::before { display: none; }
.cm-finance-step-num {
  position: absolute;
  left: 0;
  top: 0;
  width: 24px;
  height: 24px;
  background: var(--cv-primary);
  color: var(--cv-white);
  font-size: 0.9rem;
  font-weight: 800;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cm-finance-reviews {
  background: var(--cv-white);
  padding: 56px 24px;
}
.cm-finance-reviews-title {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--cv-dark-blue);
  text-align: center;
  margin: 0 0 32px;
}
.cm-finance-reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: var(--cv-max-width);
  margin: 0 auto;
}
.cm-finance-reviews-embed {
  text-align: center;
  max-width: 480px;
  margin: 0 auto;
  padding: 32px 24px;
}
.cm-finance-reviews-embed .cm-finance-reviews-stars {
  font-size: 2rem;
  letter-spacing: 4px;
  margin-bottom: 16px;
}
.cm-finance-reviews-desc {
  font-size: 1.05rem;
  color: var(--cv-text-light);
  margin: 0 0 24px;
  line-height: 1.5;
}
.cm-finance-reviews-cta {
  display: inline-block;
  padding: 14px 32px;
  background: var(--cv-primary);
  color: white;
  font-size: 1rem;
  font-weight: 700;
  border-radius: var(--cv-radius-pill);
  text-decoration: none;
  transition: background 0.2s;
}
.cm-finance-reviews-cta:hover {
  background: var(--cv-primary-hover);
  color: white;
}
.cm-finance-review {
  margin: 0;
  padding: 20px;
  border: none;
  background: rgba(0, 45, 91, 0.04);
  border-radius: var(--cv-radius);
}
.cm-finance-stars {
  color: #f59e0b;
  font-size: 1.1rem;
  letter-spacing: 2px;
  margin-bottom: 12px;
}
.cm-finance-review p {
  font-size: 0.95rem;
  color: var(--cv-text);
  line-height: 1.6;
  margin: 0 0 16px;
}
.cm-finance-review footer {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--cv-dark-blue);
}
.cm-finance-review cite {
  display: block;
  font-size: 0.8rem;
  color: var(--cv-text-light);
  font-style: normal;
  margin-top: 4px;
}
.cm-finance-reviews-divider {
  max-width: var(--cv-max-width);
  margin: 40px auto 0;
  height: 1px;
  background: rgba(0,174,217,0.25);
}
.cm-finance-apply {
  padding: 56px 24px;
  background: var(--cv-white);
}
.cm-finance-apply-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
  max-width: var(--cv-max-width);
  margin: 0 auto;
}
.cm-finance-apply-left h2 {
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--cv-dark-blue);
  margin: 0 0 12px;
}
.cm-finance-apply-left p {
  font-size: 1.1rem;
  color: var(--cv-text-light);
  margin: 0 0 24px;
  line-height: 1.5;
}
.cm-finance-apply-right {
  display: flex;
  justify-content: center;
  position: relative;
}
.cm-finance-person-wrap {
  position: relative;
  max-width: 400px;
}
.cm-finance-person-wrap::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 120%;
  height: 90%;
  background: linear-gradient(135deg, var(--cv-dark-blue) 0%, #2d4a6f 100%);
  border-radius: 24px;
  z-index: -1;
}
.cm-finance-person-wrap img {
  width: 100%;
  height: auto;
  border-radius: 12px;
  display: block;
}
.cm-finance-float-car {
  position: absolute;
  top: 12%;
  left: -8px;
  width: 56px;
  height: 40px;
  background: linear-gradient(135deg, #e5e7eb 0%, #d1d5db 100%);
  border-radius: 6px;
  box-shadow: 0 3px 10px rgba(0,0,0,0.12);
  border: 1px solid var(--cv-gray-light);
}
.cm-finance-float-car-img {
  position: absolute;
  top: 12%;
  left: -8px;
  width: 56px;
  height: 40px;
  object-fit: cover;
  border-radius: 6px;
  box-shadow: 0 3px 10px rgba(0,0,0,0.12);
  border: 1px solid var(--cv-gray-light);
}
.cm-finance-float-card {
  position: absolute;
  bottom: 15%;
  right: -10px;
  background: var(--cv-white);
  border-radius: 24px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.15);
  padding: 10px 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--cv-dark-blue);
  border: 1px solid var(--cv-gray-light);
}
.cm-finance-float-check {
  color: var(--cv-primary);
  font-size: 1.25rem;
  font-weight: 800;
}
@media (max-width: 768px) {
  .cm-finance-hero-inner { grid-template-columns: 1fr; padding: 32px 16px; max-width: 100%; }
  .cm-finance-hero-bg { right: 0; width: 100%; clip-path: polygon(0 0, 100% 0, 100% 100%, 20% 100%); }
  .cm-finance-hero-right { order: -1; justify-content: center; }
  .cm-finance-hero-left { order: 1; }
  .cm-finance-value-grid { grid-template-columns: 1fr; padding: 0 16px; max-width: 100%; }
  .cm-finance-value { padding: 40px 16px 32px; }
  .cm-finance-steps { padding: 40px 16px; }
  .cm-finance-steps-inner { grid-template-columns: 1fr; max-width: 100%; }
  .cm-finance-steps-left { order: 2; }
  .cm-finance-reviews { padding: 40px 16px; }
  .cm-finance-reviews-grid { grid-template-columns: 1fr; padding: 0 16px; max-width: 100%; }
  .cm-finance-apply { padding: 40px 16px; }
  .cm-finance-apply-inner { grid-template-columns: 1fr; padding: 0 16px; max-width: 100%; }
  .cm-finance-apply-right { order: 2; }
  .cm-finance-page { overflow-x: hidden; width: 100%; max-width: 100%; }
}

/* ========== INVENTORY PAGE - full screen, filter card ========== */
.cv-srp {
  background: var(--cv-gray-bg);
  min-height: 100vh;
  width: 100%;
}
.cv-srp-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 24px;
  padding: 24px;
  min-height: calc(100vh - 65px);
  max-width: none;
}
@media (max-width: 1024px) {
  .cv-srp-layout { grid-template-columns: 1fr; padding: 12px; }
  .cv-srp-filters-card { display: none; }
  .cv-srp-mobile-filter { display: block !important; }
}
@media (max-width: 768px) {
  .cv-srp-layout { padding: 12px max(12px, env(safe-area-inset-left)) 12px max(12px, env(safe-area-inset-right)); }
  .cv-srp-brandnew { padding: 14px 16px; margin-bottom: 14px; }
  .cv-srp-promo { padding: 10px 16px; margin-bottom: 14px; }
  .cv-srp-card-body { padding: 16px; }
  .cv-srp-toolbar { gap: 12px; }
  .cv-srp-guide { padding: 28px 12px; margin-top: 32px; }
  .cv-srp-browse-grid { gap: 16px; }
  .cv-srp-browse-card { padding: 18px; }
}
/* Filter sidebar - own card with radius, super clean */
.cv-srp-filters-card {
  position: sticky;
  top: 24px;
  height: fit-content;
  max-height: calc(100vh - 48px);
  overflow-y: auto;
}
.cv-srp-filters {
  background: var(--cv-white);
  border-radius: 12px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
  overflow: hidden;
}

/* Dark charcoal brand new banner */
.cv-srp-brandnew {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  background: #2d2d2d;
  border-radius: var(--cv-radius-lg);
  margin-bottom: 20px;
  position: relative;
  overflow: hidden;
}
.cv-srp-brandnew::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(0,174,217,0.08) 0%, transparent 50%);
  pointer-events: none;
}
.cv-srp-brandnew-inner {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex: 1;
}
.cv-srp-brandnew-badge {
  display: inline-block;
  padding: 4px 10px;
  background: #e91e63;
  color: white;
  font-size: 0.7rem;
  font-weight: 700;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-right: 12px;
}
.cv-srp-brandnew-text {
  font-size: 0.95rem;
  color: white;
  line-height: 1.4;
}
.cv-srp-brandnew-text strong { font-weight: 700; }
.cv-srp-brandnew-link {
  font-size: 0.95rem;
  font-weight: 600;
  color: white;
  text-decoration: underline;
  margin-left: 12px;
}
.cv-srp-brandnew-link:hover { color: rgba(255,255,255,0.9); }
.cv-srp-brandnew-close {
  position: relative;
  z-index: 1;
  background: none;
  border: none;
  color: rgba(255,255,255,0.7);
  font-size: 1.25rem;
  cursor: pointer;
  padding: 4px 8px;
  line-height: 1;
  margin-left: 12px;
}
.cv-srp-brandnew-close:hover { color: white; }
/* Only Brand New Cars toggle */
.cv-filter-brandnew-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid var(--cv-gray-light);
}
.cv-filter-brandnew-label {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--cv-text);
}
.cv-toggle-pill {
  display: inline-flex;
  width: 44px;
  height: 24px;
  background: var(--cv-gray-light);
  border-radius: var(--cv-radius-pill);
  position: relative;
  transition: background 0.2s;
  flex-shrink: 0;
}
.cv-toggle-pill.is-on {
  background: var(--cv-primary);
}
.cv-toggle-pill-thumb {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 20px;
  height: 20px;
  background: white;
  border-radius: 50%;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
  transition: transform 0.2s;
}
.cv-toggle-pill.is-on .cv-toggle-pill-thumb {
  transform: translateX(20px);
}
.cv-srp-filters-form { padding: 0; }
/* Dropdown cards */
.cv-filter-group {
  border-bottom: 1px solid var(--cv-gray-light);
  overflow: hidden;
}
.cv-filter-group:last-of-type { border-bottom: none; }
.cv-filter-accordion {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  text-align: left;
  background: var(--cv-white);
  border: none;
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--cv-text);
  cursor: pointer;
  padding: 16px 24px;
  font-family: inherit;
  transition: background 0.15s;
}
.cv-filter-accordion:hover {
  background: var(--cv-gray-bg);
}
.cv-filter-chevron {
  font-size: 0.65rem;
  color: var(--cv-text-light);
  transition: transform 0.2s;
}
.cv-filter-group[data-accordion] .cv-filter-accordion[aria-expanded="false"] .cv-filter-chevron {
  transform: rotate(-90deg);
}
.cv-filter-group[data-accordion] .cv-filter-accordion[aria-expanded="false"] + .cv-filter-panel {
  display: none;
}
.cv-filter-panel {
  padding: 0 24px 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: var(--cv-white);
}
.cv-filter-price-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}
.cv-filter-input {
  flex: 1;
  padding: 10px 14px;
  border: 1px solid var(--cv-gray-light);
  border-radius: 8px;
  font-size: 0.9rem;
  font-family: inherit;
  background: var(--cv-white);
}
.cv-filter-input:focus {
  outline: none;
  border-color: var(--cv-primary);
  box-shadow: 0 0 0 2px rgba(0,174,217,0.15);
}
.cv-filter-sep { font-size: 0.85rem; color: var(--cv-text-light); }
.cv-filter-link {
  display: block;
  font-size: 0.9rem;
  color: var(--cv-primary);
  text-decoration: none;
  padding: 6px 0;
}
.cv-filter-link:hover { text-decoration: underline; }
.cv-filter-link.is-active { font-weight: 600; }
.cv-filter-check {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.9rem;
  cursor: pointer;
  color: var(--cv-text);
  padding: 4px 0;
}
.cv-filter-check:hover { color: var(--cv-primary); }
.cv-filter-check input {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  accent-color: var(--cv-primary);
}
/* Filter sliders - Year & Kilometers */
.cv-filter-slider-row {
  margin-bottom: 16px;
}
.cv-filter-slider-row:last-child { margin-bottom: 0; }
.cv-filter-slider-label {
  display: block;
  font-size: 0.9rem;
  font-weight: 600;
  margin-bottom: 8px;
  color: var(--cv-text);
}
.cv-filter-slider-wrap {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.cv-filter-slider-wrap .cv-filter-range {
  width: 100%;
  height: 6px;
  accent-color: var(--cv-primary);
  cursor: pointer;
}
.cv-filter-slider-values {
  font-size: 0.85rem;
  color: var(--cv-text-light);
  margin-top: 6px;
}
.cv-filter-slider-values .cv-filter-sep { margin: 0 4px; }
.mobile-filter-slider-row {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin: 8px 0;
}
.mobile-filter-slider-row input[type="range"] {
  width: 100%;
  accent-color: var(--cv-primary);
}
.mobile-filter-slider-values {
  font-size: 0.85rem;
  color: var(--cv-text-light);
}
.cv-filter-see-more {
  background: none;
  border: none;
  font-size: 0.9rem;
  color: var(--cv-primary);
  cursor: pointer;
  padding: 4px 0;
  font-family: inherit;
}
.cv-filter-see-more:hover { text-decoration: underline; }
.cv-filter-hint { font-size: 0.85rem; color: var(--cv-text-light); margin: 0; }
.cv-filter-actions {
  padding: 20px 24px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.cv-filter-apply {
  width: 100%;
  max-width: 100%;
  padding: 14px 24px;
  background: var(--cv-primary);
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 0.9375rem;
  font-weight: 600;
  cursor: pointer;
  margin: 0;
  font-family: inherit;
  transition: background 0.2s;
  box-sizing: border-box;
}
.cv-filter-apply:hover { background: var(--cv-primary-hover); }
.cv-filter-clear {
  display: block;
  text-align: center;
  margin: 12px 0 0;
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--cv-primary);
  text-decoration: none;
}
.cv-filter-clear:hover { text-decoration: underline; }
.cv-srp-results {
  padding: 0;
  min-width: 0;
}
.cv-srp-applied {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 12px;
}
.cv-srp-applied-label { font-size: 0.9rem; color: var(--cv-text-light); flex-shrink: 0; }
.cv-srp-applied-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.cv-srp-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 12px;
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: 20px;
  font-size: 0.85rem;
  color: var(--cv-text);
  text-decoration: none;
  transition: border-color 0.2s, background 0.2s;
}
.cv-srp-chip:hover {
  border-color: var(--cv-primary);
  background: var(--cv-primary-light);
  color: var(--cv-primary);
}
/* Large search bar */
.cv-srp-search-wrap {
  background: var(--cv-primary-light);
  border-radius: 12px;
  padding: 16px;
  margin-bottom: 20px;
}
.cv-srp-search-form {
  display: flex;
  align-items: center;
  background: white;
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius);
  overflow: hidden;
}
.cv-srp-search-form svg {
  flex-shrink: 0;
  margin-left: 16px;
  color: var(--cv-text-light);
}
.cv-srp-search-form input {
  flex: 1;
  padding: 14px 16px;
  border: none;
  font-size: 1rem;
  font-family: inherit;
}
.cv-srp-search-form input::placeholder { color: var(--cv-text-light); }
.cv-srp-search-form input:focus { outline: none; }
.cv-srp-search-row {
  display: flex;
  gap: 10px;
  align-items: stretch;
  margin-bottom: 12px;
}
.cv-srp-search-row .cv-srp-search-form { flex: 1; }
.cv-srp-filter-toggle {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: white;
  border: 1px solid #b8d4e8;
  border-radius: 10px;
  color: var(--cv-text);
  cursor: pointer;
}
.cv-srp-filter-toggle:hover { border-color: var(--cv-primary); color: var(--cv-primary); }
.cv-srp-primary-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.cv-srp-primary-chip {
  display: inline-flex;
  align-items: center;
  padding: 10px 16px;
  background: white;
  border: 1px solid #b8d4e8;
  border-radius: 999px;
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--cv-text);
  cursor: pointer;
  font-family: inherit;
  transition: border-color 0.2s, background 0.2s;
}
.cv-srp-primary-chip:hover { border-color: var(--cv-primary); background: rgba(255,255,255,0.9); }
.cv-srp-chip-chevron { margin-left: 2px; font-size: 0.8em; opacity: 0.8; }
@media (min-width: 769px) {
  .cv-srp-search-row { margin-bottom: 0; }
  .cv-srp-filter-toggle { display: none; }
  .cv-srp-primary-filters { display: none; }
}
/* Filter pills row */
.cv-srp-filter-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 20px;
}
.cv-srp-filter-pill {
  display: inline-flex;
  align-items: center;
  padding: 8px 14px;
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius-pill);
  font-size: 0.9rem;
  color: var(--cv-text);
  text-decoration: none;
  transition: border-color 0.2s, background 0.2s;
}
.cv-srp-filter-pill:hover {
  border-color: var(--cv-primary);
  background: var(--cv-primary-light);
  color: var(--cv-primary);
}
.cv-srp-filter-pill span { color: var(--cv-text-light); margin-left: 2px; }
.cv-srp-clear { font-size: 0.9rem; font-weight: 600; color: var(--cv-primary); text-decoration: none; margin-left: auto; }
.cv-srp-clear:hover { text-decoration: underline; }
.cv-srp-toolbar {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
.cv-srp-count {
  font-size: 0.9rem;
  color: var(--cv-text-light);
}
.cv-srp-toolbar-right {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-left: auto;
}
.cv-srp-toolbar-sep {
  width: 1px;
  height: 18px;
  background: #d1d5db;
  flex-shrink: 0;
}
.cv-srp-sort {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.cv-srp-sort-trigger {
  color: #0059ba;
  font-weight: 500;
  font-size: 0.9rem;
  pointer-events: none;
}
.cv-srp-sort-chevron {
  margin-left: 2px;
  font-size: 0.75em;
  opacity: 0.9;
}
.cv-srp-sort-select {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  border: none;
  background: transparent;
  font-size: 0.9rem;
  min-width: 60px;
}
.cv-srp-location {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.9rem;
  color: var(--cv-text-light);
}
.cv-srp-location svg { flex-shrink: 0; }
.cv-srp-save-search {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background: transparent;
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius);
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  font-family: inherit;
  color: var(--cv-text);
  text-decoration: none;
}
.cv-srp-save-search:hover {
  border-color: var(--cv-primary);
  color: var(--cv-primary);
}
.cv-srp-promo {
  background: linear-gradient(90deg, var(--cv-primary) 0%, var(--cv-primary-dark) 100%);
  padding: 12px 24px;
  margin-bottom: 20px;
  border-radius: var(--cv-radius);
}
.cv-srp-promo-link {
  display: block;
  color: white;
  text-decoration: none;
  font-weight: 600;
  font-size: 0.95rem;
  text-align: center;
}
.cv-srp-promo-link:hover { color: white; opacity: 0.95; }
.cv-srp-promo-cta { text-decoration: underline; margin-left: 4px; }
.cv-srp-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 1200px) {
  .cv-srp-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .cv-srp-grid { grid-template-columns: 1fr; }
}
.cv-srp-card {
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  overflow: hidden;
  transition: box-shadow 0.2s, border-color 0.2s;
  box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}
.cv-srp-card:hover {
  box-shadow: var(--cv-shadow-lg);
  border-color: #007685;
}
.cv-srp-card-link {
  display: block;
  text-decoration: none;
  color: inherit;
}
.cv-srp-card-image {
  position: relative;
  aspect-ratio: 16/10;
  background: #f8f9fa;
  overflow: hidden;
}
.cv-srp-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.cv-srp-card-watermark {
  display: none; /* ref: clean image, no watermark */
}
.cv-srp-card-favorite {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.9);
  border: 1px solid var(--cv-gray-light);
  border-radius: 50%;
  color: var(--cv-text);
  cursor: pointer;
  z-index: 2;
  transition: border-color 0.2s, color 0.2s;
}
.cv-srp-card-favorite:hover {
  border-color: #007685;
  color: #007685;
}
.cv-srp-card-image span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: var(--cv-text-light);
  font-size: 0.9rem;
}
.cv-srp-card-badges {
  display: none; /* ref: clean image, no overlay badges */
}
.cv-srp-badge {
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  width: fit-content;
}
.cv-badge-recent { background: var(--cv-primary); color: white; }
.cv-badge-great { background: var(--cv-gold); color: var(--cv-black); }
.cv-badge-pricedrop { background: #e74c3c; color: white; }
.cv-badge-owner { background: var(--cv-green); color: white; }
.cv-badge-accidents { background: #1B365D; color: white; }
.cv-badge-lowkm { background: var(--cv-primary); color: white; }
.cv-srp-card-body { padding: 20px; }
/* Vehicle title: bold black, largest text in top section - ref */
.cv-srp-card-title {
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 6px;
  color: #000000;
  line-height: 1.3;
}
/* Rating: 5.0 bold black, gold stars, (1 review) teal #007685 */
.cv-srp-card-rating {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 6px;
}
.cv-srp-rating-avg { font-size: 0.875rem; font-weight: 700; color: #000000; }
.cv-srp-rating-stars { font-size: 0.875rem; color: #f5a623; letter-spacing: 1px; }
.cv-srp-rating-stars.cv-srp-rating-empty { color: #d1d5db; }
.cv-srp-rating-link { font-size: 0.875rem; font-weight: 400; color: #007685; text-decoration: none; }
.cv-srp-rating-link:hover { text-decoration: underline; }
/* Kilometers: 15,600 Kms - standard black */
.cv-srp-card-miles {
  font-size: 0.875rem;
  font-weight: 400;
  color: #000000;
  margin: 0 0 4px;
}
/* Specs: SUV - Gasoline - medium gray */
.cv-srp-card-specs {
  font-size: 0.8125rem;
  font-weight: 400;
  color: #6B7280;
  margin: 0 0 10px;
}
.cv-srp-card-trim { font-size: 0.8125rem; font-weight: 400; color: #6B7280; margin: 0 0 4px; }
.cv-srp-card-status {
  margin: 0 0 10px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
/* CARFAX: black pill, white uppercase bold */
.cv-srp-card-carfax {
  display: inline-block;
  padding: 4px 10px;
  background: #000000;
  color: white;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-radius: var(--cv-radius-pill);
  text-decoration: none;
  width: fit-content;
}
.cv-srp-card-carfax:hover { color: white; opacity: 0.9; }
.cv-srp-card-status-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
/* Badges: Blue #2563EB, Purple #8B5CF6, Green #059669 - ref */
.cv-srp-status-badge {
  padding: 5px 10px;
  font-size: 0.7rem;
  font-weight: 700;
  border-radius: var(--cv-radius-pill);
  white-space: nowrap;
  color: white;
}
.cv-srp-status-accidents { background: #2563eb; }
.cv-srp-status-lowkm { background: #8B5CF6; }
.cv-srp-status-owner { background: #059669; }
/* Price: $77,995.00 - very large bold black */
.cv-srp-card-price {
  font-size: 1.5rem;
  font-weight: 800;
  color: #000000;
  margin: 12px 0 8px;
}
.cv-srp-card-was {
  font-size: 0.875rem;
  font-weight: 400;
  color: #6B7280;
  text-decoration: line-through;
  margin: 0 0 6px;
}
/* Delivery: FREE delivery... teal #007685; Details teal underline; Or In-Store pick up gray */
.cv-srp-card-delivery {
  margin: 0 0 10px;
  font-size: 0.875rem;
  font-weight: 400;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.cv-srp-delivery-free { color: #007685; font-weight: 400; }
.cv-srp-delivery-details { color: #6B7280; font-size: 0.875rem; font-weight: 400; }
.cv-srp-delivery-details a { color: #007685; text-decoration: underline; font-weight: 400; }
.cv-srp-delivery-details a:hover { color: #005a66; }
/* Payment pill: #ECFDF5 bg, $663 BW bold #065F46, / for 96 Months dark gray */
.cv-srp-card-payment-row {
  display: flex;
  align-items: baseline;
  gap: 4px;
  flex-wrap: wrap;
}
.cv-srp-payment-pill {
  display: inline-block;
  padding: 6px 12px;
  background: #ECFDF5;
  color: #065F46;
  font-size: 0.9rem;
  font-weight: 700;
  border-radius: var(--cv-radius-pill);
}
.cv-srp-payment-term {
  font-size: 0.9rem;
  font-weight: 400;
  color: #374151;
}
.cv-srp-tile {
  grid-column: 1 / -1;
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius-lg);
  padding: 32px;
  display: flex;
  align-items: center;
  gap: 24px;
}
.cv-srp-tile-inner { flex: 1; }
.cv-srp-tile-inner h3 {
  font-size: 1.1rem;
  margin: 0 0 8px;
  color: var(--cv-text);
}
.cv-srp-tile-inner p {
  font-size: 0.9rem;
  color: var(--cv-text-light);
  margin: 0 0 12px;
  line-height: 1.5;
}
.cv-srp-tile-cta {
  display: inline-block;
  padding: 10px 20px;
  background: var(--cv-primary);
  color: white;
  font-size: 0.9rem;
  font-weight: 600;
  border-radius: var(--cv-radius);
  text-decoration: none;
  font-family: inherit;
}
.cv-srp-tile-cta:hover { background: var(--cv-primary-hover); color: white; }
.cv-srp-tile-finance { background: linear-gradient(135deg, var(--cv-primary) 0%, var(--cv-primary-dark) 100%); color: white; }
.cv-srp-tile-finance .cv-srp-tile-inner h3,
.cv-srp-tile-finance .cv-srp-tile-inner p { color: white; }
.cv-srp-tile-finance .cv-srp-tile-cta { background: var(--cv-gold); color: var(--cv-black); }
.cv-srp-tile-finance .cv-srp-tile-cta:hover { background: var(--cv-gold-hover); color: var(--cv-black); }
.cv-srp-tile-trade { background: var(--cv-gray-bg); }
.cv-srp-tile-deals { background: linear-gradient(135deg, var(--cv-gold) 0%, var(--cv-gold-hover) 100%); }
.cv-srp-tile-deals .cv-srp-tile-inner h3 { color: var(--cv-black); }
.cv-srp-tile-deals .cv-srp-tile-inner p { color: rgba(0,0,0,0.7); }
.cv-srp-tile-deals .cv-srp-tile-cta { background: var(--cv-black); color: white; }
.cv-srp-tile-deals .cv-srp-tile-cta:hover { background: #333; color: white; }
/* Vehicle archives – guide & browse (clean, user-friendly) */
.cv-srp-guide {
  margin-top: 48px;
  padding: 40px 24px;
  border-top: 1px solid var(--cv-gray-light);
  background: #f9fafb;
  border-radius: 16px;
}
.cv-srp-guide-inner { max-width: 900px; margin: 0 auto; }
.cv-srp-guide-title {
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0 0 12px;
  color: var(--cv-text);
  letter-spacing: -0.02em;
}
.cv-srp-guide-desc {
  font-size: 1rem;
  color: var(--cv-text-light);
  margin: 0 0 28px;
  line-height: 1.6;
}
.cv-srp-guide-sub {
  font-size: 1rem;
  font-weight: 600;
  margin: 0 0 10px;
  color: var(--cv-text);
}
.cv-srp-guide-text {
  font-size: 0.95rem;
  color: var(--cv-text-light);
  line-height: 1.6;
  margin: 0 0 24px;
}
.cv-srp-guide-benefits {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 20px;
}
.cv-srp-guide-benefit {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 24px 20px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
  transition: box-shadow 0.2s, border-color 0.2s;
}
.cv-srp-guide-benefit:hover {
  box-shadow: 0 4px 12px rgba(0,0,0,0.06);
  border-color: #d1d5db;
}
.cv-srp-guide-benefit-icon {
  display: block;
  font-size: 1.75rem;
  margin-bottom: 12px;
}
.cv-srp-guide-benefit h4 {
  font-size: 1rem;
  font-weight: 600;
  margin: 0 0 8px;
  color: var(--cv-text);
}
.cv-srp-guide-benefit p {
  font-size: 0.9rem;
  color: var(--cv-text-light);
  line-height: 1.5;
  margin: 0;
}
.cv-srp-browse {
  margin-top: 40px;
  padding: 0 0 24px;
}
.cv-srp-browse-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.cv-srp-browse-card {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 24px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.cv-srp-browse-title {
  font-size: 1rem;
  font-weight: 600;
  margin: 0 0 16px;
  color: var(--cv-text);
  padding-bottom: 12px;
  border-bottom: 1px solid #e5e7eb;
}
.cv-srp-browse-links {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.cv-srp-browse-links a {
  font-size: 0.9rem;
  color: #007685;
  text-decoration: none;
  transition: color 0.15s;
}
.cv-srp-browse-links a:hover { color: #005a66; text-decoration: underline; }
.cv-srp-browse-more { font-weight: 600; margin-top: 4px; }
@media (max-width: 768px) {
  .cv-srp-guide-benefits { grid-template-columns: 1fr; }
  .cv-srp-browse-grid { grid-template-columns: 1fr; }
  .cv-srp-guide { padding: 32px 16px; }
}
.cv-srp-mobile-filter {
  display: none;
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  padding: 12px 24px;
  background: var(--cv-primary);
  color: white;
  border: none;
  border-radius: 24px;
  font-size: 0.95rem;
  font-weight: 700;
  cursor: pointer;
  z-index: 900;
  box-shadow: var(--cv-shadow-lg);
  font-family: inherit;
}
.cv-srp-mobile-filter:hover { background: var(--cv-primary-hover); }
.mobile-filter-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.5);
  z-index: 1000;
}
.mobile-filter-overlay.is-open {
  display: block;
}
.mobile-filter-drawer {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  max-width: 360px;
  height: 100%;
  background: var(--cv-white);
  box-shadow: -4px 0 24px rgba(0,0,0,0.15);
  overflow-y: auto;
}
.mobile-filter-drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--cv-gray-light);
}
.mobile-filter-drawer-header h2 { margin: 0; font-size: 1.25rem; }
.mobile-filter-drawer-close {
  background: none;
  border: none;
  font-size: 1.5rem;
  cursor: pointer;
  padding: 0;
  line-height: 1;
}
.mobile-filter-form { padding: 0 20px 24px; }
.mobile-filter-body { padding: 16px 0; }
.mobile-filter-group {
  margin-bottom: 20px;
}
.mobile-filter-group label:first-child,
.mobile-filter-label { display: block; font-size: 0.9rem; font-weight: 600; margin-bottom: 8px; }
.mobile-filter-input {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius);
  font-size: 0.95rem;
}
.mobile-filter-option {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
  font-size: 0.9rem;
  cursor: pointer;
}
.mobile-filter-price-row {
  display: flex;
  align-items: center;
  gap: 8px;
}
.mobile-filter-price-row input { flex: 1; }
.mobile-filter-drawer-footer {
  display: flex;
  gap: 12px;
  padding: 16px 0;
  border-top: 1px solid var(--cv-gray-light);
}
.mobile-filter-clear {
  padding: 12px 20px;
  color: var(--cv-primary);
  text-decoration: none;
  font-weight: 600;
}
.mobile-filter-apply {
  flex: 1;
  padding: 12px 20px;
  background: var(--cv-primary);
  color: white;
  border: none;
  border-radius: var(--cv-radius);
  font-size: 0.95rem;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
}
.mobile-filter-apply:hover { background: var(--cv-primary-hover); }

.cv-inventory-header {
  padding: 20px 24px 16px;
  background: var(--cv-white);
  border-bottom: 1px solid var(--cv-gray-light);
}
.cv-inventory-top {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 12px;
}
.cv-inventory-title {
  font-size: 1.75rem;
  font-weight: 700;
  margin: 0;
  color: var(--cv-text);
}
.cv-inventory-count {
  font-size: 0.95rem;
  color: var(--cv-text-light);
}
.cv-applied-filters {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}
.cv-applied-label {
  font-size: 0.9rem;
  color: var(--cv-text-light);
}
.cv-clear-all {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--cv-primary);
  text-decoration: none;
}
.cv-clear-all:hover { text-decoration: underline; }
.cv-inventory-toolbar {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.cv-sort-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
}
.cv-sort-label {
  font-size: 0.9rem;
  color: var(--cv-text-light);
}
.cv-sort-select {
  padding: 8px 12px;
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius);
  font-size: 0.9rem;
  font-family: inherit;
  background: var(--cv-white);
  cursor: pointer;
}
.cv-save-search {
  padding: 8px 16px;
  background: transparent;
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius);
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  font-family: inherit;
  color: var(--cv-text);
}
.cv-save-search:hover {
  border-color: var(--cv-primary);
  color: var(--cv-primary);
}
.cv-filter-btn {
  display: none;
  padding: 8px 16px;
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius);
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  font-family: inherit;
  color: var(--cv-text);
}
.cv-filter-btn:hover {
  border-color: var(--cv-primary);
  color: var(--cv-primary);
}
.cv-promo-banner {
  background: linear-gradient(90deg, var(--cv-primary) 0%, var(--cv-primary-dark) 100%);
  padding: 12px 24px;
  text-align: center;
}
.cv-promo-link {
  display: block;
  color: white;
  text-decoration: none;
  font-weight: 600;
  font-size: 0.95rem;
}
.cv-promo-link:hover { color: white; opacity: 0.95; }
.cv-promo-cta { text-decoration: underline; margin-left: 4px; }
.cv-catalog-section {
  padding: 24px;
}
.cv-archive-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px;
}
.cv-vehicle-card {
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius-lg);
  overflow: hidden;
  transition: box-shadow 0.2s, border-color 0.2s;
}
.cv-vehicle-card:hover {
  box-shadow: var(--cv-shadow-lg);
  border-color: var(--cv-primary);
}
.cv-vehicle-card-link {
  display: block;
  text-decoration: none;
  color: inherit;
}
.cv-vehicle-thumb {
  position: relative;
  aspect-ratio: 16/10;
  background: var(--cv-gray-bg);
  overflow: hidden;
}
.cv-vehicle-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.cv-vehicle-thumb span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: var(--cv-text-light);
  font-size: 0.9rem;
}
.cv-vehicle-badges {
  position: absolute;
  top: 12px;
  left: 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.cv-vehicle-badge {
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.cv-badge-recent { background: var(--cv-primary); color: white; }
.cv-badge-great { background: var(--cv-gold); color: var(--cv-black); }
.cv-badge-accident { background: var(--cv-white); color: var(--cv-text); border: 1px solid var(--cv-gray-light); }
.cv-vehicle-body {
  padding: 16px;
}
.cv-vehicle-title {
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 4px;
  color: var(--cv-text);
  line-height: 1.3;
}
.cv-vehicle-trim {
  font-size: 0.85rem;
  color: var(--cv-text-light);
  margin: 0 0 4px;
}
.cv-vehicle-miles {
  font-size: 0.85rem;
  color: var(--cv-text-light);
  margin: 0 0 8px;
}
.cv-vehicle-price {
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--cv-text);
  margin: 0 0 4px;
}
.cv-vehicle-shipping {
  font-size: 0.85rem;
  color: var(--cv-text-light);
  margin: 0 0 12px;
}
.cv-vehicle-cta {
  display: inline-block;
  padding: 10px 20px;
  background: var(--cv-primary);
  color: white;
  font-size: 0.9rem;
  font-weight: 700;
  border-radius: var(--cv-radius);
  transition: background 0.2s;
}
.cv-vehicle-card:hover .cv-vehicle-cta {
  background: var(--cv-primary-hover);
}
.cv-interstitial-tile {
  grid-column: 1 / -1;
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius-lg);
  padding: 32px;
  display: flex;
  align-items: center;
  gap: 24px;
}
.cv-tile-content h3 {
  font-size: 1.1rem;
  margin: 0 0 8px;
  color: var(--cv-text);
}
.cv-tile-content p {
  font-size: 0.9rem;
  color: var(--cv-text-light);
  margin: 0 0 12px;
  line-height: 1.5;
}
.cv-tile-cta {
  display: inline-block;
  padding: 10px 20px;
  background: var(--cv-primary);
  color: white;
  font-size: 0.9rem;
  font-weight: 600;
  border-radius: var(--cv-radius);
  text-decoration: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
}
.cv-tile-cta:hover {
  background: var(--cv-primary-hover);
  color: white;
}

/* ========== VEHICLE DETAIL PAGE ========== */
.cv-vdp-wrap {
  background: var(--cv-white);
  padding: 24px 0 64px;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}
body.page-vehicle-body { scroll-behavior: smooth; }
.cv-vdp-layout {
  display: grid;
  grid-template-columns: 1.25fr 1fr;
  grid-template-rows: auto 1fr;
  grid-template-areas: "gallery buy" "content .";
  gap: 32px;
  max-width: var(--cv-max-width);
  margin: 0 auto;
  padding: 0 24px;
  align-items: stretch;
  width: 100%;
  box-sizing: border-box;
}
.cv-vdp-gallery-card { grid-area: gallery; }
.cv-vdp-right { grid-area: buy; }
.cv-vdp-left { grid-area: content; }
@media (max-width: 1024px) {
  .cv-vdp-layout {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    grid-template-areas: "gallery" "buy" "content";
  }
}
.cv-vdp-left {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
/* VDP cards - each section its own card */
.cv-vdp-card {
  background: var(--cv-white);
  border-radius: 24px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.08);
  padding: 24px;
  border: 1px solid var(--cv-gray-light);
}
.cv-vdp-content-card {
  background: var(--cv-white);
  border-radius: 24px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.08);
  padding: 24px;
  border: 1px solid var(--cv-gray-light);
}
.cv-vdp-right {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}
@media (min-width: 1025px) {
  .cv-vdp-right { align-items: flex-start; }
}
/* Gallery card (card wrapper) */
.cv-vdp-gallery-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
}
.cv-vdp-gallery {
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
}
.cv-vdp-main-image {
  aspect-ratio: 16/10;
  background: var(--cv-gray-bg);
  border-radius: 12px;
  overflow: hidden;
  position: relative;
}
.cv-vdp-main-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.cv-vdp-image-link {
  display: block;
  width: 100%;
  height: 100%;
}
.cv-vdp-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: var(--cv-text-light);
  font-size: 0.9rem;
}
.cv-vdp-carfax {
  display: inline-block;
  margin-top: 16px;
}
.cv-vdp-carfax img {
  height: 16px;
  width: auto;
  display: block;
}
.cv-vdp-thumbs-row {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 4px;
}
.cv-vdp-thumb {
  width: 80px;
  height: 60px;
  min-width: 80px;
  padding: 0;
  border: 2px solid transparent;
  border-radius: var(--cv-radius);
  overflow: hidden;
  cursor: pointer;
  background: var(--cv-gray-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.cv-vdp-thumb.is-active {
  border-color: var(--cv-primary);
}
.cv-vdp-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.cv-vdp-thumb span {
  font-size: 0.65rem;
  text-align: center;
  padding: 4px;
  color: var(--cv-text-light);
}
.cv-vdp-see-all {
  background: none;
  border: none;
  color: var(--cv-primary);
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  padding: 0;
  font-family: inherit;
  align-self: flex-start;
}
.cv-vdp-see-all:hover { text-decoration: underline; }
.cv-vdp-content {
  display: flex;
  flex-direction: column;
  gap: 0;
}
/* Ask Echo - own card */
.cv-vdp-card-ask-echo {
  padding: 16px 24px;
}
.cv-vdp-card-ask-echo .ask-echo-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  background: var(--cv-gray-bg);
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius-pill);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--cv-text);
  cursor: pointer;
  font-family: inherit;
}
.cv-vdp-card-ask-echo .ask-echo-btn:hover {
  border-color: var(--cv-primary);
  color: var(--cv-primary);
}
.cv-vdp-card-ask-echo .ask-echo-icon { font-size: 1.1rem; }

/* Tab nav - pill-shaped bar, single row, horizontally scrollable */
.cv-vdp-card-tabs {
  display: flex;
  flex-wrap: nowrap;
  gap: 4px;
  padding: 8px 16px;
  border-radius: 999px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}
.cv-vdp-tab {
  padding: 10px 18px;
  font-size: 0.9rem;
  font-weight: 500;
  color: #1a2b48;
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
  border-radius: 999px;
  transition: color 0.2s, background 0.2s;
}
.cv-vdp-tab:hover { color: var(--cv-primary); background: var(--cv-gray-bg); }
.cv-vdp-tab.is-active {
  font-weight: 700;
  color: #1a2b48;
  background: transparent;
}
.cv-vdp-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.cv-vdp-photo-count {
  font-size: 0.875rem;
  color: var(--cv-text-light);
  margin: 0 0 8px;
}
.cv-vdp-share-save {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.875rem;
  color: var(--cv-text-light);
}
.cv-share-save {
  background: none;
  border: none;
  color: inherit;
  cursor: pointer;
  font-family: inherit;
  padding: 0;
}
.cv-share-save:hover { color: var(--cv-primary); }
.cv-vdp-pipe { color: var(--cv-gray-light); font-weight: 300; }
.cv-vdp-title {
  font-size: 1.75rem;
  font-weight: 800;
  margin: 0 0 6px;
  color: var(--cv-text);
  letter-spacing: -0.02em;
  line-height: 1.2;
}
.cv-vdp-subtitle {
  font-size: 0.95rem;
  color: var(--cv-text-light);
  margin: 0 0 4px;
}
.cv-vdp-miles {
  font-size: 0.95rem;
  color: var(--cv-text-light);
  margin: 0 0 16px;
}
.cv-vdp-price {
  font-size: 1.5rem;
  font-weight: 800;
  margin: 0 0 20px;
}
.cv-vdp-get-started {
  padding: 14px 32px;
  min-height: 48px;
  font-size: 1rem;
  font-weight: 700;
  background: var(--cv-green);
  color: white;
  border: none;
  border-radius: 999px;
  cursor: pointer;
  font-family: inherit;
  width: 100%;
  max-width: 100%;
  transition: background 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cv-vdp-get-started:hover {
  background: var(--cv-green-hover);
}
.cv-vdp-get-started-form { margin-bottom: 28px; }
.cv-vdp-buy-box {
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: 24px;
  padding: 24px 0 0 0;
  position: sticky;
  top: 88px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.08);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
@media (max-width: 1024px) {
  .cv-vdp-buy-box { flex: 1; min-height: 0; }
  .cv-vdp-buy-box .cv-vdp-buy-footer { margin-top: auto; }
}
@media (min-width: 1025px) {
  .cv-vdp-buy-box { width: 100%; flex: none; }
  .cv-vdp-buy-box .cv-vdp-buy-footer { margin-top: 12px; }
}
.cv-vdp-buy-badge {
  display: inline-block;
  padding: 6px 14px;
  background: #1B365D;
  color: white;
  font-size: 0.75rem;
  font-weight: 700;
  border-radius: var(--cv-radius-pill);
  margin: 20px 0 12px 24px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.cv-vdp-buy-title {
  font-size: 1.5rem;
  font-weight: 800;
  margin: 0 0 6px;
  color: #1B365D;
  letter-spacing: -0.02em;
  padding: 0 24px;
}
.cv-vdp-buy-subtitle {
  font-size: 0.9rem;
  color: var(--cv-text-light);
  margin: 0 0 20px;
  padding: 0 24px;
}
.cv-vdp-buy-rating {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 16px;
  padding: 0 24px;
}
.cv-vdp-buy-rating-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
  color: #1B365D;
}
.cv-vdp-buy-rating-link:hover { color: var(--cv-primary); }
.cv-vdp-buy-rating-stars {
  color: #f5a623;
  font-size: 0.95rem;
  letter-spacing: 0.5px;
}
.cv-vdp-buy-rating-stars.cv-vdp-buy-rating-empty { color: #d1d5db; }
.cv-vdp-buy-rating-avg { font-weight: 700; font-size: 0.9rem; }
.cv-vdp-buy-rating-count { font-size: 0.85rem; color: var(--cv-text-light); }
.cv-vdp-buy-rate-btn {
  background: none;
  border: none;
  padding: 0;
  font-size: 0.9rem;
  color: var(--cv-primary);
  cursor: pointer;
  text-decoration: underline;
  font-family: inherit;
}
.cv-vdp-buy-rate-btn:hover { color: var(--cv-primary-hover); }
.cv-vdp-buy-price-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 8px;
  padding: 0 24px;
}
.cv-vdp-buy-price {
  font-size: 2rem;
  font-weight: 800;
  color: #1B365D;
  margin: 0;
}
.cv-vdp-buy-price sup { font-size: 0.5em; vertical-align: super; }
.cv-vdp-buy-terms {
  font-size: 0.9rem;
  color: #1B365D;
  text-decoration: none;
  padding: 8px 16px;
  background: rgba(0,174,217,0.12);
  border-radius: var(--cv-radius-pill);
  font-weight: 600;
}
.cv-vdp-buy-terms:hover { color: var(--cv-primary-hover); text-decoration: underline; }
.cv-vdp-buy-payment {
  font-size: 0.9rem;
  color: var(--cv-text-light);
  margin: 0 0 8px;
  padding: 0 24px;
}
.cv-vdp-info-icon { opacity: 0.7; font-size: 0.9em; }
.cv-vdp-buy-delivery {
  font-size: 0.95rem;
  margin: 0 0 24px;
  padding: 0 24px;
}
.cv-vdp-delivery-free { color: var(--cv-green); font-weight: 600; }
.cv-vdp-buy-form {
  padding: 0 24px 24px;
}
.cv-vdp-get-started {
  border-radius: var(--cv-radius-pill);
}
.cv-vdp-buy-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  padding: 16px 24px;
  background: var(--cv-gray-bg);
  border-top: 1px solid var(--cv-gray-light);
}
.cv-vdp-buy-footer .cv-share-save {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: 0.9rem;
  color: var(--cv-text-light);
}
.cv-vdp-buy-footer .cv-share-save:hover { color: var(--cv-primary); }
.cv-vdp-buy-footer .cv-vdp-test-drive-btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--cv-primary);
  background: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
  padding: 0;
}
.cv-vdp-buy-footer .cv-vdp-test-drive-btn:hover { text-decoration: underline; }
.cv-vdp-footer-icon { font-size: 1rem; opacity: 0.8; }
.cv-vdp-footer-divider {
  width: 1px;
  height: 20px;
  background: var(--cv-gray-light);
  flex-shrink: 0;
}

/* Rating modal */
.cv-vdp-rating-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9999;
  align-items: center;
  justify-content: center;
}
.cv-vdp-rating-modal.open {
  display: flex;
}
.cv-vdp-rating-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  cursor: pointer;
}
.cv-vdp-rating-content {
  position: relative;
  background: var(--cv-white);
  padding: 28px 24px;
  border-radius: 16px;
  max-width: 360px;
  width: 90%;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.2);
  z-index: 1;
}
.cv-vdp-rating-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 32px;
  height: 32px;
  border: none;
  background: transparent;
  color: #666;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  padding: 0;
}
.cv-vdp-rating-close:hover { color: #333; }
.cv-vdp-rating-title {
  margin: 0 0 16px;
  font-size: 1.25rem;
  font-weight: 700;
  color: #1B365D;
}
.cv-vdp-rating-stars-wrap {
  display: flex;
  gap: 4px;
  margin-bottom: 16px;
}
.cv-vdp-rate-star {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  font-size: 28px;
  color: #d1d5db;
  line-height: 1;
}
.cv-vdp-rate-star:hover,
.cv-vdp-rate-star.active { color: #f5a623; }
.cv-vdp-rating-review-label {
  display: block;
  font-size: 0.9rem;
  font-weight: 600;
  color: #1B365D;
  margin-bottom: 8px;
}
.cv-vdp-rating-review {
  width: 100%;
  padding: 12px;
  border: 1px solid var(--cv-gray-light);
  border-radius: 8px;
  font-family: inherit;
  font-size: 0.9rem;
  margin-bottom: 16px;
  box-sizing: border-box;
}
.cv-vdp-rating-submit {
  width: 100%;
  padding: 12px 20px;
  background: var(--cv-primary);
  color: white;
  border: none;
  border-radius: var(--cv-radius-pill);
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
}
.cv-vdp-rating-submit:hover { background: var(--cv-primary-hover); }
.cv-vdp-rating-submit:disabled { opacity: 0.7; cursor: not-allowed; }

.cv-vdp-sections { margin-top: 40px; }
.cv-vdp-section { margin-bottom: 40px; }

/* Overview card - white card, orange accent, carousel (reference) */
.cv-vdp-card-overview {
  background: var(--cv-white);
  padding: 32px 24px 0;
  border: 1px solid #e8e9eb;
  border-radius: 12px;
}
.cv-vdp-overview-inner {
  position: relative;
  padding-bottom: 0;
}
.cv-vdp-overview-header {
  text-align: center;
  margin-bottom: 24px;
  position: relative;
  padding-right: 56px;
}
.cv-vdp-why-accent {
  display: block;
  width: 48px;
  height: 4px;
  background: #f97316;
  border-radius: 2px;
  margin: 0 auto 16px;
}
.cv-vdp-why-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: #001C3D;
  margin: 0 0 12px;
}
.cv-vdp-overview-desc {
  font-size: 0.95rem;
  color: #6b7280;
  margin: 0 0 24px;
  line-height: 1.5;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}
.cv-vdp-overview-arrows {
  position: absolute;
  top: 0;
  right: 0;
  display: flex;
  gap: 8px;
}
.cv-vdp-carousel-prev,
.cv-vdp-carousel-next {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid #001C3D;
  background: var(--cv-white);
  color: #001C3D;
  font-size: 1.25rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  font-family: inherit;
  line-height: 1;
  transition: opacity 0.2s, border-color 0.2s, color 0.2s;
}
.cv-vdp-carousel-prev:hover:not(.is-disabled):not(:disabled),
.cv-vdp-carousel-next:hover:not(.is-disabled):not(:disabled) {
  background: #f0f4f8;
}
.cv-vdp-carousel-prev.is-disabled,
.cv-vdp-carousel-next.is-disabled,
.cv-vdp-carousel-prev:disabled,
.cv-vdp-carousel-next:disabled {
  border-color: #d1d5db;
  color: #9ca3af;
  cursor: not-allowed;
  opacity: 0.8;
}
.cv-vdp-overview-cards-wrap {
  overflow: hidden;
  margin-bottom: 20px;
}
.cv-vdp-overview-cards {
  display: flex;
  justify-content: center;
  gap: 12px;
  transition: transform 0.3s ease;
}
.cv-vdp-overview-cards .cv-vdp-why-card {
  flex: 0 0 calc((100% - 24px) / 3);
  min-width: 0;
  box-sizing: border-box;
  padding: 24px 16px;
}
.cv-vdp-overview-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-bottom: 24px;
}
.cv-vdp-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  border: none;
  background: #d1d5db;
  cursor: pointer;
  padding: 0;
  transition: background 0.2s;
}
.cv-vdp-dot.is-active {
  background: #0059ba;
}
.cv-vdp-overview-car {
  height: 120px;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  margin: 0 -24px 0;
}
.cv-vdp-overview-car-cutout {
  height: 200px;
  background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(248,250,252,0.6) 40%, rgba(255,255,255,1) 100%);
  padding: 20px 0;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.cv-vdp-overview-car img {
  max-height: 100%;
  width: auto;
  object-fit: contain;
  object-position: center bottom;
}
.cv-vdp-overview-car-cutout img {
  filter: drop-shadow(0 6px 16px rgba(0,0,0,0.12));
  max-height: 180px;
  width: auto;
  object-fit: contain;
  object-position: center bottom;
}
.cv-vdp-overview-disclaimer {
  font-size: 0.8rem;
  color: #94a3b8;
  margin: 16px 0 0;
  padding: 0 0 24px;
  line-height: 1.5;
}
.cv-vdp-why-card {
  background: var(--cv-white);
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  padding: 20px 16px;
  transition: box-shadow 0.2s;
}
.cv-vdp-why-card:hover { box-shadow: 0 2px 12px rgba(0,0,0,0.06); }
.cv-vdp-why-card h3,
.cv-vdp-why-card h4 {
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 8px;
  color: #001C3D;
}
.cv-vdp-why-card p {
  font-size: 0.9rem;
  color: #6b7280;
  margin: 0;
  line-height: 1.5;
}
.cv-vdp-feature-list {
  list-style: disc;
  padding-left: 24px;
  margin: 0 0 16px;
}
.cv-vdp-feature-list li { margin-bottom: 8px; }
.cv-vdp-spec-table {
  width: 100%;
  border-collapse: collapse;
}
.cv-vdp-spec-table td {
  padding: 8px 0;
  border-bottom: 1px solid var(--cv-gray-light);
}
.cv-vdp-spec-table td:first-child {
  color: var(--cv-text-light);
  width: 140px;
}

/* Vehicle Details - Carvana-style icon grid */
.cv-vdp-details-accent {
  display: block;
  width: 48px;
  height: 4px;
  background: #f97316;
  border-radius: 2px;
  margin: 0 auto 16px;
}
.cv-vdp-details-title {
  text-align: center;
  color: #001C3D;
  font-weight: 700;
  margin-bottom: 24px;
}
.cv-vdp-details-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
}
.cv-vdp-details-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px 0;
  border-bottom: 1px solid #e5e7eb;
}
.cv-vdp-details-icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #E8F4FF;
  color: #0059ba;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cv-vdp-details-icon svg {
  flex-shrink: 0;
}
.cv-vdp-details-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.cv-vdp-details-label {
  font-size: 0.8rem;
  color: #6b7280;
}
.cv-vdp-details-value {
  font-size: 0.95rem;
  font-weight: 700;
  color: #001C3D;
}
.cv-vdp-details-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid #e5e7eb;
}
.cv-vdp-details-brand-logo {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: #f3f4f6;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.cv-vdp-details-brand-initial {
  font-size: 1.25rem;
  font-weight: 700;
  color: #001C3D;
}
.cv-vdp-details-brand-text {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.cv-vdp-details-brand-text strong {
  font-size: 0.95rem;
  color: #001C3D;
}
.cv-vdp-details-features-link {
  font-size: 0.9rem;
  color: #0059ba;
  text-decoration: none;
}
.cv-vdp-details-features-link:hover {
  text-decoration: underline;
}
.cv-vdp-details-prior {
  font-size: 0.9rem;
  color: #4b5563;
  margin: 16px 0 20px;
}
.cv-vdp-details-prior-link {
  color: #0059ba;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.cv-vdp-details-prior-link:hover {
  text-decoration: underline;
}
.cv-vdp-details-prior-link svg {
  flex-shrink: 0;
  opacity: 0.8;
}
.cv-vdp-details-specs-btn {
  display: inline-block;
  padding: 12px 24px;
  background: white;
  border: 2px solid #001C3D;
  color: #001C3D;
  font-size: 1rem;
  font-weight: 600;
  text-decoration: none;
  border-radius: 999px;
  transition: background 0.2s, color 0.2s;
}
.cv-vdp-details-specs-btn:hover {
  background: #001C3D;
  color: white;
}
@media (max-width: 768px) {
  .cv-vdp-details-grid {
    grid-template-columns: 1fr;
  }
}
.cv-vdp-mobile-bar {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--cv-white);
  border-top: 1px solid var(--cv-gray-light);
  padding: 12px 16px;
  z-index: 998;
  box-shadow: 0 -4px 12px rgba(0,0,0,0.08);
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
}
@media (max-width: 768px) {
  .cv-vdp-mobile-bar { display: flex; }
}
.cv-vdp-mobile-echo,
.cv-vdp-mobile-carfax,
.cv-vdp-mobile-wishlist,
.cv-vdp-mobile-share,
.cv-vdp-mobile-test-drive {
  padding: 8px 16px;
  font-size: 0.85rem;
  background: var(--cv-gray-bg);
  border: 1px solid var(--cv-gray-light);
  border-radius: var(--cv-radius);
  text-decoration: none;
  color: var(--cv-text);
  font-family: inherit;
  cursor: pointer;
}
.cv-vdp-mobile-echo,
.cv-vdp-mobile-carfax { display: inline-flex; align-items: center; }
.cv-vdp-ask-echo {
  margin-bottom: 16px;
}
.cv-vdp-related-title {
  font-size: 1.5rem;
  font-weight: 700;
  margin: 32px 0 24px;
  color: var(--cv-text);
  max-width: var(--cv-max-width);
  margin-left: auto;
  margin-right: auto;
  padding: 0 24px;
}
.cv-vdp-related-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px;
  max-width: var(--cv-max-width);
  margin: 0 auto 48px;
  padding: 0 24px;
}
.cv-vdp-related-card {
  background: var(--cv-white);
  border: 1px solid var(--cv-gray-light);
  border-radius: 12px;
  overflow: hidden;
  transition: box-shadow 0.2s, border-color 0.2s;
}
.cv-vdp-related-card:hover {
  box-shadow: var(--cv-shadow-lg);
  border-color: var(--cv-primary);
}
.cv-vdp-related-link { text-decoration: none; color: inherit; display: block; }
.cv-vdp-related-image {
  position: relative;
  aspect-ratio: 16/10;
  overflow: hidden;
  border-radius: 12px 12px 0 0;
  background: var(--cv-gray-bg);
  overflow: hidden;
}
.cv-vdp-related-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.cv-vdp-related-badges {
  position: absolute;
  top: 12px;
  left: 12px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.cv-vdp-related-badge {
  padding: 6px 12px;
  background: #1B365D;
  color: white;
  font-size: 0.75rem;
  font-weight: 700;
  border-radius: var(--cv-radius-pill);
}
.cv-vdp-related-badge.cv-vdp-badge-owner { background: var(--cv-green); }
.cv-vdp-related-badge.cv-vdp-badge-accidents { background: #1B365D; }
.cv-vdp-related-badge.cv-vdp-badge-lowkm { background: var(--cv-primary); }
.cv-vdp-related-body { padding: 16px; }
.cv-vdp-related-body h3 {
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 4px;
}
.cv-vdp-related-trim,
.cv-vdp-related-miles { font-size: 0.85rem; color: var(--cv-text-light); margin: 0 0 4px; }
.cv-vdp-related-price { font-size: 1.25rem; font-weight: 800; margin: 0 0 8px; }
.cv-vdp-related-payment { font-size: 0.85rem; color: var(--cv-text-light); margin: 0 0 6px; }
.cv-vdp-related-carfax { display: inline-block; margin: 0 0 8px; }
.cv-vdp-related-carfax img { height: 16px; width: auto; display: block; }
.cv-vdp-related-shipping { font-size: 0.85rem; color: var(--cv-text-light); margin: 0 0 12px; }
.cv-vdp-related-cta {
  display: inline-block;
  padding: 10px 20px;
  background: var(--cv-green);
  color: white;
  font-size: 0.9rem;
  font-weight: 700;
  border-radius: var(--cv-radius-pill);
  transition: background 0.2s;
}
.cv-vdp-related-card:hover .cv-vdp-related-cta { background: var(--cv-green-hover); }
.cv-vdp-hide { display: none !important; }
.cv-vdp-section-title { font-size: 1.25rem; font-weight: 700; margin: 0 0 16px; }
.cv-vdp-section-p { font-size: 0.95rem; color: var(--cv-text-light); margin: 0 0 16px; line-height: 1.5; }
.cv-vdp-details-title { font-size: 1.1rem; font-weight: 700; margin: 0 0 12px; }
.cv-vdp-extra {
  background: var(--cv-gray-bg);
  padding: 40px 32px;
  border-radius: 24px;
  border: 1px solid var(--cv-gray-light);
  margin: 32px auto;
  max-width: var(--cv-max-width);
}
.cv-vdp-extra-inner { max-width: 800px; margin: 0 auto; }
.cv-vdp-extra-title { font-size: 1.25rem; font-weight: 700; margin: 0 0 8px; }
.cv-vdp-extra-desc { color: var(--cv-text-light); margin: 0 0 16px; line-height: 1.5; }
/* 150-Point Inspection - reference layout */
.cv-vdp-card-inspection {
  background: #F7F9FB;
}
.cv-vdp-inspection-accent {
  display: block;
  width: 48px;
  height: 4px;
  background: #F9A825;
  border-radius: 2px;
  margin: 0 auto 16px;
}
.cv-vdp-inspection-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: #050B20;
  margin: 0 0 12px;
  text-align: center;
}
.cv-vdp-inspection-desc {
  font-size: 0.95rem;
  color: #4D5C6D;
  margin: 0 auto 24px;
  line-height: 1.5;
  text-align: center;
  max-width: 560px;
}
.cv-vdp-inspection-cards {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.cv-vdp-inspection-card {
  background: white;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 24px 28px;
}
.cv-vdp-inspection-card:first-child {
  display: flex;
  align-items: center;
  gap: 20px;
}
.cv-vdp-inspection-card-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #007BD3;
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  flex-shrink: 0;
}
.cv-vdp-inspection-card-icon svg {
  width: 28px;
  height: 28px;
}
.cv-vdp-inspection-icon-check {
  position: absolute;
  top: 4px;
  right: 6px;
  font-size: 0.75rem;
  font-weight: 700;
}
.cv-vdp-inspection-card-title {
  font-size: 1.1rem;
  font-weight: 700;
  color: #050B20;
  margin: 0 0 6px;
}
.cv-vdp-inspection-card-text {
  font-size: 0.95rem;
  color: #4D5C6D;
  margin: 0;
  line-height: 1.5;
}
.cv-vdp-inspection-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.cv-vdp-inspection-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid #e5e7eb;
}
.cv-vdp-inspection-list li:last-of-type {
  border-bottom: none;
}
.cv-vdp-inspection-cat {
  font-size: 0.95rem;
  color: #4D5C6D;
}
.cv-vdp-inspection-status {
  font-size: 0.95rem;
  font-weight: 700;
  color: #050B20;
  display: flex;
  align-items: center;
  gap: 6px;
}
.cv-vdp-inspection-check {
  color: #28A745;
  font-weight: 700;
}
.cv-vdp-inspection-status-link {
  color: #007BD3;
  font-weight: 700;
  text-decoration: none;
}
.cv-vdp-inspection-status-link:hover { text-decoration: underline; }
.cv-vdp-inspection-card-footer {
  padding-top: 16px;
  margin-top: 8px;
  border-top: 1px solid #e5e7eb;
}
.cv-vdp-inspection-full-link {
  font-size: 0.95rem;
  color: #007BD3;
  font-weight: 600;
  text-decoration: none;
}
.cv-vdp-inspection-full-link:hover { text-decoration: underline; }
.cv-vdp-inspection-card-carfax {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.cv-vdp-inspection-carfax-logo {
  height: 28px;
  width: auto;
  max-width: 120px;
  object-fit: contain;
}
.cv-vdp-inspection-view-report {
  font-size: 0.95rem;
  color: #007BD3;
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.cv-vdp-inspection-view-report:hover { text-decoration: underline; }
.cv-vdp-inspection-view-report svg { flex-shrink: 0; opacity: 0.8; }
.cv-vdp-guarantee-list {
  list-style: none;
  padding: 0;
  margin: 0 0 16px;
}
.cv-vdp-guarantee-list li {
  padding: 6px 0;
  border-bottom: 1px solid var(--cv-gray-light);
}
.cv-vdp-report-link { color: var(--cv-primary); font-weight: 600; }
.cv-vdp-report-link:hover { text-decoration: underline; }
.cv-vdp-extra-sub { font-size: 1rem; font-weight: 600; margin: 16px 0 8px; color: #1a2b48; }
.cv-vdp-pricing-content { margin-top: 8px; }
.cv-vdp-pricing-main { font-size: 2rem; font-weight: 800; color: #1a2b48; margin: 0 0 12px; }
.cv-vdp-pricing-content .cv-vdp-buy-terms { display: inline-block; margin-top: 12px; }

/* Price Details - Carvana-style card */
.cv-vdp-pricing-card {
  background: #f0f8ff;
  border: 1px solid #e0edf7;
  border-radius: 12px;
  padding: 24px;
  margin-top: 16px;
}
.cv-vdp-pricing-was-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
}
.cv-vdp-pricing-was {
  font-size: 1rem;
  color: #6b7280;
  text-decoration: line-through;
}
.cv-vdp-pricing-savings {
  font-size: 0.9rem;
  font-weight: 600;
  color: #059669;
}
.cv-vdp-pricing-main-row {
  margin-bottom: 16px;
}
.cv-vdp-pricing-card .cv-vdp-pricing-main {
  font-size: 2.5rem;
  font-weight: 800;
  color: #1a2b48;
  margin: 0;
  line-height: 1.1;
}
.cv-vdp-pricing-card .cv-vdp-pricing-main sup {
  font-size: 0.45em;
  vertical-align: super;
}
.cv-vdp-pricing-payment-row {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 4px;
}
.cv-vdp-pricing-payment-label {
  font-size: 0.95rem;
  color: #4b5563;
}
.cv-vdp-pricing-payment-value {
  font-size: 1.1rem;
  font-weight: 700;
  color: #1a2b48;
}
.cv-vdp-pricing-payment-note {
  font-size: 0.9rem;
  color: #6b7280;
  margin: 0 0 20px;
}
.cv-vdp-pricing-finance-btn {
  display: inline-block;
  padding: 12px 24px;
  background: var(--cv-primary);
  color: white;
  font-size: 1rem;
  font-weight: 600;
  text-decoration: none;
  border-radius: 999px;
  transition: background 0.2s;
  border: none;
  cursor: pointer;
  font-family: inherit;
}
.cv-vdp-pricing-finance-btn:hover {
  background: var(--cv-primary-hover);
  color: white;
}
.cv-vdp-pricing-includes {
  font-size: 0.85rem;
  color: #6b7280;
  margin: 16px 0 0;
}

/* Owner Reviews - reference layout */
.cv-vdp-reviews-accent {
  display: block;
  width: 48px;
  height: 4px;
  background: #f97316;
  border-radius: 2px;
  margin: 0 auto 16px;
}
.cv-vdp-reviews-title {
  text-align: center;
  font-size: 1.5rem;
  font-weight: 700;
  color: #002C5F;
  margin: 0 0 24px;
}
.cv-vdp-reviews-card {
  background: #f1f5f9;
  border-radius: 12px;
  padding: 24px;
  margin-bottom: 28px;
  display: flex;
  gap: 32px;
  flex-wrap: wrap;
}
.cv-vdp-reviews-card-empty {
  flex-direction: column;
}
.cv-vdp-reviews-left {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 160px;
}
.cv-vdp-reviews-avg {
  font-size: 2.75rem;
  font-weight: 800;
  color: #002C5F;
  line-height: 1;
}
.cv-vdp-reviews-stars-wrap {
  font-size: 1.1rem;
  letter-spacing: 2px;
}
.cv-vdp-star-full,
.cv-vdp-star-half-fg { color: #F9A825; }
.cv-vdp-star-empty,
.cv-vdp-star-half-bg { color: #d1d5db; }
.cv-vdp-star-half {
  position: relative;
  display: inline-block;
}
.cv-vdp-star-half-bg { display: inline; }
.cv-vdp-star-half-clip {
  position: absolute;
  left: 0;
  top: 0;
  width: 50%;
  overflow: hidden;
  display: inline-block;
}
.cv-vdp-star-half-fg {
  display: inline;
  position: relative;
  left: 0;
}
.cv-vdp-reviews-vehicle {
  font-size: 1rem;
  font-weight: 700;
  color: #002C5F;
}
.cv-vdp-reviews-count {
  font-size: 0.9rem;
  color: #6b7280;
}
.cv-vdp-reviews-about {
  font-size: 0.85rem;
  color: #6b7280;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 4px;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  font-family: inherit;
  text-align: left;
}
.cv-vdp-reviews-about:hover { text-decoration: underline; color: #4b5563; }
.cv-vdp-reviews-about:focus { outline: none; }
.cv-vdp-reviews-info-icon {
  font-size: 0.9rem;
  opacity: 0.8;
}
.cv-vdp-reviews-breakdown {
  flex: 1;
  min-width: 200px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  justify-content: center;
}
.cv-vdp-reviews-row {
  display: flex;
  align-items: center;
  gap: 12px;
}
.cv-vdp-reviews-filter {
  font-size: 0.9rem;
  color: #002C5F;
  text-decoration: underline;
  text-underline-offset: 2px;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  text-align: left;
  min-width: 90px;
  flex-shrink: 0;
}
.cv-vdp-reviews-filter:hover { color: #0059ba; }
.cv-vdp-reviews-bar-wrap {
  flex: 1;
  height: 8px;
  background: #e2e8f0;
  border-radius: 4px;
  overflow: hidden;
}
.cv-vdp-reviews-bar {
  height: 100%;
  background: #F9A825;
  border-radius: 4px;
  transition: width 0.3s;
}
.cv-vdp-reviews-qa {
  margin-top: 28px;
}
.cv-vdp-reviews-qa-title {
  font-size: 1.05rem;
  font-weight: 600;
  color: #002C5F;
  margin: 0 0 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.cv-vdp-reviews-qa-icon {
  font-size: 1rem;
}
.cv-vdp-reviews-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 16px;
}
.cv-vdp-reviews-pill {
  padding: 10px 16px;
  background: #E3F2FD;
  color: #1565c0;
  border: none;
  border-radius: 999px;
  font-size: 0.9rem;
  font-family: inherit;
  cursor: pointer;
  text-align: left;
  transition: background 0.2s, color 0.2s;
}
.cv-vdp-reviews-pill:hover {
  background: #BBDEFB;
  color: #0d47a1;
}
.cv-vdp-reviews-ask-btn {
  padding: 12px 24px;
  background: #0059ba;
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 1rem;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.2s;
}
.cv-vdp-reviews-ask-btn:hover {
  background: #004494;
}
.cv-vdp-reviews-list {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid var(--cv-gray-light);
}
.cv-vdp-review-item {
  padding: 16px;
  background: var(--cv-gray-bg);
  border-radius: 12px;
  border: 1px solid var(--cv-gray-light);
}
.cv-vdp-review-stars {
  font-size: 1rem;
  color: var(--cv-gold);
  letter-spacing: 1px;
  margin-bottom: 8px;
}
.cv-vdp-review-text {
  font-size: 0.95rem;
  color: var(--cv-text);
  line-height: 1.5;
  margin: 0 0 8px;
}
.cv-vdp-review-date {
  font-size: 0.85rem;
  color: var(--cv-text-light);
}

/* Pickup and Delivery */
.cv-vdp-pickup-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-top: 16px;
}
.cv-vdp-pickup-option {
  padding: 24px;
  background: var(--cv-gray-bg);
  border-radius: 12px;
  border: 1px solid var(--cv-gray-light);
  text-align: center;
}
.cv-vdp-pickup-icon {
  font-size: 2.5rem;
  margin-bottom: 12px;
  line-height: 1;
}
.cv-vdp-pickup-option h4 {
  font-size: 1.1rem;
  font-weight: 700;
  color: #1a2b48;
  margin: 0 0 8px;
}
.cv-vdp-pickup-option p {
  font-size: 0.95rem;
  color: var(--cv-text-light);
  margin: 0;
  line-height: 1.5;
}
.cv-vdp-ai-disclaimer {
  font-size: 0.85rem;
  color: var(--cv-text-light);
  margin: 24px 0 0;
  line-height: 1.5;
}
.cv-vdp-browse-link {
  display: inline-block;
  padding: 12px 24px;
  background: var(--cv-primary);
  color: white;
  font-size: 1rem;
  font-weight: 600;
  border-radius: var(--cv-radius-pill);
  text-decoration: none;
  margin-top: 8px;
  transition: background 0.2s;
}
.cv-vdp-browse-link:hover { background: var(--cv-primary-hover); color: white; }

/* Overview info - Looking for vehicle info + Pickup & Delivery - clean layout */
.cv-vdp-overview-info {
  margin-top: 40px;
  padding-top: 32px;
  border-top: 1px solid #e5e7eb;
  display: flex;
  flex-direction: column;
  gap: 40px;
}
.cv-vdp-overview-info-block {
  max-width: 560px;
}
.cv-vdp-overview-info-title {
  font-size: 1.2rem;
  font-weight: 700;
  color: #1a2b48;
  margin: 0 0 8px;
  letter-spacing: -0.01em;
}
.cv-vdp-overview-info-desc {
  font-size: 1rem;
  color: #4b5563;
  margin: 0 0 20px;
  line-height: 1.6;
}
.cv-vdp-overview-browse-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  background: #0059ba;
  color: white;
  font-size: 0.95rem;
  font-weight: 600;
  border-radius: 10px;
  text-decoration: none;
  transition: background 0.2s, transform 0.15s;
}
.cv-vdp-overview-browse-btn:hover {
  background: #004a9a;
  color: white;
  transform: translateY(-1px);
}
.cv-vdp-overview-pickup {
  max-width: none;
}
.cv-vdp-overview-pickup .cv-vdp-overview-info-title {
  margin-bottom: 20px;
}
.cv-vdp-overview-pickup-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
.cv-vdp-overview-pickup-card {
  background: #f8fafc;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 24px 20px;
  text-align: center;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.cv-vdp-overview-pickup-card:hover {
  border-color: #cbd5e1;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
.cv-vdp-overview-pickup-icon {
  font-size: 2rem;
  margin-bottom: 12px;
  line-height: 1;
}
.cv-vdp-overview-pickup-card h4 {
  font-size: 1.05rem;
  font-weight: 700;
  color: #1a2b48;
  margin: 0 0 8px;
}
.cv-vdp-overview-pickup-card p {
  font-size: 0.9rem;
  color: #6b7280;
  margin: 0;
  line-height: 1.5;
}

/* Pickup and Delivery - legacy */
.cv-vdp-pickup-wrap {
  display: flex;
  align-items: center;
  gap: 24px;
  margin-top: 16px;
  margin-bottom: 32px;
  flex-wrap: wrap;
}
.cv-vdp-pickup-wrap .cv-vdp-pickup-option {
  flex: 1;
  min-width: 200px;
}

/* More to Love - reference layout: orange accent, Highlights cards, Key Features columns */
.cv-vdp-card-features {
  background: #f8fafc;
}
.cv-vdp-more-accent {
  display: block;
  width: 48px;
  height: 4px;
  background: #f97316;
  border-radius: 2px;
  margin: 0 auto 16px;
}
.cv-vdp-more-title {
  text-align: center;
  font-size: 1.5rem;
  font-weight: 700;
  color: #001C3D;
  margin: 0 0 24px;
}
.cv-vdp-more-subtitle {
  font-size: 1.1rem;
  font-weight: 700;
  margin: 0 0 16px;
  color: #001C3D;
}
.cv-vdp-highlights-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-bottom: 28px;
}
.cv-vdp-highlight-card {
  background: white;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.cv-vdp-highlight-carfax-logo {
  height: 24px;
  width: auto;
  max-width: 100px;
  object-fit: contain;
}
.cv-vdp-highlight-text {
  font-size: 1rem;
  font-weight: 700;
  color: #001C3D;
  margin: 0;
}
.cv-vdp-highlight-link {
  font-size: 0.95rem;
  color: #0059ba;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: auto;
}
.cv-vdp-highlight-link:hover { text-decoration: underline; }
.cv-vdp-highlight-link svg { flex-shrink: 0; opacity: 0.8; }
.cv-vdp-highlight-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.cv-vdp-highlight-list li {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 0;
  font-size: 0.95rem;
  color: #5b6b7a;
}
.cv-vdp-check {
  color: #16a34a;
  font-weight: 700;
  flex-shrink: 0;
}
.cv-vdp-key-features-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-bottom: 24px;
}
.cv-vdp-key-cat-card {
  background: white;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  padding: 20px;
}
.cv-vdp-key-cat-icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: #E8F4FF;
  color: #0059ba;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 12px;
}
.cv-vdp-key-cat-icon svg { flex-shrink: 0; }
.cv-vdp-key-cat-title {
  font-size: 1rem;
  font-weight: 700;
  color: #001C3D;
  margin: 0 0 12px;
}
.cv-vdp-key-cat-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.cv-vdp-key-cat-list li {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 0;
  font-size: 0.95rem;
  color: #5b6b7a;
}
.cv-vdp-more-view-details {
  display: inline-block;
  padding: 12px 24px;
  background: white;
  border: 2px solid #001C3D;
  color: #001C3D;
  font-size: 1rem;
  font-weight: 600;
  text-decoration: none;
  border-radius: 999px;
  transition: background 0.2s, color 0.2s;
}
.cv-vdp-more-view-details:hover {
  background: #001C3D;
  color: white;
}
@media (max-width: 768px) {
  .cv-vdp-highlights-cards,
  .cv-vdp-key-features-grid {
    grid-template-columns: 1fr;
  }
  .cv-vdp-overview-info {
    margin-top: 32px;
    padding-top: 24px;
    gap: 32px;
  }
  .cv-vdp-overview-pickup-cards {
    grid-template-columns: 1fr;
  }
}
.cv-vdp-sell-cta {
  display: inline-block;
  padding: 12px 24px;
  background: var(--cv-primary);
  color: white;
  font-size: 1rem;
  font-weight: 600;
  border-radius: var(--cv-radius-pill);
  text-decoration: none;
  margin-top: 8px;
  transition: background 0.2s;
}
.cv-vdp-sell-cta:hover { background: var(--cv-primary-hover); color: white; }

/* Money Back Guarantee - 3 cards */
.cv-vdp-guarantee-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 20px;
  margin: 20px 0 24px;
}
.cv-vdp-guarantee-card {
  padding: 20px;
  background: var(--cv-gray-bg);
  border-radius: 12px;
  border: 1px solid var(--cv-gray-light);
}
.cv-vdp-included {
  display: inline-block;
  padding: 4px 10px;
  background: var(--cv-green);
  color: white;
  font-size: 0.75rem;
  font-weight: 700;
  border-radius: 4px;
  margin-bottom: 12px;
  text-transform: uppercase;
}
.cv-vdp-guarantee-card h4 {
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 8px;
  color: #1a2b48;
}
.cv-vdp-guarantee-card p {
  font-size: 0.9rem;
  color: var(--cv-text-light);
  margin: 0 0 8px;
  line-height: 1.5;
}

@media (max-width: 600px) {
  .cv-vdp-pickup-grid { grid-template-columns: 1fr; }
  .cv-vdp-overview-pickup-cards { grid-template-columns: 1fr; }
  .cv-vdp-reviews-card { flex-direction: column; }
}

.cv-share-save {
  background: none;
  border: none;
  font-size: 0.9rem;
  color: var(--cv-primary);
  cursor: pointer;
  font-family: inherit;
  padding: 0;
}
.cv-share-save:hover { text-decoration: underline; }
.cv-sticky-get-started {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--cv-white);
  border-top: 1px solid var(--cv-gray-light);
  padding: 12px 24px;
  z-index: 999;
  box-shadow: 0 -4px 12px rgba(0,0,0,0.08);
  align-items: center;
  gap: 12px;
}
.cv-sticky-get-started .cv-sticky-price {
  font-size: 1.25rem;
  font-weight: 800;
  margin-right: auto;
}
.cv-sticky-get-started .cv-vdp-get-started {
  max-width: none;
  padding: 12px 24px;
}
@media (max-width: 768px) {
  .cv-sticky-get-started { display: flex; }
  body.page-vehicle-body { padding-bottom: 80px; overflow-x: hidden; }
  .cv-vdp-buy-box { position: static; }
}
.related-title {
  font-size: 1.5rem;
  font-weight: 700;
  margin: 32px 0 24px;
  color: var(--cv-text);
}
body.cv-theme .product-related {
  padding: 0 24px 48px;
  max-width: var(--cv-max-width);
  margin: 0 auto;
}

/* ========== MOBILE ========== */
@media (max-width: 900px) {
  .cv-nav-toggle { display: flex; }
  .cv-header-top { flex-wrap: wrap; }
  .cv-search-wrap { order: 3; width: 100%; max-width: none; }
  .cv-nav-mobile { display: flex !important; }
  .cv-header-inner { position: relative; }
  .cv-archive-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .cv-inventory-header { padding: 16px; }
  .cv-inventory-title { font-size: 1.35rem; }
  body.cv-theme .product-layout {
    grid-template-columns: 1fr;
    padding: 16px;
  }
  body.cv-theme .product-gallery { grid-column: 1; }
  body.cv-theme .product-info { grid-column: 1; grid-row: auto; }
  body.cv-theme .product-buy { grid-column: 1; grid-row: auto; }
}
@media (max-width: 600px) {
  .cv-header-ctas { flex-wrap: wrap; }
  .cv-cta-link { padding: 8px 14px; font-size: 0.85rem; }
  .cv-hero { padding: 32px 16px 40px; }
  .cv-hero h1 { font-size: 2rem; }
  .cv-value-banner-inner { flex-direction: column; text-align: center; }
  .cv-value-tagline { text-align: center; }
  .cv-styles-grid { grid-template-columns: repeat(2, 1fr); }
  .cv-archive-grid { grid-template-columns: 1fr; gap: 12px; }
  .cv-vehicle-body { padding: 12px; }
  .cv-vehicle-title { font-size: 0.95rem; }
  .cv-vehicle-cta { padding: 8px 16px; font-size: 0.85rem; }
  .cv-interstitial-tile { padding: 20px; flex-direction: column; text-align: center; }
  .cv-inventory-toolbar { flex-direction: column; align-items: stretch; }
  .cv-filter-btn-mobile { display: block !important; }
  .cv-mobile-filter-bar { display: block; }
  body.cv-theme .product-mobile-top { display: block; }
  .cv-sticky-get-started {
    display: flex;
    align-items: center;
    gap: 12px;
  }
  body.page-vehicle-body { padding-bottom: 80px; }
  .mobile-filter-pill {
    background: var(--cv-white);
    border: 1px solid var(--cv-gray-light);
    color: var(--cv-text);
  }
  .mobile-filter-pill.is-active {
    background: var(--cv-primary);
    border-color: var(--cv-primary);
    color: white;
  }
  .mobile-filter-pill-trigger {
    background: var(--cv-white);
    border: 1px solid var(--cv-gray-light);
  }
  .mobile-filter-apply {
    background: var(--cv-primary) !important;
    border-color: var(--cv-primary) !important;
    color: white !important;
  }
}

/* ========== CLEAN OVERRIDES ========== */
body.cv-theme .container {
  max-width: var(--cv-max-width);
  padding: 0 24px;
}
body.cv-theme .flash.success {
  background: #e8f5e9;
  color: #2e7d32;
  padding: 12px 24px;
  margin: 16px auto;
  border-radius: var(--cv-radius);
}
/* Floating chat widget */
.cv-chat-fab {
  position: fixed;
  bottom: 80px;
  right: 24px;
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--cv-primary);
  color: white;
  border: none;
  border-radius: 50%;
  box-shadow: 0 4px 16px rgba(0,174,217,0.4);
  z-index: 999;
  transition: transform 0.2s, box-shadow 0.2s;
  cursor: pointer;
  text-decoration: none;
}
.cv-chat-fab:hover {
  transform: scale(1.05);
  box-shadow: 0 6px 20px rgba(0,174,217,0.5);
  color: white;
}

body.cv-theme .flash.error {
  background: #ffebee;
  color: #c62828;
  padding: 12px 24px;
  margin: 16px auto;
  border-radius: var(--cv-radius);
}

/* ========== MOBILE FIT - every page fits perfectly ========== */
html {
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
}
body.cv-theme {
  overflow-x: hidden;
  min-width: 0;
}
body.cv-theme img {
  max-width: 100%;
  height: auto;
}

@media (max-width: 768px) {
  /* Base containers - no horizontal overflow */
  body.cv-theme .container {
    padding: 0 max(16px, env(safe-area-inset-right)) 0 max(16px, env(safe-area-inset-left));
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }
  main.container {
    padding: 0 max(16px, env(safe-area-inset-right)) 0 max(16px, env(safe-area-inset-left));
  }

  /* Header */
  .cv-header-inner {
    padding: 0 max(16px, env(safe-area-inset-right)) 0 max(16px, env(safe-area-inset-left));
  }
  .cv-header-top {
    padding: 10px 0;
    gap: 12px;
  }
  .cv-logo img {
    height: 22px;
    max-height: 22px;
  }
  .cv-logo-text {
    font-size: 0.95rem;
  }
  .cv-logo-dealercanada {
    padding: 6px 10px 8px;
  }
  .cv-logo-dealercanada .cv-logo-text {
    font-size: 0.9rem;
  }
  .cv-logo-dealercanada .cv-logo-bar {
    width: 1.8em;
    height: 2px;
    top: -5px;
  }

  /* Hero */
  .cv-hero {
    padding: 32px 16px 40px;
  }
  .cv-hero h1 {
    font-size: 1.75rem;
    line-height: 1.2;
  }
  .cv-hero p {
    font-size: 1rem;
  }
  .cv-hero-search {
    padding: 0;
  }
  .cv-hero-search .cv-search-form input {
    font-size: 16px; /* prevents zoom on iOS */
  }

  /* Sections */
  .cv-section {
    padding: 24px 16px;
  }
  .cv-section-title {
    font-size: 1.25rem;
    margin-bottom: 16px;
  }
  .cv-styles-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
  .cv-style-card {
    padding: 16px 12px;
    font-size: 0.9rem;
  }
  .cv-affordable {
    padding: 24px 16px;
  }
  .cv-affordable-inner {
    flex-direction: column;
    gap: 10px;
  }
  .cv-affordable a {
    width: 100%;
    text-align: center;
  }
  .cv-trust-grid {
    grid-template-columns: 1fr;
    gap: 16px;
    margin-top: 24px;
  }
  .cv-models-wrap {
    flex-wrap: wrap;
    gap: 8px;
  }
  .cv-model-pill {
    font-size: 0.85rem;
    padding: 10px 14px;
  }

  /* Promo banner */
  .cv-promo-banner {
    padding: 12px 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    text-align: center;
  }
  .cv-promo-text {
    font-size: 0.9rem;
  }
  .cv-srp-filter-pills {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    flex-wrap: nowrap;
    padding-bottom: 4px;
  }
  .cv-srp-filter-pill {
    white-space: nowrap;
    flex-shrink: 0;
  }
  .cv-srp-applied-chips {
    flex-wrap: wrap;
  }

  /* VDP - vehicle detail - minimal padding on mobile to fit properly */
  .cv-vdp-wrap {
    padding: 12px 8px 80px;
    padding-left: max(8px, env(safe-area-inset-left));
    padding-right: max(8px, env(safe-area-inset-right));
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    overflow-x: hidden;
  }
  .cv-vdp-layout {
    gap: 20px;
    min-width: 0;
    width: 100%;
    padding: 0;
  }
  .cv-vdp-left,
  .cv-vdp-right {
    min-width: 0;
    max-width: 100%;
  }
  .cv-vdp-gallery,
  .cv-vdp-card {
    min-width: 0;
  }
  .cv-vdp-card {
    padding: 16px;
    overflow-x: hidden;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }
  .cv-vdp-card-inspection {
    width: 100%;
    max-width: 100%;
  }
  .cv-vdp-inspection-card:first-child {
    flex-direction: column;
    align-items: flex-start;
  }
  .cv-vdp-inspection-card-carfax {
    flex-direction: column;
    align-items: flex-start;
  }
  .cv-vdp-card-inspection .cv-vdp-inspection-list {
    word-wrap: break-word;
    overflow-wrap: break-word;
  }
  .cv-vdp-card-inspection .cv-vdp-inspection-list li {
    word-break: break-word;
  }
  .cv-vdp-card-tabs {
    padding: 8px 12px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .cv-vdp-tab {
    padding: 12px 14px;
    font-size: 0.85rem;
    flex-shrink: 0;
  }
  .cv-vdp-overview-cards .cv-vdp-why-card {
    flex: 0 0 100%;
    margin-right: 0;
  }
  .cv-vdp-overview-header { padding-right: 60px; }
  .cv-vdp-sections {
    margin-top: 24px;
  }
  .cv-vdp-section {
    margin-bottom: 24px;
  }
  .cv-vdp-buy-box {
    padding: 20px 16px;
    min-width: 0;
  }
  .cv-vdp-buy-title {
    font-size: 1.25rem;
    word-wrap: break-word;
  }
  .cv-vdp-buy-price-row {
    flex-wrap: wrap;
    gap: 8px;
  }
  .cv-vdp-buy-price-row > * {
    min-width: 0;
  }
  .cv-vdp-related-title {
    padding: 0 16px;
    font-size: 1.25rem;
    margin: 24px 0 16px;
    box-sizing: border-box;
  }
  .cv-vdp-related-grid {
    padding: 0 16px 32px;
    gap: 16px;
    grid-template-columns: 1fr;
    min-width: 0;
  }
  .cv-vdp-related-card {
    min-width: 0;
  }
  .cv-vdp-extra {
    padding: 24px 16px;
    margin: 24px 16px;
    border-radius: var(--cv-radius-lg);
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }
  .cv-vdp-extra-inner {
    padding: 0;
    max-width: 100%;
  }
  #vehicle-details {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .cv-vdp-spec-table td {
    word-break: break-word;
  }
  .cv-vdp-spec-table td:first-child {
    min-width: 90px;
  }

  /* SRP - vehicles index */
  .cv-srp-layout {
    padding: 16px;
    padding-left: max(16px, env(safe-area-inset-left));
    padding-right: max(16px, env(safe-area-inset-right));
  }
  .cv-srp-brandnew {
    padding: 16px;
    flex-direction: column;
    gap: 12px;
    text-align: center;
  }
  .cv-srp-brandnew-inner {
    flex-direction: column;
  }
  .cv-srp-toolbar {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }
  .cv-srp-toolbar-right {
    margin-left: 0;
    flex-wrap: wrap;
  }
  .cv-srp-grid {
    gap: 16px;
  }
  .cv-vehicle-card {
    min-width: 0;
  }

  /* Footer */
  .cv-footer-inner {
    padding: 24px 16px 32px;
  }
  .cv-footer-browse {
    grid-template-columns: 1fr;
    gap: 20px;
    padding: 20px 0;
  }
  .cv-footer-section {
    padding: 0;
  }
  .cv-footer-legal-links {
    gap: 4px 6px;
  }
  .cv-footer-legal-links a {
    font-size: 0.7rem;
  }
  .cv-footer-copyright,
  .cv-footer-address {
    font-size: 0.7rem;
    padding: 0 8px;
  }

  /* Chat FAB - safe area for notched devices */
  .cv-chat-fab {
    bottom: max(80px, env(safe-area-inset-bottom));
    right: max(24px, env(safe-area-inset-right));
  }

  /* Sticky get started - safe area */
  .cv-sticky-get-started {
    padding-left: max(16px, env(safe-area-inset-left));
    padding-right: max(16px, env(safe-area-inset-right));
    padding-bottom: max(12px, env(safe-area-inset-bottom));
  }

  /* Mobile bar - safe area */
  .cv-vdp-mobile-bar {
    padding-left: max(16px, env(safe-area-inset-left));
    padding-right: max(16px, env(safe-area-inset-right));
    padding-bottom: max(12px, env(safe-area-inset-bottom));
  }
}

/* ========== SELL PAGE - same padding & cards as main ========== */
.cm-sell-page-hero {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  min-height: 360px;
  display: flex;
  align-items: center;
  background-size: cover;
  background-position: center;
  margin-bottom: 32px;
}
.cm-sell-page-hero.has-bg::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(5,51,97,0.85) 0%, rgba(5,51,97,0.4) 50%, transparent 100%);
  pointer-events: none;
}
.cm-sell-page-hero .cm-hero-ribbon {
  display: none;
}
.cm-sell-page-hero-content {
  position: relative;
  z-index: 2;
  padding: 48px 40px;
  max-width: var(--cm-max-width);
  margin: 0 auto;
  width: 100%;
}
.cm-sell-page-hero .cm-hero-eyebrow {
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.9);
  margin: 0 0 8px;
}
.cm-sell-page-hero h1 {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 800;
  margin: 0 0 12px;
  color: #fff;
  line-height: 1.3;
}
.cm-sell-page-hero-desc {
  margin: 0;
  font-size: 1.05rem;
  color: rgba(255,255,255,0.95);
  max-width: 520px;
}
.cm-sell-form-card {
  background: var(--cm-white);
  border: 1px solid var(--cm-gray-light);
  border-radius: 20px;
  padding: 48px 40px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
.cm-sell-form-card-inner {
  max-width: 560px;
  margin: 0 auto;
  text-align: left;
}
.cm-sell-form-card .cm-section-title {
  margin-bottom: 8px;
  font-size: 1.5rem;
  font-weight: 700;
  color: #050B20;
}
.cm-sell-form-card .cm-section-subtitle {
  margin-bottom: 32px;
  font-size: 1rem;
  color: var(--cm-text-light);
  line-height: 1.5;
}
.cm-sell-page-form .cm-finance-field {
  margin-bottom: 0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}
.cm-sell-page-form .cm-finance-field label {
  display: block;
  font-size: 0.875rem;
  font-weight: 600;
  color: #374151;
  margin-bottom: 8px;
}
.cm-sell-page-form .cm-finance-field input {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  font-size: 1rem;
  font-family: inherit;
  background: var(--cm-white);
}
.cm-sell-page-form .cm-finance-field input:focus {
  outline: none;
  border-color: #0056D2;
  box-shadow: 0 0 0 2px rgba(0,86,210,0.15);
}
.cm-sell-page-form .cm-finance-field input::placeholder {
  color: #9ca3af;
}
.cm-sell-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px 24px;
  margin-bottom: 24px;
}
.cm-sell-form-grid:last-of-type { margin-bottom: 28px; }
.cm-sell-form-hint {
  display: block;
  font-size: 0.8rem;
  color: var(--cm-text-light);
  margin-top: 6px;
  line-height: 1.4;
}
.cm-sell-form-section-label {
  font-size: 0.95rem;
  font-weight: 600;
  color: #050B20;
  margin: 0 0 20px;
}
.cm-sell-form-email { grid-column: 1 / -1; }
.cm-sell-submit {
  margin-top: 4px;
  width: 100%;
  padding: 14px 24px;
  font-size: 1rem;
  font-weight: 700;
  border-radius: 10px;
}
.cm-sell-privacy-note {
  margin: 28px 0 0;
  padding-top: 24px;
  border-top: 1px solid #e5e7eb;
  font-size: 0.85rem;
  color: var(--cm-text-light);
  line-height: 1.5;
}
.cm-sell-benefit-card {
  background: var(--cm-white);
  border: 1px solid var(--cm-gray-light);
  border-radius: var(--cm-radius-xl);
  padding: 40px;
  text-align: center;
  box-shadow: 0 4px 24px rgba(0,0,0,0.08);
}
.cm-sell-benefit-tagline {
  font-size: 1.1rem;
  color: var(--cm-text-light);
  margin: 0 0 16px;
}
.cm-sell-rating {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.95rem;
  color: var(--cm-text);
}
.cm-sell-stars { color: #f59e0b; }
.cm-sell-steps-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 24px;
}
.cm-sell-step-card {
  background: var(--cm-white);
  border: 1px solid var(--cm-gray-light);
  border-radius: var(--cm-radius-xl);
  padding: 32px 24px;
  text-align: center;
  box-shadow: 0 4px 24px rgba(0,0,0,0.08);
  transition: box-shadow 0.2s;
}
.cm-sell-step-card:hover { box-shadow: 0 6px 28px rgba(0,0,0,0.1); }
.cm-sell-step-num {
  width: 48px;
  height: 48px;
  margin: 0 auto 16px;
  background: var(--cm-blue);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 1.25rem;
}
.cm-sell-step-card h3 {
  margin: 0 0 8px;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--cm-blue);
}
.cm-sell-step-card p {
  margin: 0;
  font-size: 0.95rem;
  color: var(--cm-text-light);
  line-height: 1.5;
}
.cm-sell-voucher-note {
  text-align: center;
  font-size: 0.95rem;
  color: var(--cm-text-light);
  margin: 0;
}
.cm-sell-paid-steps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-bottom: 32px;
}
.cm-sell-paid-step {
  background: var(--cm-white);
  border: 1px solid var(--cm-gray-light);
  border-radius: var(--cm-radius-lg);
  padding: 24px 20px;
  text-align: center;
  box-shadow: 0 4px 24px rgba(0,0,0,0.08);
}
.cm-sell-paid-step h3 {
  margin: 0 0 8px;
  font-size: 1rem;
  font-weight: 700;
  color: var(--cm-blue);
}
.cm-sell-paid-step p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--cm-text-light);
}
.cm-sell-amount-example {
  background: linear-gradient(135deg, #e8f4fc 0%, #d4e8f5 100%);
  border: 1px solid var(--cm-gray-light);
  border-radius: var(--cm-radius-xl);
  padding: 28px 32px;
  max-width: 360px;
  margin: 0 auto;
  text-align: center;
}
.cm-sell-amount-label {
  margin: 0 0 4px;
  font-size: 0.85rem;
  color: var(--cm-text-light);
}
.cm-sell-amount-value {
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--cm-blue);
  margin: 0 0 8px;
}
.cm-sell-amount-from, .cm-sell-amount-email {
  margin: 0;
  font-size: 0.9rem;
  color: var(--cm-text-light);
}
.cm-sell-promo-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.cm-sell-promo-card {
  background: var(--cm-white);
  border: 1px solid var(--cm-gray-light);
  border-radius: var(--cm-radius-xl);
  padding: 32px 28px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.08);
  transition: box-shadow 0.2s;
}
.cm-sell-promo-card:hover { box-shadow: 0 6px 28px rgba(0,0,0,0.1); }
.cm-sell-promo-card h3 {
  margin: 0 0 12px;
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--cm-blue);
}
.cm-sell-promo-card p {
  margin: 0 0 20px;
  font-size: 0.95rem;
  color: var(--cm-text-light);
  line-height: 1.5;
}
.cm-sell-newsletter-card {
  background: linear-gradient(135deg, #053361 0%, #0d2137 100%);
  border-radius: var(--cm-radius-xl);
  padding: 40px;
  text-align: center;
  color: #fff;
}
.cm-sell-newsletter-card h2 {
  margin: 0 0 8px;
  font-size: 1.5rem;
  font-weight: 700;
  color: #fff;
}
.cm-sell-newsletter-card p {
  margin: 0;
  font-size: 1rem;
  opacity: 0.95;
}
@media (max-width: 768px) {
  body.cm-theme main.page-sell { padding: 16px 16px 40px; }
  main.page-sell .cm-section { padding: 32px 16px; }
  .cm-sell-page-hero-content { padding: 32px 24px; }
  .cm-sell-form-card { padding: 32px 24px; }
  .cm-sell-form-card-inner { max-width: none; }
  .cm-sell-form-grid { grid-template-columns: 1fr 1fr; gap: 16px 20px; }
  .cm-sell-steps-grid { grid-template-columns: 1fr; gap: 16px; }
  .cm-sell-paid-steps-grid { grid-template-columns: 1fr; gap: 16px; }
  .cm-sell-promo-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  body.cm-theme main.page-sell { padding: 12px 12px 32px; }
  main.page-sell .cm-section { padding: 24px 12px; }
  .cm-sell-page-hero-content { padding: 24px 16px; }
  .cm-sell-form-card { padding: 24px 16px; }
  .cm-sell-form-grid { grid-template-columns: 1fr; gap: 20px; }
}

/* ========== CONTENT PAGES (how-it-works, faqs, services, contact, legal) ========== */
main.page-how-it-works .cm-section,
main.page-faqs .cm-section,
main.page-services .cm-section,
main.page-contact .cm-section,
main.page-privacy .cm-section,
main.page-conditions .cm-section,
main.page-returns .cm-section {
  max-width: var(--cm-max-width);
  margin: 0 auto;
  padding: 48px 32px;
}
.cm-page-hero-card,
.cm-page-card,
.cm-page-cta-card,
.cm-page-quote-card {
  background: var(--cm-white);
  border: 1px solid var(--cm-gray-light);
  border-radius: var(--cm-radius-xl);
  padding: 40px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.08);
}
.cm-page-hero-card .cm-section-title { margin-bottom: 8px; }
.cm-page-hero-card .cm-section-subtitle { margin-bottom: 24px; }
.cm-page-intro {
  font-size: 1rem;
  color: var(--cm-text-light);
  margin: 0 0 24px;
  line-height: 1.6;
}
.cm-page-steps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-bottom: 28px;
}
.cm-page-step-card {
  text-align: center;
  padding: 24px 16px;
  background: var(--cm-gray-bg);
  border-radius: var(--cm-radius-lg);
  border: 1px solid var(--cm-gray-light);
}
.cm-page-step-num {
  width: 40px;
  height: 40px;
  margin: 0 auto 12px;
  background: var(--cm-blue);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 1.1rem;
}
.cm-page-step-card h3 {
  margin: 0 0 8px;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--cm-blue);
}
.cm-page-step-card p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--cm-text-light);
  line-height: 1.5;
}
.cm-page-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.cm-page-card h3, .cm-page-card h4 {
  margin: 0 0 12px;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--cm-blue);
}
.cm-page-card p {
  margin: 0;
  font-size: 0.95rem;
  color: var(--cm-text-light);
  line-height: 1.6;
}
.cm-page-quote-card {
  text-align: center;
}
.cm-page-quote {
  font-size: 1.25rem;
  font-style: italic;
  color: var(--cm-text);
  margin: 0;
}
.cm-page-table-card {
  overflow-x: auto;
  border-radius: var(--cm-radius-lg);
  border: 1px solid var(--cm-gray-light);
}
.cm-page-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.95rem;
}
.cm-page-table th, .cm-page-table td {
  padding: 14px 20px;
  text-align: left;
  border-bottom: 1px solid var(--cm-gray-light);
}
.cm-page-table th {
  background: var(--cm-gray-bg);
  font-weight: 700;
  color: var(--cm-blue);
}
.cm-page-table tbody tr:last-child td { border-bottom: none; }
.cm-page-cta-card p { margin-bottom: 16px; }
.cm-page-cta-tagline { font-weight: 600 !important; color: var(--cm-blue) !important; }
.cm-page-faq-list {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.cm-page-faq-item {
  padding: 24px;
  background: var(--cm-white);
  border: 1px solid var(--cm-gray-light);
  border-radius: var(--cm-radius-lg);
  box-shadow: 0 2px 12px rgba(0,0,0,0.04);
}
.cm-page-faq-item h4 {
  margin: 0 0 12px;
  font-size: 1rem;
  font-weight: 700;
  color: var(--cm-blue);
}
.cm-page-faq-item p {
  margin: 0;
  font-size: 0.95rem;
  color: var(--cm-text);
  line-height: 1.6;
}
.cm-page-lenders-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 24px;
  margin-top: 16px;
}
.cm-page-lenders-grid span {
  padding: 8px 16px;
  background: var(--cm-gray-bg);
  border-radius: var(--cm-radius);
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--cm-blue);
}
.cm-page-tire-links,
.cm-page-brands-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 16px;
}
.cm-btn-outline {
  background: transparent !important;
  color: var(--cm-blue) !important;
  border: 2px solid var(--cm-blue) !important;
}
.cm-btn-outline:hover {
  background: var(--cm-blue-light) !important;
}
.cm-page-form .cm-finance-grid { margin-bottom: 20px; }
.cm-page-form-note {
  margin: 20px 0 0;
  padding-top: 20px;
  border-top: 1px solid var(--cm-gray-light);
  font-size: 0.85rem;
  color: var(--cm-text-light);
}
.cm-page-form-full { grid-column: 1 / -1; }
.cm-page-form-full textarea {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--cm-gray-light);
  border-radius: var(--cm-radius);
  font-family: inherit;
  font-size: 1rem;
  resize: vertical;
}
.cm-page-hours-grid {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 16px;
}
.cm-page-hour-row {
  display: flex;
  justify-content: space-between;
  padding: 12px 16px;
  background: var(--cm-gray-bg);
  border-radius: var(--cm-radius);
}
.cm-page-day { font-weight: 600; }
.cm-page-time { color: var(--cm-text-light); }
.cm-page-contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}
.cm-page-contact-info {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-top: 20px;
}
.cm-page-contact-item h3 {
  margin: 0 0 6px;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--cm-blue);
}
.cm-page-contact-item p { margin: 0; font-size: 0.95rem; }
.cm-page-offices-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.cm-page-office-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.cm-page-office-address { margin: 0 !important; }
.cm-page-office-email, .cm-page-office-phone { margin: 0 !important; font-size: 0.9rem; }
.cm-legal-card {
  max-width: 800px;
  margin: 0 auto;
}
.cm-legal-card h1 { font-size: 1.75rem; }
.cm-legal-card h2 { font-size: 1.2rem; margin: 28px 0 12px; color: var(--cm-blue); }
.cm-legal-card h3 { font-size: 1.05rem; margin: 20px 0 8px; }
.cm-legal-card p, .cm-legal-card li { font-size: 0.95rem; line-height: 1.65; margin-bottom: 12px; }
.cm-legal-card ul { margin: 12px 0; padding-left: 24px; }
.cm-legal-card a { color: var(--cm-blue); text-decoration: underline; }
.cm-legal-back { display: inline-block; margin-top: 24px; }
.cm-legal-card .legal-effective { font-size: 0.9rem; color: var(--cm-text-light); margin: 0 0 24px; }
.cm-legal-card .legal-note { font-size: 0.9rem; color: var(--cm-text-light); margin-top: 24px; padding: 16px; background: var(--cm-gray-bg); border-radius: var(--cm-radius); }
.cm-legal-card .legal-final { margin-top: 24px; font-size: 0.95rem; }
@media (max-width: 768px) {
  main.page-how-it-works .cm-section,
  main.page-faqs .cm-section,
  main.page-services .cm-section,
  main.page-contact .cm-section,
  main.page-privacy .cm-section,
  main.page-conditions .cm-section,
  main.page-returns .cm-section { padding: 32px 16px; }
  body.cm-theme main.page-how-it-works,
  body.cm-theme main.page-faqs,
  body.cm-theme main.page-services,
  body.cm-theme main.page-contact,
  body.cm-theme main.page-privacy,
  body.cm-theme main.page-conditions,
  body.cm-theme main.page-returns { padding: 16px 16px 40px; }
  .cm-page-hero-card, .cm-page-card, .cm-page-cta-card, .cm-page-quote-card { padding: 24px 20px; }
  .cm-page-steps-grid { grid-template-columns: 1fr; gap: 16px; }
  .cm-page-cards-grid { grid-template-columns: 1fr; }
  .cm-page-contact-grid { grid-template-columns: 1fr; }
  .cm-page-offices-grid { grid-template-columns: 1fr; }
  .cm-page-tire-links, .cm-page-brands-grid { flex-direction: column; }
}
@media (max-width: 480px) {
  main.page-how-it-works .cm-section,
  main.page-faqs .cm-section,
  main.page-services .cm-section,
  main.page-contact .cm-section,
  main.page-privacy .cm-section,
  main.page-conditions .cm-section,
  main.page-returns .cm-section { padding: 24px 12px; }
  body.cm-theme main.page-how-it-works,
  body.cm-theme main.page-faqs,
  body.cm-theme main.page-services,
  body.cm-theme main.page-contact,
  body.cm-theme main.page-privacy,
  body.cm-theme main.page-conditions,
  body.cm-theme main.page-returns { padding: 12px 12px 32px; }
  .cm-page-hero-card, .cm-page-card, .cm-page-cta-card, .cm-page-quote-card { padding: 20px 16px; }
}

/* Cart, checkout - cv-theme overrides */
@media (max-width: 768px) {
  body.cv-theme .cart-page {
    padding: 16px 16px 100px;
    max-width: 100%;
  }
  body.cv-theme .cart-layout {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  body.cv-theme .cart-item {
    flex-wrap: wrap;
    padding: 12px;
  }
  body.cv-theme .cart-item__thumb {
    width: 80px;
    height: 56px;
  }
  body.cv-theme .checkout-layout {
    grid-template-columns: 1fr;
    padding: 16px;
  }
}

/* Small phones - 480px and below */
@media (max-width: 480px) {
  .cv-vdp-wrap {
    padding: 12px 6px 80px;
    padding-left: max(6px, env(safe-area-inset-left));
    padding-right: max(6px, env(safe-area-inset-right));
    overflow-x: hidden;
  }
  .cv-vdp-card {
    padding: 12px;
    width: 100%;
    max-width: 100%;
  }
  .cv-vdp-buy-box {
    padding: 16px 12px;
  }
  .cv-vdp-related-grid {
    padding: 0 12px 32px;
  }
  .cv-vdp-related-title {
    padding: 0 12px;
  }
  .cv-vdp-extra {
    margin: 24px 12px;
    padding: 20px 12px;
  }
  .cv-styles-grid {
    grid-template-columns: 1fr;
  }
  .cv-hero h1 {
    font-size: 1.5rem;
  }
  body.cv-theme .container {
    padding: 0 12px;
  }
  .cv-header-inner {
    padding: 0 12px;
  }
}
