/* Loading Icon Styles */
.loading-icon {
    display: inline-block;
    animation: spin 1s linear infinite;
    margin-right: 8px;
  }
  
  .loading-icon svg {
    width: 16px;
    height: 16px;
  }
  
  @keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
  }
  
  .btn.loading {
    opacity: 0.8;
    cursor: not-allowed;
  }
  
  .btn.loading .loading-icon {
    display: inline-block;
  }
  
  /* Mobile top bar layout — two centered rows (Sales, Service) */
  @media (max-width: 768px) {
    .top-bar { padding: 4px 0 !important; }
    .top-bar-inner { flex-direction: column !important; align-items: center !important; gap: 2px !important; min-height: auto !important; padding: 0 6px !important; }
    .top-bar-left { display: none !important; }
    .top-bar-center, .top-bar-right { width: 100% !important; justify-content: center !important; text-align: center !important; gap: 4px !important; flex-wrap: nowrap !important; white-space: nowrap !important; overflow: hidden !important; }
    .top-bar .contact-link { font-size: 11px !important; padding: 0 2px !important; white-space: nowrap !important; }
    .top-bar .contact-link svg { width: 12px !important; height: 12px !important; }
    .top-bar .separator { margin: 0 3px !important; }
    /* Hide inline labels on mobile to keep each row on a single line */
    .top-bar .inline-label { display: none !important; }
  }
  /* About – full-width banner image (match home hero heights) */
  .about-hero-banner { padding: 0 40px; }
  .about-hero-img { width: 100%; height: 500px; object-fit: cover; object-position: center; border-radius: 20px; box-shadow: 0 8px 24px rgba(0,0,0,0.08); display: block; background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%); }
  @media (max-width: 992px) {
    .about-hero-img { height: 300px; }
  }
  @media (max-width: 768px) {
    .about-hero-banner { padding: 0 16px; }
  }
  @media (max-width: 600px) {
    .about-hero-img { height: 200px !important; }
  }
  /* About - New Design */
  .about-banner { background: linear-gradient(135deg, #f8fafc 0%, #ffffff 100%); padding: 24px 40px; border-bottom: 1px solid var(--border); }
  .about-banner-inner { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 24px; align-items: center; }
  .about-banner-left .about-heading { margin: 0 0 6px; font-size: 28px; font-weight: 800; color: var(--primary); }
  .about-banner-left .about-sub { margin: 0 0 12px; color: #374151; }
  .about-banner-right img { width: 100%; height: 320px; object-fit: cover; border-radius: 12px; box-shadow: 0 8px 24px rgba(0,0,0,0.08); }
  .about-cta { display: flex; gap: 10px; }
  
  /* KPI billboard */
  .about-kpi { position: relative; padding: 0 40px; background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%); }
  .about-kpi-inner { position: relative;  margin: 0 auto; background: url('assets/img/showroom.png') center/cover no-repeat; border-radius: 12px; overflow: hidden; min-height: 360px; display: grid; grid-template-rows: auto 1fr; padding: 0; }
  .kpi-left { padding: 0; }
  .kpi-rank { font-size: 140px; font-weight: 900; color: #ef4444; line-height: 0.8; margin: 0 0 8px; text-shadow: 0 6px 16px rgba(0,0,0,0.08); }
  .kpi-heading { white-space: pre-line; margin: 0 0 10px; font-size: 40px; font-weight: 800; letter-spacing: -0.5px;text-align: center; }
  .kpi-sub { margin: 0; color: #374151;text-align: left; }
  .kpi-right { align-self: end; padding: 0; }
  .kpi-panel { background: #0f172a; color: #e5e7eb; border: 1px solid #0b1226; border-radius: 14px; padding: 16px 18px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; box-shadow: 0 8px 22px rgba(15,23,42,0.35); }
  .kpi-item { text-align: center; display: grid; gap: 6px; }
  .kpi-value { font-size: 30px; font-weight: 900; letter-spacing: 1px; }
  .kpi-value span { color: #ef4444; font-weight: 900; margin-left: 2px; }
  .kpi-label { font-size: 12px; color: #9ca3af; line-height: 1.2; }
  .kpi-note { font-size: 11px; color: #6b7280; margin: 8px 6px; }
  
  .about-highlights .highlight-cards { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 14px; }
  .highlight-card { background: #fff; border: 1px solid var(--border); border-radius: 12px; padding: 16px; display: flex; align-items: center; gap: 10px; font-weight: 700; color: #111827; }
  .highlight-card i { color: var(--primary); }
  
  .about-story { text-align: left; }
  .about-story .story-content { max-width: none; margin: 0; width: 100%; }
  .story-content h2 { margin: 0 0 24px; font-size: 32px; font-weight: 800; color: #111827; }
  .story-content p { margin: 0 0 32px; color: #6b7280; font-size: 18px; line-height: 1.7; }
  .values-list { display: flex; flex-direction: column; gap: 16px; align-items: flex-start; }
  .value-item { display: flex; align-items: flex-start; gap: 16px; max-width: 500px; }
  .value-item i { color: var(--primary); font-size: 22px; margin-top: 4px; }
  .value-content strong { display: block; margin-bottom: 6px; font-size: 16px; font-weight: 700; color: #111827; }
  .value-content p { margin: 0; color: #6b7280; font-size: 14px; line-height: 1.5; }
  
  /* Enhanced Our Story aesthetics */
  .story-quote { display: flex; align-items: center; gap: 10px; background: #fff7f7; border: 1px solid #ffe0e0; color: #b30a0a; padding: 10px 12px; border-radius: 10px; margin: 8px 0 14px; font-weight: 700; }
  .story-quote i { color: var(--primary); }
  .story-cta { display: flex; gap: 10px; margin-top: 14px; justify-content: flex-start; flex-wrap: wrap; }
  .story-cta .btn { min-width: 140px; }
  
  /* Enhanced Who We Are section */
  .who-we-are-content { margin-bottom: 20px; }
  .mission-vision { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; margin: 24px 0; text-align: center; }
  .mission-section, .vision-section { padding: 24px; background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%); border-radius: 16px; border: 1px solid #e2e8f0; position: relative; overflow: hidden; }
  .mission-section::before, .vision-section::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: linear-gradient(90deg, var(--primary) 0%, #ef4444 100%); }
  .section-header { display: flex; align-items: center; justify-content: center; gap: 16px; margin-bottom: 20px; }
  .icon-wrapper { width: 60px; height: 60px; background: linear-gradient(135deg, var(--primary) 0%, #ef4444 100%); border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 16px rgba(220, 38, 38, 0.3); }
  .icon-wrapper i { color: #fff; font-size: 24px; }
  .mission-section h3, .vision-section h3 { margin: 0; font-size: 24px; font-weight: 800; color: #111827; }
  .mission-section p, .vision-section p { margin: 0; color: #6b7280; font-size: 16px; line-height: 1.7; }
  .core-principle { margin-top: 24px; padding: 24px; background: #f8fafc; border-radius: 12px; border: 1px solid #e2e8f0; text-align: center; }
  .core-principle h4 { margin: 0 0 12px; font-size: 20px; font-weight: 700; color: #1e293b; display: flex; align-items: center; justify-content: center; gap: 12px; }
  .core-principle h4 i { color: var(--primary); font-size: 22px; }
  .core-principle p { margin: 0; color: #475569; font-size: 15px; line-height: 1.6; }
  
  @media (max-width: 768px) {
    .mission-vision { grid-template-columns: 1fr; gap: 24px; }
    .core-principle { padding: 20px; }
    .story-cta { flex-direction: column; gap: 12px; align-items: stretch; }
    .story-cta .btn { width: 100%; text-align: center; max-width: none; }
    .about-story .story-content { margin: 0; }
  }
  
  /* Redesigned Values section (6 cards in a bordered white panel) */
  .values-section { padding: 32px 40px; background: linear-gradient(180deg, #ffffff 0%, #f9fafb 100%); }
  .values-card { background: transparent; border-radius: 0; box-shadow: none; border: 0; padding: 32px 0; position: relative; overflow: visible; max-width: 1160px; margin: 0 auto; }
  .values-card::before { content: none; }
  .values-title { margin: 0 0 6px; text-align: center; font-size: 32px; font-weight: 900; color: #111827; letter-spacing: -0.3px; }
  .values-title::after { content: ''; display: block; width: 84px; height: 3px; margin: 10px auto 0; background: linear-gradient(90deg, var(--primary) 0%, #ef4444 100%); border-radius: 2px; }
  .values-subtitle { margin: 8px 0 24px; text-align: center; color: #64748b; font-weight: 600; }
  /* Match Why Choose Us card style */
  .values-grid-6 { display: grid; grid-template-columns: repeat(3, minmax(280px, 1fr)); gap: 28px; justify-content: center; justify-items: center; }
  .value6 { 
    width: 100%;
    max-width: 320px;
    min-height: 260px; /* consistent height for elegance */
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    border-radius: 16px;
    border: 1px solid #eef2f7;
    box-shadow: 0 6px 18px rgba(0,0,0,0.06);
    padding: 18px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  }
  .value6-icon { 
    height: 72px; width: 72px; margin: 0 auto 12px auto;
    background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%) padding-box,
                linear-gradient(135deg, #e5e7eb, #ffffff) border-box;
    border: 1px solid transparent; border-radius: 16px; color: var(--primary);
    box-shadow: 0 6px 18px rgba(0,0,0,0.06), inset 0 0 0 6px rgba(236, 72, 72, 0.03);
    font-size: 28px; display: flex; align-items: center; justify-content: center;
  }
  .value6-title { margin: 2px 0 8px; font-size: 18px; font-weight: 800; color: #0f172a; text-align: center; letter-spacing: .2px; }
  .value6-text { margin: 0; color: #475569; font-size: 14px; line-height: 1.7; text-align: center; max-width: 90%; }
  .value6:hover { transform: translateY(-6px); box-shadow: 0 16px 40px rgba(0,0,0,0.14); border-color: #e2e8f0; }
  
  /* Gentle fade/slide for elegance */
  .values-grid-6 .value6 { opacity: 0; transform: translateY(16px); animation: values-in 0.5s ease-out forwards; }
  .values-grid-6 .value6:nth-child(1) { animation-delay: 0.02s; }
  .values-grid-6 .value6:nth-child(2) { animation-delay: 0.08s; }
  .values-grid-6 .value6:nth-child(3) { animation-delay: 0.14s; }
  .values-grid-6 .value6:nth-child(4) { animation-delay: 0.20s; }
  .values-grid-6 .value6:nth-child(5) { animation-delay: 0.26s; }
  .values-grid-6 .value6:nth-child(6) { animation-delay: 0.32s; }
  @keyframes values-in { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }
  
  @media (max-width: 992px) { .values-section { padding: 24px 40px; } .values-title { font-size: 28px; } .values-grid-6 { grid-template-columns: repeat(2, minmax(260px, 1fr)); gap: 24px; } .value6 { max-width: 340px; min-height: 250px; } }
  @media (max-width: 768px) { .values-section { padding: 24px 16px; } .values-title { font-size: 24px; } .values-grid-6 { grid-template-columns: 1fr; gap: 16px; } .values-card { padding: 20px; } .value6 { width: 100%; max-width: 420px; min-height: 240px; } }
  @media (max-width: 992px) {
    .about-banner-inner { grid-template-columns: 1fr; }
    .about-highlights .highlight-cards { grid-template-columns: repeat(2, minmax(0,1fr)); }
  
    .values-grid { grid-template-columns: 1fr 1fr; }
    .kpi-panel { grid-template-columns: repeat(2, 1fr); }
  }
  
  @media (max-width: 768px) {
    .about-kpi { padding: 0 16px; }
    .about-banner { padding: 16px; }
    .about-banner-left .about-heading { font-size: 24px; }
    .about-highlights .highlight-cards { grid-template-columns: 1fr; }
    .values-grid { grid-template-columns: 1fr; }
    .kpi-rank { font-size: 96px; }
    .kpi-heading { font-size: 28px; }
    .kpi-panel { grid-template-columns: 1fr; }
  }
  :root {
    --bg: #ffffff;
    --panel: #ffffff;
    --panel-alt: #f8fafc;
    --text: #111827;
    --muted: #6b7280;
    --primary: #dc0b0b;
    --primary-600: #b30a0a;
    --accent: #6ea8fe;
    --ring: #1d4ed820;
    --border: #e5e7eb;
    --card: #f5f5f5;
    --success: #22c55e;
  }
  
  * { box-sizing: border-box; }
  html, body { height: 100%; }
  body {
    margin: 0;
    font-family: var(--font-family-primary);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    font-kerning: normal;
    background: #ffffff;
    color: var(--text);
    line-height: 1.6;
    padding-top: 104px; /* Updated to account for both top bar and header */
    scroll-behavior: smooth;
  }
  img { max-width: 100%; display: block; }
  .container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
  .small { font-size: 12px; }
  .muted { color: var(--muted); }
  .link { color: var(--accent); text-decoration: none; }
  .link:hover { text-decoration: underline; }
  
  
  a.brand-link {
    text-decoration: none !important;
    border: none !important;
  }
  
  a.brand-link:hover {
    text-decoration: none !important;
    border: none !important;
  }
  
  /* Top Bar Styles */
  .top-bar {
    background: linear-gradient(315deg, #dc0b0b 0%, #b30a0a 50%, #8f0808 100%);
    color: white;
    padding: 4px 0;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 101;
    width: 100%;
  }
  
  /* Match top bar horizontal padding with header/nav (40px gutters) */
  .top-bar .container {
    max-width: none;
    margin-left: 0;
    margin-right: 0;
    padding-left: 40px;
    padding-right: 40px;
  }
  
  .top-bar-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 12px;
    font-weight: 500;
    min-height: 32px;
    width: 100%;
    padding-left: 40px; /* align with header inner gutter */
    padding-right: 40px; /* align with header inner gutter */
  }
  
  .top-bar-left {
    display: flex;
    gap: 12px;
    flex: 0 0 auto;
    align-items: center;
    justify-content: flex-start;
    min-width: 120px;
  }
  
  /* Desktop-only micro alignment to match brand text start */
  @media (min-width: 769px) {
    .top-bar-left { margin-left: 0; }
  }
  
  .social-link {
    color: white;
    text-decoration: none;
    display: flex;
    align-items: center;
    transition: all 0.2s ease;
    padding: 4px;
    border-radius: 4px;
  }
  
  /* Align first icon edge with brand text start */
  .top-bar-left .social-link:first-child { padding-left: 0; }
  
  .social-link:hover {
    opacity: 0.8;
    background: rgba(255, 255, 255, 0.1);
  }
  
  .top-bar-center {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
    justify-content: flex-end;
    text-align: right;
    max-width: none;
    margin-right: 20px;
  }
  
  .top-bar-right {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 0 0 auto;
    justify-content: flex-end;
    min-width: 280px;
  }
  
  .contact-link {
    color: white;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 6px;
    transition: all 0.2s ease;
    padding: 4px 8px;
    border-radius: 4px;
  }
  
  .contact-link:hover {
    opacity: 0.8;
    background: rgba(255, 255, 255, 0.1);
  }
  
  .separator {
    color: rgba(255, 255, 255, 0.8);
    font-weight: 400;
    margin: 0 6px;
  }
  
  /* Updated Header Styles */
  .site-header { 
    position: fixed; 
    top: 40px; /* Position below top bar */
    left: 0; 
    right: 0; 
    z-index: 100; 
    background: #ffffff; 
  }
  
  @media (max-width: 720px) {
    .site-header {
      top: 48px !important; /* Increased to account for taller stacked top bar */
      height: 56px !important; /* Smaller header height on mobile */
    }
  }
  
  .header-inner { 
    display: flex; 
    align-items: center; 
    justify-content: flex-start; 
    height: 64px;
    width: 100%;
    padding: 0 40px;
    gap: 40px;
  }
  /* Ensure brand text starts exactly at the 40px gutter (same as hero) */
  .site-header .brand,
  .site-header .brand-text,
  .site-header .brand-name {
    margin-left: 0 !important;
    padding-left: 0 !important;
  }
  
  .brand { 
    display: flex; 
    align-items: center;
    flex: 0 0 auto;
    min-width: 0; /* allow brand to sit exactly at the left gutter */
  }
  
  .brand-text {
    display: flex;
    align-items: center;
    gap: 8px; /* tighter spacing to align visually with hero edge */
  }
  
  .brand-name { 
    font-weight: 800; 
    font-size: 24px; 
    letter-spacing: 0.2px; 
    color: var(--primary);
    text-decoration: none;
    white-space: nowrap;
  }
  
  .brand-divider {
    width: 1px;
    height: 40px;
    background: #d1d5db;
    margin: 0 4px; /* reduce gap so text hugs the 40px gutter */
  }
  
  .honda-logo {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
  }
  
  .honda-logo img {
    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.1));
    border-radius: 4px;
    max-width: 100%;
    height: auto;
    display: block;
  }
  
  .honda-text {
    font-size: 12px;
    font-weight: 700;
    color: #111827;
    letter-spacing: 1px;
    text-align: center;
  }
  
  .btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; border: 1px solid var(--border); background: #f9fafb; color: var(--text); padding: 12px 16px; border-radius: 8px; text-decoration: none; font-weight: 600; transition: transform 0.1s ease, background 0.2s ease, border-color 0.2s ease; min-height: 44px; line-height: 1; }
  .btn-primary, .btn-ghost { min-height: 44px; line-height: 1; padding-top: 12px; padding-bottom: 12px; }
  .btn-ghost { border-width: 1px; }
  
  /* Normalize button heights inside form action rows */
  .form-actions .btn { height: 44px; min-height: 44px; padding-top: 0; padding-bottom: 0; line-height: 1; }
  .form-actions .btn-primary, .form-actions .btn-ghost { height: 44px; }
  .btn:hover { transform: translateY(-1px); border-color: var(--ring); }
  .btn:active { transform: translateY(0); }
  .btn-small { padding: 8px 12px; font-size: 14px; }
  .btn-primary { background: linear-gradient(315deg, #dc0b0b 0%, #b30a0a 50%, #8f0808 100%); border-color: transparent; color: #ffffff; }
  .btn-primary:hover { background: #475569; }
  .btn-secondary { background: #eef2ff; }
  .btn-ghost { background: transparent; }
  .btn-ghost:hover, .btn-ghost:focus { background: #f3f4f6; border-color: #e5e7eb; }
  
  .badge { margin-left: 10px; padding: 4px 8px; border-radius: 20px; font-size: 11px; background: #eef2ff; border: 1px solid var(--border); color: var(--muted); }
  .pill { display: inline-block; padding: 6px 10px; border-radius: 999px; background: #eff6ff; border: 1px solid var(--border); margin-right: 8px; font-size: 12px; }
  
  /* Enhanced navigation styles */
  .site-nav { 
    position: relative;
    margin-left: auto;
    flex: 1;
    display: flex;
    justify-content: flex-end;
  }
  
  .nav-toggle { 
    display: none; /* Hidden by default on desktop */
    background: transparent; 
    border: 0; 
    padding: 8px; 
    border-radius: 10px; 
    cursor: pointer;
    position: relative;
    z-index: 100;
    min-width: 44px;
    min-height: 44px;
  }
  
  .nav-toggle:focus-visible { 
    outline: 2px solid var(--accent); 
  }
  
  .nav-toggle .bar { 
    display: block; 
    width: 22px; 
    height: 3px; 
    background: #111827; /* Dark bars on transparent background */
    margin: 3px 0; 
    border-radius: 2px; 
    transition: all 0.3s ease;
  }
  
  .nav-menu { 
    display: flex; 
    align-items: center; 
    gap: 16px; 
    list-style: none; 
    margin: 0; 
    padding: 0;
    height: 100%;
    justify-content: flex-end;
  }
  
  /* Dropdown styles */
  .nav-menu li.has-dropdown { position: relative; }
  .nav-menu li.has-dropdown > a::after { content: none; }
  .dropdown-menu { display: none; position: absolute; top: 100%; left: 0; background: #ffffff; border: 1px solid var(--border); border-radius: 8px; box-shadow: 0 6px 18px rgba(0,0,0,0.08); padding: 8px 0; min-width: 180px; z-index: 1000; }
  .dropdown-menu li { display: block; height: auto; }
  .dropdown-menu a { display: block; padding: 10px 14px; font-weight: 600; color: #111827; }
  .dropdown-menu a:hover { background: #f8fafc; color: var(--primary); }
  .nav-menu li.has-dropdown:hover > .dropdown-menu { display: block; }
  
  /* Prevent full-width hover background on BOOKING parent */
  .nav-menu li.has-dropdown > a:hover { background: transparent; }
  
  @media (max-width: 768px) {
    .nav-menu li.has-dropdown { width: 100%; display: flex; flex-direction: column; align-items: stretch; }
    .dropdown-menu { position: static; border: none; box-shadow: none; padding: 4px 0 8px 0; min-width: 0; display: none; background: transparent; }
    .dropdown-menu a { padding: 8px 14px 8px 24px; }
    .nav-menu li.has-dropdown.open > .dropdown-menu { display: block; }
    /* Override mobile hover fill for BOOKING */
    .nav-menu li.has-dropdown > a:hover { background: transparent !important; color: inherit; }
  }
  
  /* Ensure navbar horizontal alignment matches hero on desktop */
  @media (min-width: 769px) {
    .site-header .header-inner,
    .site-header .nav-menu {
      padding-left: 40px !important;
      padding-right: 40px !important;
    }
  }
  
  .nav-menu li {
    display: flex;
    align-items: center;
    height: 100%;
  }
  
  .nav-menu a { 
    color: #111827; 
    text-decoration: none; 
    font-weight: 600; 
    font-size: 14px; 
    letter-spacing: 0.3px; 
    transition: all 0.2s ease; 
    padding: 8px 6px;
    position: relative;
    height: 100%;
    display: flex;
    align-items: center;
    white-space: nowrap;
  }
  
  .nav-menu a:hover { 
    color: var(--primary); 
  }
  
  .nav-menu a:not(.btn).active { 
    color: var(--primary); 
  }
  
  .nav-menu a:not(.btn)[aria-current="page"] { 
    color: var(--primary); 
  }
  
  .nav-menu a:not(.btn):hover::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--primary);
    border-radius: 1px;
  }
  
  /* Ensure nav primary button has white text over red background */
  .nav-menu a.btn-primary { 
    color: #ffffff; 
  }
  
  /* Why Choose Us Section */
  .why-choose { padding: 32px 40px 40px 40px; background: #f8fafc; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
  .why-grid { display: grid; grid-template-columns: 1fr; align-items: start; gap: 24px; }
  .why-left { text-align: center; display: block; }
  .why-title { font-size: 32px; line-height: 1.2; font-weight: 800; color: var(--primary); margin: 0; text-align: center; }
  .why-right { width: 100%; }
  .why-cards { display: grid; grid-template-columns: repeat(4, minmax(160px, 1fr)); gap: 32px; align-items: start; justify-content: start; }
  .why-column { display: contents; }
  .why-column.stagger { margin-top: 0; }
  .why-card { 
    width: 100%;
    aspect-ratio: 16 / 11;
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    border-radius: 16px;
    border: 1px solid #eef2f7;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.06);
    padding: 18px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  }
  .why-card-icon { display: flex; align-items: center; justify-content: center; height: 72px; width: 72px; margin: 0 auto 12px auto; background: linear-gradient(135deg, #eef2ff 0%, #ffffff 100%); border: 1px solid #e5e7eb; border-radius: 16px; color: var(--primary); box-shadow: 0 4px 12px rgba(0,0,0,0.06); }
  .why-card-icon i { font-size: 30px; }
  .why-card-title { margin: 0 0 6px 0; font-size: 18px; font-weight: 800; color: #0f172a; text-align: center; letter-spacing: .2px; }
  .why-card-text { margin: 0; color: #475569; font-size: 14px; line-height: 1.6; text-align: center; }
  /* Stagger top alignment like previous design */
  .why-cards { align-items: start; }
  .why-cards .why-card:nth-child(2) { margin-top: 72px; }
  .why-cards .why-card:nth-child(3) { margin-top: 72px; }
  /* Ensure Genuine Parts (2) matches Widespread Branch (3) height */
  .why-cards .why-card:nth-child(2),
  .why-cards .why-card:nth-child(3) { min-height: 260px; }
  .why-card:hover { transform: translateY(-6px); box-shadow: 0 14px 36px rgba(0,0,0,0.12); border-color: #e2e8f0; }
  
  /* About page: keep all why-cards on a single straight line (no stagger) */
  main#about .why-cards .why-card:nth-child(2),
  main#about .why-cards .why-card:nth-child(3) { margin-top: 0 !important; min-height: 260px; }
  @media (min-width: 993px) {
    /* About page: enforce equal card heights on desktop */
    main#about .why-cards .why-card { height: 260px; }
  }
  
  @media (max-width: 992px) {
    .why-title { font-size: 32px; }
    .why-cards { grid-template-columns: repeat(2, minmax(160px, 1fr)); gap: 24px; }
    .why-card { aspect-ratio: 16 / 11; }
    .why-cards .why-card:nth-child(2) { margin-top: 24px; }
    .why-cards .why-card:nth-child(3) { margin-top: 48px; }
    .why-cards .why-card:nth-child(2),
    .why-cards .why-card:nth-child(3) { min-height: 240px; }
    .why-column.stagger { margin-top: 48px; }
  }
  
  @media (max-width: 768px) {
    .why-choose { padding: 24px 16px; }
    .why-grid { grid-template-columns: 1fr; gap: 16px; }
    .why-right { justify-content: flex-start; width: 100%; }
    .why-title { font-size: 32px; }
    .why-cards { grid-template-columns: 1fr; gap: 16px; }
    .why-card { aspect-ratio: 16 / 11; width: 100%; }
    .why-cards .why-card:nth-child(2),
    .why-cards .why-card:nth-child(3),
    .why-cards .why-card:nth-child(4) { margin-top: 0; }
    .why-cards .why-card:nth-child(2),
    .why-cards .why-card:nth-child(3) { min-height: 220px; }
    .why-column.stagger { margin-top: 0; }
  }
  
  .hero { 
    padding: 0 40px;
    /*padding: 0 ;*/
    margin: 0; 
    scroll-margin-top: 104px;
     /* Account for fixed header height */
  }
  
  #home {
    scroll-margin-top: 104px; /* Account for fixed header */
    padding-top: 0;
  }
  /*.hero-banner { width: 100%; height: 500px; position: relative; overflow: hidden; }*/
  .hero-banner {
    width: 100%;
    height: 500px;
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);
    
    /* Rounded corners */
    border-radius: 20px; /* adjust to make more/less curved */
  }
  
  
  .hero-banner-image {
    width: 100%;
    height: 500px;
    object-fit: cover;
    object-position: center;
    border-radius: 20px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
    display: block;
  }
  /* Responsive: single column if small screen OR image removed */
  @media (max-width: 768px) {
    .hero { 
      padding: 0 16px;
      /*padding: 0 ;*/
      margin: 0; 
      scroll-margin-top: 104px;
       /* Account for fixed header height */
    }
  }
  
  /* Top bar: stack email and phones on two lines on mobile */
  @media (max-width: 768px) {
    .top-bar-inner {
      flex-direction: column !important;
      justify-content: center !important;
      align-items: center !important;
      gap: 4px !important;
      text-align: center !important;
    }
    .top-bar-left { display: none !important; }
    .top-bar-center { 
      justify-content: center !important; 
      text-align: center !important; 
      margin-right: 0 !important; 
      width: 100% !important; 
      white-space: normal !important; 
      overflow: visible !important; 
      flex-wrap: wrap !important;
      gap: 6px !important;
    }
    .top-bar-right { 
      justify-content: center !important; 
      text-align: center !important; 
      width: 100% !important; 
      white-space: normal !important; 
      overflow: visible !important; 
      flex-wrap: wrap !important;
      gap: 6px !important;
    }
    .top-bar-center .contact-link, 
    .top-bar-right .contact-link {
      font-size: 12px !important;
      line-height: 1.4 !important;
      padding: 2px 6px !important;
    }
  }
  .accent { color: var(--accent); }
  
  /* Hero slider */
  .hero-slider { position: relative; overflow: hidden; max-width: 100%; }
  .hero-slide { width: 100%; }
  .hero-slide[hidden] { display: none !important; }
  .hero-controls { position: absolute; inset: 0; display: flex; align-items: center; justify-content: space-between; pointer-events: none; z-index: 10; }
  .hero-prev, .hero-next { pointer-events: auto; background: rgba(0, 0, 0, 0.6); border: 2px solid rgba(255, 255, 255, 0.3); color: white; width: 50px; height: 50px; border-radius: 50%; display: grid; place-items: center; font-size: 24px; cursor: pointer; margin: auto 20px; transition: all 0.3s ease; }
  .hero-prev:hover, .hero-next:hover { background: rgba(0, 0, 0, 0.8); border-color: rgba(255, 255, 255, 0.6); transform: scale(1.1); }
  .hero-dots { position: absolute; left: 0; right: 0; bottom: 20px; display: flex; gap: 8px; justify-content: center; z-index: 10; }
  .hero-dots button { width: 12px; height: 12px; border-radius: 999px; border: 2px solid rgba(255, 255, 255, 0.6); background: rgba(255, 255, 255, 0.3); cursor: pointer; padding: 0; transition: all 0.3s ease; }
  .hero-dots button[aria-selected="true"] { background: white; border-color: white; width: 24px; }
  
  /* Welcome Section */
  .welcome-section {
    padding: 40px 40px;
    background: linear-gradient(135deg, #f8fafc 0%, #ffffff 100%);
    border-bottom: 1px solid var(--border);
  }
  
  .welcome-content {
    text-align: left;
    max-width: 100%;
    margin: 0;
    width: 100%;
  }
  
  .welcome-title {
    font-size: 2rem;
    font-weight: 800;
    color: var(--primary);
    margin-bottom: 32px;
    line-height: 1.2; /* ✅ fixed from 0.5, was too squashed */
    letter-spacing: -0.02em;
    text-align: left; /* ✅ centers the title */
  }
  
  
  .welcome-text {
    display: flex;
    flex-direction: column;
    gap: 24px;
  }
  
  .welcome-paragraph {
    font-size: 1.125rem;
    line-height: 1.7;
    color: #374151;
    margin: 0;
    font-weight: 400;
  }
  /* Layout grid */
  /* Layout grid */
  .welcome-grid {
    display: grid;
    grid-template-columns: 1fr 1fr; /* two equal halves */
    align-items: center;
    gap: 40px;
  }
  
  /* Image on the left */
  .welcome-image {
    display: flex;
    justify-content: flex-start; /* push image to left edge */
  }
  
  .welcome-image img {
    max-width: 100%;
    height: auto;
    border-radius: 12px;
    object-fit: cover;
  }
  
  /* Text on the right */
  .welcome-content {
    text-align: left;
  }
  
  
  /* Responsive: single column if small screen OR image removed */
  @media (max-width: 768px) {
    .welcome-grid {
      grid-template-columns: 1fr; /* text takes full width */
      text-align: center; /* optional: center text on small screens */
    }
  
    .welcome-image {
      display: none; /* hide image completely on mobile */
    }
  }
  
  
  .section { padding: 32px 40px 56px 40px; scroll-margin-top: 30px; }
  .section.alt { background: #f8fafc; border-bottom: 1px solid var(--border); }
  .section.contact { background: linear-gradient(135deg, #f8fafc 0%, #ffffff 100%); }
  .section-head { margin-bottom: 20px; text-align: center; }
  .section-head h2 { margin: 0 0 8px; font-size: 32px; }
  .section-head p { margin: 0; color: var(--muted); }
  
  /* Mobile gutters for all sections (matches hero/nav) */
  @media (max-width: 768px) {
    .section { padding: 32px 16px 48px 16px; }
  }
  
  @media (max-width: 480px) {
    .section { padding: 24px 16px 32px 16px; }
  }
  
  .tabs { display: flex; gap: 8px; margin: 12px 0 20px; flex-wrap: wrap; }
  .tab { background: #ffffff08; border: 1px solid var(--border); color: var(--text); padding: 8px 12px; border-radius: 8px; cursor: pointer; }
  .tab.active { outline: 2px solid var(--ring); }
  
  .grid { display: grid; gap: 16px; }
  .cards { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .features { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .locations { grid-template-columns: repeat(1, minmax(0, 1fr)); }
  
  .card { background: var(--card); border: 1px solid var(--border); border-radius: 12px; padding: 16px; }
  .card h3 { margin: 0 0 8px; }
  .card .meta { display: flex; flex-wrap: wrap; gap: 8px; margin: 12px 0; }
  .card .meta span { background: #ffffff08; border: 1px solid var(--border); padding: 4px 8px; border-radius: 8px; font-size: 12px; color: var(--muted); }
  
  /* About Page */
  .about-hero { display: grid; grid-template-columns: 1.2fr 0.8fr; gap: 20px; align-items: start; padding: 0; }
  .about-hero-text { display: grid; gap: 10px; }
  .about-title { margin: 0; font-size: 24px; font-weight: 800; color: var(--primary); }
  .about-lead { margin: 0; color: #374151; font-size: 16px; line-height: 1.6; }
  .about-bullets { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 16px; margin-top: 6px; }
  .about-bullet { display: inline-flex; align-items: center; gap: 8px; color: #111827; font-weight: 600; font-size: 14px; }
  .about-bullet i { color: var(--primary); }
  .about-hero-media img { width: 100%; max-height: 360px; height: 100%; object-fit: cover; border-radius: 12px; box-shadow: 0 10px 24px rgba(0,0,0,0.08); }
  
  .about-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; margin-top: 12px; }
  .about-card { background: #fff; border: 1px solid var(--border); border-radius: 12px; padding: 20px; box-shadow: 0 6px 16px rgba(0,0,0,0.06); }
  .about-card h3 { margin: 0 0 8px; font-size: 18px; color: #111827; }
  .about-card p { margin: 0; color: #374151; line-height: 1.7; }
  .about-list { margin: 0; padding-left: 18px; color: #374151; line-height: 1.8; }
  
  /* Tighter gutters for About section only */
  main#about .section { padding-top: 24px; }
  
  @media (max-width: 992px) {
    .about-hero { grid-template-columns: 1fr; gap: 16px; }
    .about-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
  }
  
  @media (max-width: 768px) {
    .about-bullets { grid-template-columns: 1fr; }
    .about-grid { grid-template-columns: 1fr; gap: 12px; }
    main#about .section { padding-top: 16px; }
  }
  
  .cta-row { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 14px; }
  
  .features .feature { background: #f3f4f6; border: 1px dashed var(--border); padding: 16px; border-radius: 12px; }
  
  /* Header top dark section */
  .stats-section {
    margin: 32px 0 64px 0;
    padding: 0 40px;
    font-family: 'Arial', sans-serif;
    position: relative;
  }
  
  .test-drive-buttons {
    display: grid;
    grid-auto-flow: column;
    grid-template-columns: auto auto auto;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin-top: 14px;
  }
  @media (max-width: 576px) {
    .test-drive-buttons {
      grid-auto-flow: row;
      grid-template-columns: 1fr; /* stack vertically: button, OR, button */
      gap: 10px;
    }
    .test-drive-buttons .btn { width: 100%; }
    .test-drive-buttons p { margin: 0 4px; text-align: center; }
  }
  
  #milestones{
    margin-top: 64px;
  }
  
  /* Header dark section */
  .stats-header {
    background: #1e2a39;
    border-radius: 8px;
    position: relative;
    height: auto; /* allow header to expand with content */
    min-height: 220px; /* ensure adequate space on desktop */
    display: flex;
    justify-content: flex-start; /* allow space on left */
    align-items: flex-start;
    padding-top: 30px ; 
    padding-bottom: 28px; /* extra breathing room below button */
    margin: 0;
    box-sizing: border-box;
    z-index: 2; /* Keep header content (title/button) above overlapping stats cards */
  }
  
  /* Subtitle inside the blue header (make white and slightly larger) */
  /* Stronger override to beat global p{ color: #000 !important; } */
  #home .stats-header p,
  .stats-header p {
    color: #ffffff !important;
    font-size: 18px;
    margin: 6px 0 0 0;
    text-align: center;
  }
  
  
  .stats-header-left h2 {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 8px;
  }
  
  .stats-header-left p {
    margin: 0 0 16px;
    color: #d1d5db;
    font-size: 15px;
  }
  
  .btn-primary {
    background: linear-gradient(315deg, #dc0b0b 0%, #b30a0a 50%, #8f0808 100%);
    color: #fff;
    padding: 12px 28px;
    border-radius: 25px;
    text-decoration: none;
    font-weight: 600;
    display: inline-block;
  }
  
  .stats-header-right {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 16px;
  }
  
  .stats-header-right small {
    display: block;
    color: #d1d5db;
    font-size: 13px;
    margin-bottom: 2px;
  }
  
  .stats-header-right strong {
    font-size: 22px;
    font-weight: 700;
  }
  
  /* Stats grid - overlaps header */
  .stats-inner {
    display: grid;
    grid-template-columns: repeat(4, minmax(160px, 1fr));
    gap: 32px;
    width: 90%;
    margin: 18px auto 0; /* add breathing room between heading and cards */
    position: static; /* remove overlap behavior */
    align-items: start;
  }
  
  /* Stats heading uses shared .section-head and .why-title styles */
  .stats-section .section-head { margin: 10px auto 10px; text-align: center; }
  .stats-section .section-head .why-title { position: relative; display: inline-block; margin-bottom: 8px; }
  .stats-section .section-head .why-title::after {
    content: '';
    display: block;
    width: 84px;
    height: 3px;
    margin: 10px auto 0;
    background: linear-gradient(90deg, var(--primary) 0%, #ef4444 100%);
    border-radius: 2px;
  }
  .stats-section .section-head p { color: #475569; font-weight: 600; margin: 0; }
  
  @media (max-width: 768px) {
    .stats-section { margin: 32px 0 48px 0; padding: 0 16px; }
    .stats-inner { gap: 16px; width: 95%; margin-top: 10px; }
  }
  
  /* Tablet - 2 columns */
  @media (max-width: 992px) {
    .stats-inner {
      grid-template-columns: repeat(2, 1fr);
      bottom: -60%; /* adjust overlap spacing */
    }
    .stats-section { margin: 40px 0 80px 0; }
    .stats-header {
      background: #1e2a39;
      border-radius: 8px;
      position: relative;
      height: auto;
      min-height: 140px;
      display: flex;
      justify-content: center;
      align-items: center;
      padding: 25px 20px;
      margin: 0; /* align with section gutters */
      box-sizing: border-box;
    }
    .stats-section { padding: 0 16px; }
    .stats-header-inner {
      width: 100%;
      text-align: center;
    }
    .stats-buttons {
      display: flex;
      justify-content: center;
      gap: 15px;
      flex-wrap: wrap;
    }
    .btn-primary, .btn-outline {
      padding: 12px 24px;
      font-size: 15px;
    }
    /* Tablet: scale stats typography */
    .stat-value { font-size: 30px; }
    .stat-plus { font-size: 30px; }
    .stat-label { font-size: 13px; }
    .stats-header-left h2 { font-size: 24px; }
    .stats-header-left p { font-size: 14px; }
  }
  
  /* Mobile - force 1 column */
  @media (max-width: 576px) {
    .stats-inner {
      grid-template-columns: 1fr !important; /* force single column */
      gap: 16px;
      width: 95%;
      position: static;   /* remove absolute so they flow normally */
      margin: 20px auto 0;
      transform: none;
    }
    .stats-section { margin: 32px 0 48px 0; }
    .stats-header {
      background: #1e2a39;
      border-radius: 8px;
      position: relative;
      height: auto;
      min-height: 120px;
      display: flex;
      justify-content: center;
      align-items: center;
      padding: 20px 15px;
      margin: 0; /* align with section gutters */
      box-sizing: border-box;
    }
    .stats-section { padding: 0 16px; }
    .stats-header-inner {
      width: 100%;
      text-align: center;
    }
    .stats-buttons {
      display: flex;
      flex-direction: column;
      gap: 12px;
      align-items: center;
      width: 100%;
    }
    .btn-primary, .btn-outline {
      width: 100%;
      max-width: 280px;
      text-align: center;
      padding: 14px 20px;
      font-size: 16px;
    }
    .stat {
      padding: 20px 12px;
    }
    .stat-value { font-size: 22px; }
    .stat-plus { font-size: 22px; }
    .stat-label { font-size: 10.5px; }
    .btn-primary, .btn-outline { font-size: 13px; padding: 10px 18px; }
    .stats-header-left h2 { font-size: 20px; }
    .stats-header-left p { font-size: 12px; }
  }
  
  /* Phones and small tablets: additional scaling */
  @media (max-width: 768px) {
    .stat-value { font-size: 24px; }
    .stat-plus { font-size: 24px; }
    .stat-label { font-size: 11px; }
    .btn-primary, .btn-outline { font-size: 14px; padding: 10px 20px; }
    .stats-header-left h2 { font-size: 22px; }
    .stats-header-left p { font-size: 13px; }
  }
  
  
  
  
  .stat {
    width: 100%;
    aspect-ratio: 16 / 11;
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    border-radius: 16px;
    border: 1px solid #eef2f7;
    box-shadow: 0 6px 18px rgba(0,0,0,0.06);
    padding: 18px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  }
  
  /* Align with Why Choose Us card internals */
  .stat .why-card-icon { height: 72px; width: 72px; margin: 0 auto 12px auto; background: linear-gradient(135deg, #eef2ff 0%, #ffffff 100%); border: 1px solid #e5e7eb; border-radius: 16px; display: grid; place-items: center; color: var(--primary); box-shadow: 0 4px 12px rgba(0,0,0,0.06); }
  .stat .why-card-icon i { font-size: 30px; }
  .stat .stat-title { margin: 0 0 6px 0; font-size: 18px; font-weight: 800; color: #0f172a; letter-spacing: .2px; }
  .stat .stat-text { margin: 0; color: #475569; font-size: 14px; line-height: 1.6; text-align: center; }
  
  @media (max-width: 992px) { .stats-inner { grid-template-columns: repeat(2, minmax(160px, 1fr)); gap: 24px; } }
  @media (max-width: 576px) { .stats-inner { grid-template-columns: 1fr; width: 95%; gap: 16px; } }
  
  /* Elevate on hover (match Why Choose Us) */
  .stat:hover { transform: translateY(-6px); box-shadow: 0 14px 36px rgba(0,0,0,0.12); border-color: #e2e8f0; }
  
  .stat-value { font-size: 36px; font-weight: 900; display: inline-block; letter-spacing: 0.5px; }
  
  .stat-plus {
    font-size: 36px;
    font-weight: 900;
    color: var(--primary);
    margin-left: 2px;
  }
  
  .stat-label { color: #6b7280; font-size: 13px; margin-top: 6px; font-weight: 700; letter-spacing: .4px; text-transform: none; }
  
  .stats-buttons {
    display: flex;
    justify-content: center;
    gap: 20px;
    flex-direction: column; /* Stack title and button vertically */
    align-items: center; /* Center-align items when stacked */
    margin-left: auto;
    margin-right: auto;
    width: 100%; /* Allow full width so content centers consistently */
  }
  
  /* Ensure clean spacing and centering of the title in the blue section */
  .stats-buttons .why-title { 
    margin: 0 0 10px 0; 
    text-align: center; 
  }
  .btn-primary {
    background: linear-gradient(315deg, #dc0b0b 0%, #b30a0a 50%, #8f0808 100%);
    color: #fff;
    padding: 12px 28px;
    border-radius: 8px;
    text-decoration: none;
    font-weight: 600;
    transition: 0.3s;
  }
  
  .btn-primary:hover {
    background: #475569;
  }
  
  .btn-outline {
    background: #f8fafc;
    color: #475569;
    padding: 12px 28px;
    border: 2px solid #e2e8f0;
    border-radius: 8px;
    text-decoration: none;
    font-weight: 600;
    transition: 0.3s;
  }
  
  .btn-outline:hover {
    background: #475569;
    color: white;
    border-color: #475569;
  }
  .stats-header-inner {
    max-width: 1200px;
    width: 100%;
    padding: 0;
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    position: relative; /* create stacking context for children */
    z-index: 3; /* Ensure inner content stays above stats grid */
  }
  
  /* Desktop: center buttons horizontally inside stats header */
  @media (min-width: 993px) {
    .stats-header {
      justify-content: center;
    }
    .stats-header-inner {
      justify-content: center;
      text-align: center;
    }
  }
  
  
  .contact-grid { display: grid; grid-template-columns: 1.2fr 0.8fr; gap: 24px; align-items: stretch; }
  .contact-form,
  .contact-info-card { height: 100%; display: flex; flex-direction: column; }
  
  /* Standard Contact Form Styles */
  .contact-form {
    background: white;
    border-radius: 16px;
    padding: 32px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    border: 1px solid #f1f5f9;
  }
  
  .form-header {
    text-align: center;
    margin-bottom: 32px;
    padding-bottom: 24px;
    border-bottom: 2px solid #f1f5f9;
  }
  
  .form-header h3 {
    font-size: 24px;
    font-weight: 700;
    color: var(--text);
    margin: 0 0 8px 0;
  }
  
  .form-header p {
    color: var(--muted);
    margin: 0;
    font-size: 14px;
  }
  
  .form-group {
    margin-bottom: 24px;
  }
  
  .form-group label {
    display: block;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 8px;
    font-size: 14px;
  }
  
  /* Red asterisks for required fields */
  .form-group label::after {
    content: ' *';
    color: #dc2626;
    font-weight: 700;
  }
  
  /* Hide asterisk for non-required fields */
  .form-group label:not([for="name"]):not([for="phone"]):not([for="model"])::after {
    display: none;
  }
  
  .form-group input,
  .form-group select,
  .form-group textarea {
    width: 100%;
    padding: 14px 16px;
    border: 2px solid #e2e8f0;
    border-radius: 8px;
    font-size: 14px;
    transition: all 0.3s ease;
    background: white;
  }
  
  .form-group input:focus,
  .form-group select:focus,
  .form-group textarea:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(220, 11, 11, 0.1);
  }
  
  .form-group input::placeholder,
  .form-group textarea::placeholder {
    color: #9ca3af;
  }
  
  .form-actions {
    display: flex;
    gap: 16px;
    margin-top: 32px;
    margin-bottom: 24px;
  }
  
  .form-footer {
    text-align: center;
    padding-top: 20px;
    border-top: 1px solid #f1f5f9;
  }
  
  .form-note {
    color: var(--muted);
    font-size: 12px;
    margin: 0;
    line-height: 1.5;
  }
  
  .success-message {
    display: flex;
    align-items: center;
    gap: 12px;
    background: #f0fdf4;
    color: #166534;
    padding: 16px;
    border-radius: 8px;
    border: 1px solid #bbf7d0;
    margin-top: 20px;
  }
  
  .success-message svg {
    color: #22c55e;
    flex-shrink: 0;
  }
  
  /* Standard Contact Info Card Styles */
  .contact-info-card {
    background: white;
    border-radius: 16px;
    padding: 32px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    border: 1px solid #f1f5f9;
    height: 100%;
    display: flex;
    flex-direction: column;
  }
  
  .contact-card-header {
    text-align: center;
    margin-bottom: 32px;
    padding-bottom: 24px;
    border-bottom: 2px solid #f1f5f9;
  }
  
  .contact-card-header h3 {
    font-size: 24px;
    font-weight: 700;
    color: var(--text);
    margin: 0 0 8px 0;
  }
  
  .contact-card-header p {
    color: var(--muted);
    margin: 0;
    font-size: 14px;
  }
  /* Contact timings list */
  .timings-list { list-style: none; margin: 10px 0 0; padding: 0; display: grid; gap: 6px; justify-content: center; }
  .timings-list li { display: inline-flex; align-items: center; gap: 8px; color: #374151; font-weight: 600; }
  .timings-list i { color: var(--primary); }
  
  .showroom-image {
    flex: 1;
    margin: 0 0 24px 0;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
    background: #f8fafc;
    display: block;
    min-height: 300px;
  }
  
  .showroom-image img {
    width: 100%;
    height: auto;
    object-fit: cover;
    transition: transform 0.3s ease;
  }
  
  .showroom-image:hover img {
    transform: scale(1.02);
  }
  
  /* timings inside showroom image - above image, left aligned */
  .timings-list.in-image { margin: 0 0 8px 0; padding: 8px 0; list-style: none; text-align: left; }
  .timings-list.in-image li { display: flex; align-items: center; gap: 8px; color: #374151; font-weight: 600; }
  .timings-list.in-image i { color: var(--primary); }
  
  
  
  .contact-card-footer {
    text-align: center;
    padding-top: 24px;
    border-top: 1px solid #f1f5f9;
    margin-top: auto;
  }
  
  .contact-note {
    color: var(--muted);
    font-size: 13px;
    margin: 0 0 20px 0;
    line-height: 1.5;
  }
  
  .btn-full {
    width: 100%;
    text-align: center;
    padding: 14px 20px;
    font-size: 14px;
    font-weight: 600;
  }
  .form-card { display: block; }
  .form-row { display: grid; gap: 6px; margin-bottom: 12px; }
  label { font-weight: 600; font-size: 14px; }
  input, select, textarea { width: 100%; background: #ffffff; border: 1px solid var(--border); color: var(--text); padding: 12px; border-radius: 10px; outline: none; }
  input:focus, select:focus, textarea:focus { border-color: var(--ring); box-shadow: 0 0 0 3px #1d4ed810; }
  .error { color: #f97316; font-size: 12px; min-height: 16px; }
  .form-actions { display: flex; gap: 10px; align-items: center; }
  .form-note { color: var(--muted); font-size: 12px; }
  .form-success { margin-top: 10px; color: var(--success); font-weight: 700; }
  
  .site-footer { border-top: 1px solid var(--border); margin-top: 40px; background: #f8fafc; }
  .footer-inner { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 18px 40px; }
  .footer-links { display: flex; gap: 16px; flex-wrap: wrap; }
  .footer-bottom { padding: 8px 40px 24px 40px; }
  .footer-brand { display: flex; gap: 10px; align-items: center; }
  
  /* New dark footer layout */
  .site-footer.dark { background: #111315; color: #e5e7eb; border-top-color: #1f2937; }
  .site-footer.dark a { color: #93c5fd; text-decoration: none; }
  .site-footer.dark a:hover { text-decoration: underline; }
  .footer-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 24px; padding: 28px 40px; }
  .footer-col h4 { margin: 0 0 8px; font-size: 16px; color: #ffffff; position: relative; }
  .footer-col h4::after { content: ""; display: block; width: 64px; height: 2px; background: #ef4444; margin-top: 6px; }
  .footer-list { list-style: none; margin: 0; padding: 0; }
  .footer-list li { margin: 10px 0; color: #9ca3af; }
  .footer-address { color: #d1d5db; font-style: normal; margin: 10px 0; }
  .footer-contact { color: #d1d5db; margin: 8px 0; }
  .site-footer.dark .footer-bottom { border-top: 1px solid #1f2937; margin-top: 8px; padding-top: 16px; color: #9ca3af; }
  
  /* New Vani Honda Footer */
  .vh-footer { background: #202b36; color: #e5e7eb; text-align: center; margin-top: 60px; }
  .vh-footer-inner { max-width: 960px; margin: 0 auto; padding: 48px 16px; }
  .vh-footer-heading { text-transform: uppercase; font-size: 12px; letter-spacing: 1px; color: #9ca3af; margin: 0 0 10px; }
  .vh-footer-title { margin: 0 0 8px; font-size: 22px; font-weight: 800; }
  .vh-footer-address { margin: 0 0 6px; color: #cbd5e1; }
  .vh-footer-contacts { margin: 6px 0 3px; color: #cbd5e1; }
  .vh-footer-contacts a { color: #ff6b6b; text-decoration: none; }
  .vh-footer-contacts .divider { margin: 0 8px; color: #64748b; }
  .vh-social { display: flex; gap: 12px; justify-content: center; margin-top: 12px; }
  .vh-social-btn { width: 40px; height: 40px; display: grid; place-items: center; border-radius: 999px; background: #293545; color: #e5e7eb; text-decoration: none; transition: transform .2s ease, background .2s ease; }
  .vh-social-btn:hover { transform: translateY(-2px); background: #334155; }
  .vh-footer-bottom { color: #ffffff !important; font-size: 13px; padding-bottom: 24px; }
  .vh-footer-bottom a { color: #93c5fd; text-decoration: none; }
  .vh-footer-bottom a:hover { text-decoration: underline; }
  
  /* Developer credit — elegant */
  .dev-link { 
    text-decoration: none; 
    color: #93c5fd; 
    position: relative;
    transition: color .2s ease;
  }
  .dev-link::after {
    content: '';
    position: absolute;
    left: 0; right: 0; bottom: -2px;
    height: 1px;
    background: currentColor;
    opacity: .4;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .2s ease, opacity .2s ease;
  }
  .dev-link:hover { color: #bfdbfe; }
  .dev-link:hover::after { transform: scaleX(1); opacity: .8; }
  
  /* Footer – mobile optimizations */
  @media (max-width: 576px) {
    .vh-footer-inner { padding: 28px 16px; }
    .vh-footer-title { font-size: 18px; }
    .vh-footer-heading { font-size: 11px; letter-spacing: .8px; }
    .vh-footer-address { font-size: 13px; line-height: 1.5; margin: 0 0 8px; }
    .vh-footer-contacts { 
      display: flex; 
      flex-wrap: wrap; 
      gap: 6px 10px; 
      justify-content: center; 
      margin: 4px 0; 
      font-size: 14px; 
    }
    .vh-footer-contacts .divider { display: none; }
    .vh-footer-contacts a { word-break: break-word; }
    .vh-social { gap: 10px; margin-top: 10px; }
    .vh-social-btn { width: 36px; height: 36px; }
    .vh-footer-bottom { padding: 16px 12px 28px 12px; font-size: 12px; }
    .vh-footer-bottom p { 
      margin: 8px 0 16px; 
      line-height: 1.4; 
      display: flex; 
      flex-direction: column; 
      gap: 6px; 
      align-items: center; 
    }
  }
  @media (max-width: 360px) {
    .vh-footer-title { font-size: 16px; }
    .vh-footer-contacts a { font-size: 13px; }
    .vh-social-btn { width: 32px; height: 32px; }
  }
  
  @media (max-width: 960px) {
    .hero-inner { grid-template-columns: 1fr; }
    .contact-grid { grid-template-columns: 1fr; gap: 20px; }
    
    .contact-form {
      padding: 24px;
    }
    
    .form-header {
      margin-bottom: 24px;
      padding-bottom: 20px;
    }
    
    .form-header h3 {
      font-size: 20px;
    }
    
    .form-actions {
      flex-direction: column;
      gap: 12px;
    }
    
    .form-actions .btn {
      width: 100%;
      text-align: center;
    }
    
    .contact-info-card {
      padding: 20px;
    }
    
    .contact-card-header {
      margin-bottom: 20px;
      padding-bottom: 16px;
    }
    
    .contact-card-header h3 {
      font-size: 18px;
    }
    
    .showroom-image {
      min-height: 250px;
      margin-bottom: 20px;
    }
    .cards { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .features { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .stats-inner { grid-template-columns: repeat(2, 1fr); }
    /* keep arrows usable on mobile */
    .hero-prev, .hero-next { width: 34px; height: 34px; font-size: 18px; }
    .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    
    /* Show hamburger on tablets too */
    .nav-toggle { 
      display: flex !important;
      margin-left: auto;
      padding: 8px;
      background: #f0f0f0;
      border-radius: 6px;
      border: 1px solid #ddd;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      width: 40px;
      height: 40px;
    }
    
    .nav-toggle .bar {
      width: 18px;
      height: 2px;
      background: #333;
      margin: 2px 0;
      border-radius: 1px;
    }
    
    .nav-menu {
      display: none !important;
    }
    
    .nav-menu.open {
      display: flex !important;
      position: fixed; 
      top: 96px;
      left: 0;
      right: 0;
      background: #ffffff; 
      border-bottom: 1px solid var(--border); 
      padding: 16px; 
      flex-direction: column; 
      gap: 8px; 
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
      z-index: 999;
    }
    
    /* Top bar responsive adjustments */
    .top-bar-inner {
      flex-direction: column;
      gap: 8px;
      text-align: center;
    }
    
    .top-bar-center, .top-bar-right {
      gap: 8px;
    }
    
    .brand-name {
      font-size: 20px;
    }
    
    .brand-text {
      gap: 12px;
    }
    
    .brand-divider {
      margin: 0 4px;
    }
    
    /* Hero banner mobile adjustments - match about us page exactly */
    .hero-banner {
      height: 300px;
      padding: 0;
    }
    
    .hero-banner-image {
      width: 100%;
      height: 300px;
      object-fit: cover;
      object-position: center;
      border-radius: 20px;
      box-shadow: 0 8px 24px rgba(0,0,0,0.08);
      display: block;
    }
    
    .hero-controls {
      margin: auto 10px;
    }
    
    .hero-prev, .hero-next {
      width: 40px;
      height: 40px;
      font-size: 20px;
    }
    
    /* Welcome Section Mobile Adjustments */
    .welcome-section {
      padding: 16px 16px;
    }
    
    .welcome-title {
      font-size: 2.5rem;
      margin-bottom: 16px;
    }
    
    .welcome-paragraph {
      font-size: 1.0625rem;
    }
  }
  @media (max-width: 768px) {
    body {
      padding-top: 104px !important; /* Updated for stacked top bar (~48px) + header (56px) */
    }
    
    .header-inner {
      padding: 0 16px !important; /* Mobile-optimized padding */
      gap: 8px !important; /* Compact spacing for mobile */
      align-items: center !important; /* Ensure vertical centering */
      height: 56px !important; /* Mobile header height */
      justify-content: space-between !important; /* Proper distribution */
    }
    
    .brand {
      flex: 1 !important; /* Take available space */
      min-width: 0 !important; /* Allow shrinking */
      display: flex !important;
      align-items: center !important; /* Vertical center alignment */
    }
    
    .brand-text {
      display: flex !important;
      align-items: center !important; /* Vertical center alignment */
      gap: 8px !important;
    }
    
    .brand-name {
      font-size: 18px !important; /* Better readable size */
      white-space: nowrap !important; /* Prevent wrapping */
      line-height: 1 !important; /* Tight line height */
      display: flex !important;
      align-items: center !important; /* Vertical center */
    }
    
    .nav-toggle { 
      display: flex !important;
      visibility: visible !important;
      opacity: 1 !important;
      margin-left: 16px !important; /* Proper spacing */
      padding: 8px !important;
      background: transparent !important; /* No background */
      border: none !important; /* No border */
      width: 32px !important;
      height: 32px !important;
      position: relative !important;
      z-index: 9999 !important;
      flex-shrink: 0 !important; /* Don't allow shrinking */
      flex-direction: column !important;
      justify-content: center !important;
      align-items: center !important;
    }
    
    .nav-toggle .bar {
      width: 20px !important;
      height: 2px !important;
      background: #000000 !important; /* Black bars on transparent background */
      margin: 2px 0 !important;
      border-radius: 1px !important;
      display: block !important;
    }
    .nav-menu { 
      position: fixed; 
      top: calc(48px + 56px) !important; /* exactly below stacked top bar + header */
      left: 0;
      right: 0;
      background: #ffffff; 
      border-bottom: 1px solid var(--border); 
      padding: 16px; 
      display: none; 
      flex-direction: column; 
      gap: 8px; 
      box-shadow: none; /* remove shadow */
      height: auto;
      z-index: 999;
      max-height: 80vh;
      overflow-y: auto;
    }
    
    .nav-menu.open { 
      display: flex !important; 
    }
    .nav-menu.open { display: flex; }
    .cards { grid-template-columns: 1fr; }
    .features { grid-template-columns: 1fr; }
    .stats-inner { grid-template-columns: repeat(2, 1fr); }
    .footer-grid { grid-template-columns: 1fr; }
    
    /* Top bar mobile adjustments */
    .top-bar {
      padding: 2px 16px !important;
    }
    
    .top-bar-inner {
      flex-direction: row !important;
      justify-content: space-between !important;
      align-items: center !important;
      gap: 1px !important;
      font-size: 8px !important;
      min-height: 22px !important;
      padding: 0 8px !important;
      overflow: hidden !important;
    }
    
    .top-bar-left {
      gap: 6px !important;
      flex: 0 0 auto !important;
      min-width: 50px !important;
    }
    
    .top-bar-center {
      gap: 2px !important;
      flex: 1 !important;
      justify-content: center !important;
      text-align: center !important;
      overflow: hidden !important;
      white-space: nowrap !important;
    }
    
    .top-bar-right {
      gap: 2px !important;
      flex: 0 0 auto !important;
      min-width: 100px !important;
      justify-content: flex-end !important;
    }
    
    .contact-link {
      font-size: 8px !important;
      padding: 1px 2px !important;
      white-space: nowrap !important;
    }
    
    .social-link {
      padding: 1px !important;
      width: 14px !important;
      height: 14px !important;
    }
    
    .social-link svg {
      width: 12px !important;
      height: 12px !important;
    }
    
    .separator {
      margin: 0 2px !important;
      font-size: 8px !important;
    }
    
    .brand-text {
      flex-direction: row;
      gap: 6px;
      align-items: center;
    }
    
    .brand-name {
      font-size: 14px !important; /* Even smaller on mobile */
    }
    
    .brand-divider {
      display: block;
      height: 24px;
      width: 1px;
    }
    
    .honda-logo {
      flex-direction: column;
      gap: 1px;
    }
    
    .honda-logo img {
      width: 24px !important;
      height: 24px !important;
    }
    
    .nav-menu {
      gap: 8px;
    }
    
    .nav-menu a {
      display: flex;
      align-items: center;
      gap: 16px;         /* space between icon and text */
      font-size: 14px !important;
      padding: 10px 5px;
      text-decoration: none;
      color: #111;
    }
    .nav-menu a i {
      font-size: 18px;   /* slightly larger icons */
      width: 20px;       /* fixed width for alignment */
      text-align: center;
       color:var(--primary);  
    }
    
    .nav-menu a:hover {
      background: var(--primary);
      color: white;
      border-color: var(--primary);
    }
    
    .nav-menu li {
      height: auto;
      width: 100%;
    }
    
    .nav-menu a:not(.btn):hover::after {
      display: none;
    }
    .nav-toggle[aria-expanded="true"] .bar:nth-child(1) {
      transform: rotate(45deg) translate(5px, 5px);
    }
    .nav-toggle[aria-expanded="true"] .bar:nth-child(2) {
      opacity: 0;
    }
    .nav-toggle[aria-expanded="true"] .bar:nth-child(3) {
      transform: rotate(-45deg) translate(5px, -5px);
    }
    
    .top-bar {
      padding: 6px 16px;
    }
    
    .top-bar-inner {
      min-height: 36px;
    }
    
    /* Hero banner mobile adjustments - match about us page exactly */
    .hero-banner {
      height: 200px !important;
      width: 100% !important;
      overflow: hidden !important;
      padding: 0;
    }
    
    /* Welcome Section Mobile Adjustments */
    .welcome-section {
      padding: 8px 16px !important;
      min-height: auto;
      margin-top: 8px !important;
    }
    
    .welcome-content {
      max-width: 100%;
      padding: 0 12px;
      text-align: left;
    }
    
    .welcome-title {
      font-size: 2rem;
      margin-bottom: 12px;
    }
    
    .welcome-text {
      gap: 8px;
    }
    
    .welcome-paragraph {
      font-size: 1rem;
      line-height: 1.6;
    }
    
    .hero-banner-image {
      width: 100%;
      height: 200px !important;
      object-fit: cover;
      object-position: center;
      border-radius: 20px;
      box-shadow: 0 8px 24px rgba(0,0,0,0.08);
      display: block;
    }
    
    .hero {
      margin-bottom: 0 !important;
      padding-bottom: 0 !important;
    }
    
    .hero-controls {
      margin: auto 8px;
    }
    
    .hero-prev, .hero-next {
      width: 32px;
      height: 32px;
      font-size: 16px;
      background: rgba(0, 0, 0, 0.7);
      border: none;
    }
    
    .hero-dots {
      bottom: 10px;
    }
    
    .hero-dots button {
      width: 8px;
      height: 8px;
    }
    
    .hero-dots button[aria-selected="true"] {
      width: 16px;
    }
    
    /* Welcome Section Extra Small Mobile Adjustments */
    .welcome-section {
      padding: 8px 16px;
    }
    
    .welcome-title {
      font-size: 1.75rem;
      margin-bottom: 8px;
    }
    
    .welcome-paragraph {
      font-size: 0.9375rem;
      line-height: 1.5;
    }
  } 
  
  /* Extra small mobile devices */
  @media (max-width: 480px) {
    .welcome-section {
      padding: 8px 16px;
    }
    
    .welcome-content {
      padding: 0 10px;
      text-align: left;
    }
    
    .welcome-title {
      font-size: 1.5rem;
      margin-bottom: 6px;
    }
    
    .welcome-paragraph {
      font-size: 0.875rem;
      line-height: 1.4;
    }
  }
  
  /* Featured Products Section Styles */
  #products.section {
    padding: 40px 40px 40px 40px !important;
  }
  
  /* Mobile responsive padding for products section */
  @media (max-width: 768px) {
    #products.section {
      padding: 48px 16px !important;
    }
  }
  
  @media (max-width: 480px) {
    #products.section {
      padding: 24px 16px !important;
    }
  }
  
  .product-tabs {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-bottom: 40px;
    flex-wrap: wrap;
  }
  
  .product-tab {
    background: #f8fafc;
    border: 2px solid #e5e7eb;
    color: #6b7280;
    padding: 12px 24px;
    border-radius: 25px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    font-size: 14px;
  }
  
  .product-tab:hover {
    border-color: var(--primary);
    color: var(--primary);
  }
  
  .product-tab.active {
    background: var(--primary);
    border-color: var(--primary);
    color: white;
  }
  
  .products-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: 30px;
    margin-bottom: 50px;
    margin-top: 16px;
  }
  
  .product-card {
    background: white;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
    border: 1px solid #f1f5f9;
  }
  
  .product-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15);
  }
  
  .product-image {
    width: 100%;
    height: 250px;
    overflow: hidden;
    margin-bottom: 16px;
    background: #ffffff; /* pure white background for transparent PNGs */
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  
  .product-image img {
    width: 100%;
    height: 100%;
    object-fit: contain; /* fill container regardless of image aspect */
    object-position: center;
    border-radius: 0; /* container has the radius */
  }
  
  .product-badge {
    position: absolute;
    top: 16px;
    right: 16px;
    background: var(--primary);
    color: white;
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
  }
  
  .product-content {
    padding: 24px;
  }
  
  .product-title {
    font-size: 20px;
    font-weight: 700;
    color: var(--text);
    margin: 0 0 12px 0;
    line-height: 1.3;
  }
  
  .product-description {
    color: var(--muted);
    margin: 0 0 20px 0;
    line-height: 1.6;
    font-size: 14px;
  }
  
  .product-specs {
    display: flex;
    gap: 8px;
    margin-bottom: 20px;
    flex-wrap: wrap;
  }
  
  .spec {
    background: #f1f5f9;
    color: #475569;
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 500;
  }
  
  .product-price {
    margin-bottom: 24px;
    text-align: center;
  }
  
  .price-label {
    display: block;
    color: var(--muted);
    font-size: 12px;
    margin-bottom: 4px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
  }
  
  .price {
    display: block;
    font-size: 24px;
    font-weight: 800;
    color: var(--primary);
  }
  
  .product-actions {
    display: flex;
    gap: 12px;
    flex-direction: column;
  }
  
  .product-actions .btn {
    text-align: center;
    padding: 12px 20px;
    font-weight: 600;
    border-radius: 8px;
    transition: all 0.3s ease;
  }
  
  .products-cta {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-top: 40px;
    flex-wrap: wrap;
  }
  
  .btn-large {
    padding: 16px 32px;
    font-size: 16px;
    font-weight: 600;
  }
  
  /* Ride Home Header Section */
  .ride-home-header {
    background: linear-gradient(135deg, #1e2a39 0%, #374151 100%);
    color: white;
    padding: 80px 40px;
    text-align: center;
    position: relative;
  }
  
  .ride-home-header::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="50" cy="50" r="1" fill="rgba(255,255,255,0.03)"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');
    opacity: 0.5;
  }
  
  .ride-home-content {
    position: relative;
    z-index: 2;
  }
  
  .ride-home-title {
    font-size: 48px;
    font-weight: 800;
    margin: 0 0 20px 0;
    background: linear-gradient(135deg, #ffffff 0%, #f3f4f6 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    line-height: 1.2;
  }
  
  .ride-home-subtitle {
    font-size: 20px;
    color: #d1d5db;
    margin: 0 0 40px 0;
    font-weight: 400;
    line-height: 1.6;
  }
  
  .ride-home-actions {
    display: flex;
    gap: 20px;
    justify-content: center;
    flex-wrap: wrap;
  }
  
  .ride-home-actions .btn-large {
    padding: 16px 32px;
    font-size: 16px;
    font-weight: 600;
    border-radius: 8px;
    transition: all 0.3s ease;
  }
  
  /* Mobile Responsiveness for Products */
  @media (max-width: 768px) {
    .ride-home-header {
      padding: 60px 16px;
    }
    
    .ride-home-title {
      font-size: 36px;
      margin-bottom: 16px;
    }
    
    .ride-home-subtitle {
      font-size: 18px;
      margin-bottom: 30px;
    }
    
    .ride-home-actions {
      gap: 16px;
    }
    
    .ride-home-actions .btn-large {
      padding: 14px 28px;
      font-size: 15px;
    }
    
    .product-tabs {
      gap: 6px;
      margin-bottom: 30px;
    }
    
    .product-tab {
      padding: 10px 18px;
      font-size: 13px;
    }
    
    .products-grid {
      grid-template-columns: 1fr;
      gap: 24px;
      margin-bottom: 40px;
    }
    
    .product-card {
      border-radius: 12px;
    }
    
    .product-image {
      height: 200px;
    }
    
    .product-content {
      padding: 20px;
    }
    
    .product-title {
      font-size: 18px;
    }
    
    .product-actions {
      flex-direction: column;
      align-items: center;
    }
    
    .products-cta {
      flex-direction: column;
      align-items: center;
      gap: 16px;
    }
    
    .btn-large {
      width: 100%;
      max-width: 300px;
    }
  }
  
  @media (max-width: 480px) {
    .ride-home-header {
      padding: 40px 16px;
    }
    
    .ride-home-title {
      font-size: 28px;
      margin-bottom: 12px;
    }
    
    .ride-home-subtitle {
      font-size: 16px;
      margin-bottom: 24px;
    }
    
    .ride-home-actions {
      flex-direction: column;
      align-items: center;
      gap: 12px;
    }
    
    .ride-home-actions .btn-large {
      width: 100%;
      max-width: 280px;
      padding: 12px 24px;
      font-size: 14px;
    }
    
    .product-tabs {
      margin-bottom: 24px;
    }
    
    .product-tab {
      padding: 8px 16px;
      font-size: 12px;
    }
    
    .products-grid {
      gap: 20px;
      margin-bottom: 30px;
    }
    
    .product-image {
      height: 180px;
    }
    
    .product-content {
      padding: 16px;
    }
    
    .product-title {
      font-size: 16px;
    }
    
    .product-specs {
      gap: 6px;
    }
    
    .spec {
      padding: 4px 10px;
      font-size: 11px;
    }
    
    .price {
      font-size: 20px;
    }
  }
  
  /* Final mobile override for top bar visibility and wrapping */
  @media (max-width: 768px) {
    .top-bar-left { display: none !important; }
    .top-bar-inner { flex-direction: column !important; gap: 4px !important; text-align: center !important; }
    .top-bar-center, .top-bar-right {
      display: flex !important;
      justify-content: center !important;
      align-items: center !important;
      width: 100% !important;
      margin: 0 !important;
      flex-wrap: wrap !important;
      white-space: normal !important;
      overflow: visible !important;
      gap: 6px !important;
    }
    .top-bar-center .contact-link, .top-bar-right .contact-link {
      font-size: 12px !important;
      padding: 2px 6px !important;
    }
    /* Keep both emails on a single line */
    .top-bar-center { flex-wrap: nowrap !important; gap: 4px !important; overflow: hidden !important; }
    .top-bar-center .contact-link { 
      white-space: nowrap !important; 
      overflow: hidden !important; 
      text-overflow: ellipsis !important; 
      max-width: 48% !important; 
      display: inline-flex !important;
    }
  }
  
  /* Extra-small phones: shrink email text slightly to avoid overlap */
  @media (max-width: 360px) {
    .top-bar-center .contact-link { font-size: 10px !important; }
  }
  
  /* ===== Contact section: compact variant ===== */
  .section.contact.compact { padding: 20px 40px 28px 40px; }
  .section.contact.compact .section-head { margin-bottom: 14px; }
  .section.contact.compact .section-head h2 { font-size: 28px; }
  .section.contact.compact .section-head p { font-size: 13px; }
  
  .compact .contact-grid { grid-template-columns: 1fr 1fr; gap: 16px; align-items: stretch; }
  .compact .contact-form { border-radius: 12px; padding: 20px; }
  /* Professional two-column layout for contact form */
  .contact-form.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 16px; align-items: start; }
  .contact-form.two-col .form-header { grid-column: 1 / -1; margin-bottom: 8px; padding-bottom: 12px; }
  .contact-form.two-col .form-group.full { grid-column: 1 / -1; }
  .contact-form.two-col .form-actions { grid-column: 1 / -1; }
  .contact-form.two-col .form-footer { grid-column: 1 / -1; }
  .contact-form.two-col .form-success { grid-column: 1 / -1; }
  .contact-form.two-col .form-group { margin-bottom: 0; }
  .contact-form.two-col .form-group.full { grid-column: 1 / -1; }
  
  /* Polished input look */
  .contact-form.two-col .form-group input,
  .contact-form.two-col .form-group select,
  .contact-form.two-col .form-group textarea {
    border-radius: 10px;
    border-width: 1px;
  }
  .contact-form.two-col .form-group label { font-size: 13px; margin-bottom: 6px; color: #111827; }
  
  /* Buttons alignment */
  .contact-form.two-col .form-actions { display: flex; gap: 12px; justify-content: flex-start; }
  .contact-form.two-col .form-actions .btn { height: 40px; min-height: 40px; padding: 0 14px; }
  
  @media (max-width: 768px) {
    .contact-form.two-col { grid-template-columns: 1fr; gap: 12px; }
  }
  
  /* Consent row alignment (single column full width) */
  .consent-group { margin-top: 2px; margin-bottom: 10px; }
  .form-group .consent-label { display: flex !important; align-items: center !important; gap: 10px; font-weight: 600; color: #111827; vertical-align: middle; white-space: normal; }
  .consent-checkbox { margin-top: 0; flex-shrink: 0; width: auto !important; height: auto; padding: 0; border: 0; box-shadow: none; display: inline-block; transform: translateY(1px); }
  .consent-group input[type="checkbox"] { width: auto !important; height: auto; display: inline-block; margin-right: 8px; }
  .consent-text { font-weight: 400; color: #374151; line-height: 1.5; display: inline-block; vertical-align: middle; }
  .compact .form-header { margin-bottom: 16px; padding-bottom: 12px; }
  .compact .form-header h3 { font-size: 20px; }
  .compact .form-header p { font-size: 13px; }
  .compact .form-group { margin-bottom: 14px; }
  .compact .form-group input,
  .compact .form-group select,
  .compact .form-group textarea { padding: 10px 12px; font-size: 13px; }
  .compact .form-actions { margin-top: 12px; margin-bottom: 8px; }
  .compact .form-actions .btn { height: 40px; min-height: 40px; padding: 0 12px; }
  .compact #contact-submit-status { font-size: 13px; }
  
  .compact .contact-info-card { border-radius: 12px; padding: 20px; }
  .compact .contact-card-header { margin-bottom: 16px; padding-bottom: 12px; }
  .compact .contact-card-header h3 { font-size: 20px; }
  .compact .contact-card-header p { font-size: 13px; }
  .compact .showroom-image { min-height: 220px; border-radius: 10px; margin-bottom: 12px; }
  .compact .timings-list { gap: 4px; }
  .compact .contact-card-footer { padding-top: 14px; }
  .compact .contact-note { font-size: 12px; margin: 0 0 12px 0; }
  .compact .btn-full { padding: 12px 16px; font-size: 13px; }
  
  @media (max-width: 992px) {
    .section.contact.compact { padding: 16px 16px 24px 16px; }
    .compact .contact-grid { grid-template-columns: 1fr; gap: 12px; }
  }
  
  /* Our Story enriched styles */
  .story-panel { background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%); border: 1px solid #e2e8f0; border-radius: 16px; padding: 24px; box-shadow: 0 6px 18px rgba(0,0,0,0.06); }
  .story-badges { display: flex; gap: 10px; flex-wrap: wrap; margin: 16px 0 8px; }
  .badge-chip { display: inline-flex; align-items: center; gap: 8px; padding: 8px 12px; background: #eef2ff; color: #1e293b; border: 1px solid #e2e8f0; border-radius: 999px; font-weight: 700; font-size: 12px; }
  .badge-chip i { color: var(--primary); }
  
  /* Our Story – new full-width layout */
  .story-head { margin-bottom: 16px; }
  .story-eyebrow { margin: 0 0 6px; font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; color: var(--primary); }
  .story-title { margin: 0 0 8px; font-size: 28px; font-weight: 900; color: #111827; }
  .story-lead { margin: 0 0 16px; color: #374151; }
  
  .story-features { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 16px; margin: 14px 0 10px; }
  .story-feature { display: grid; grid-template-columns: 44px 1fr; gap: 10px; padding: 14px; border: 1px solid #e5e7eb; border-radius: 12px; background: #fff; }
  .feature-icon { width: 44px; height: 44px; border-radius: 10px; display: grid; place-items: center; background: #fef2f2; color: var(--primary); font-size: 18px; }
  .feature-body h3 { margin: 0 0 6px; font-size: 16px; font-weight: 800; color: #111827; }
  .feature-body p { margin: 0; color: #6b7280; font-size: 14px; line-height: 1.6; }
  
  .story-statbar { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 10px; margin: 12px 0 0; }
  .stat-item { background: #0f172a; color: #e5e7eb; border: 1px solid #0b1226; border-radius: 12px; padding: 12px; text-align: center; }
  .stat-num { font-size: 20px; font-weight: 900; letter-spacing: 0.5px; }
  .stat-label { font-size: 12px; color: #9ca3af; margin-top: 2px; }
  
  @media (max-width: 992px) {
    .story-features { grid-template-columns: 1fr 1fr; }
    .story-statbar { grid-template-columns: 1fr 1fr; }
  }
  @media (max-width: 768px) {
    .story-features { grid-template-columns: 1fr; }
    .story-statbar { grid-template-columns: 1fr; }
  }
  
  /* About Us Intro */
  .about-intro .section-head { text-align: center; }
  .about-intro .section-head p { color: #000; text-align: center; }
  .about-intro-grid { display: grid; grid-template-columns: 1fr; gap: 20px; align-items: center; max-width: 900px; margin: 0 auto; }
  .about-intro .intro-text { text-align: center; max-width: 800px; margin: 0 auto; }
  .intro-title { margin: 0 0 8px; font-size: 22px; font-weight: 800; color: #111827; }
  .intro-lead { margin: 0 0 14px; color: #374151; }
  .intro-points { list-style: none; padding: 0; margin: 0 0 16px; display: grid; gap: 8px; justify-items: center; }
  .intro-points li { display: flex; align-items: center; gap: 10px; color: #1f2937; font-weight: 600; justify-content: center; }
  .intro-points i { color: var(--primary); }
  .intro-cta { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; }
  /* removed intro-media image for full-width centered text */
  
  @media (max-width: 992px) {
    .about-intro-grid { grid-template-columns: 1fr; gap: 16px; }
  }
  @media (max-width: 768px) {
    .about-intro .section-head { text-align: left; }
    .intro-cta { flex-direction: column; align-items: stretch; }
    .intro-cta .btn { width: 100%; text-align: center; }
  }
  
  /* Global typography overrides */
  :root {
    /* Standard Font Family Variables */
    --font-family-primary: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    --font-family-heading: var(--font-family-primary);
    --font-family-body: var(--font-family-primary);
    --font-family-button: var(--font-family-primary);
  }
  
  /* Apply font family variables globally */
  html, body, body * { font-family: var(--font-family-primary); }
  h1, h2, h3, h4, h5, h6 { font-family: var(--font-family-heading); }
  p, span, div, a, li { font-family: var(--font-family-body); }
  button, .btn, input, textarea, select { font-family: var(--font-family-button); }
  
  p { color: #000 !important; }
  
  
  
  /*product page style*/
  .filter-buttons {
    display: flex;
    justify-content: center;
    gap: 16px;
    margin-bottom: 16px;
  }
  .filters-head { display: none; }
  .filters-title { margin: 0; font-weight: 900; text-transform: uppercase; letter-spacing: .5px; }
  .filters-toggle { padding: 8px 12px; border: 2px solid #111; background:#fff; border-radius:8px; font-weight:800; cursor:pointer; display:inline-flex; align-items:center; gap:8px; }
  .filters-toggle i{ font-size:14px; }
  
  .filter-btn {
    padding: 12px 24px;
    border: 2px solid #e5e7eb;
    background: #fff;
    color: #374151;
    border-radius: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
  }
  
  .filter-btn:hover {
    border-color: #dc2626;
    color: #dc2626;
  }
  
  .filter-btn.active {
    background: #dc2626;
    border-color: #dc2626;
    color: #fff;
  }
  
  .products-container {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
    max-width: 1200px;
    margin: 0 auto;
  }
  
  /* Space between product categories */
  .product-category { margin-bottom: 40px; padding-bottom: 8px; }
  
  .product-item {
    text-align: center;
  }
  .product-item .product-name { margin: 0; font-size: 18px; font-weight: 800; color: #494d4e;  letter-spacing: 0.5px; }
  /* Tighten gap between product image and name on products page */
  .products-container .product-image { margin-bottom: 0; }
  
  /* Subtle hover effects for products screen */
  .product-item .product-image,
  .product-item .product-image img,
  .product-item .product-name {
    transition: all 0.3s ease;
  }
  
  /* Removed lift and shadow on hover for image container */
  
  .product-item:hover .product-image img {
    transform: scale(1.04);
  }
  
  .product-item:hover .product-name {
    color: var(--primary);
  }
  
  .product-image {
    width: 100%;
    height: 250px;
    overflow: hidden;
    margin-bottom: 16px;
    background: #ffffff; /* pure white background for transparent PNGs */
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  
  .product-image img {
    width: 100%;
    height: 100%;
    object-fit: contain; /* show full vehicle without cropping */
    object-position: center;
    border-radius: 0; /* container has the radius */
  }
  
  .product-name {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: #111827;
  }
  
  .product-category-head { 
    margin: 4px 0 12px; 
    padding: 0 0 6px 0; 
    font-size: 20px; 
    font-weight: 900; 
    letter-spacing: .5px; 
    color: #111827; 
    text-transform: capitalize; 
    width: 100%;
    border-bottom: 1px solid #cbd5e1;
  }
  .product-category-head span { display: inline-block; }
  
  @media (max-width: 768px) {
    .filter-buttons { display: none; }
    .product-filters.open .filter-buttons { 
        display: grid; 
        grid-template-columns: 1fr 1fr; 
        gap: 12px; 
        margin-top: 12px;
    }
    .filters-head { 
        display: flex; 
        flex-direction: column; 
        align-items: center; 
        gap: 8px; 
        background: #f3f4f6; 
        padding: 12px; 
        border-radius: 12px; 
    }
    .products-container {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    .product-category { margin-bottom: 24px; }
    .product-item .product-name { font-size: 18px; }
  }
  
  @media (max-width: 480px) {
    .products-container {
        grid-template-columns: 1fr;
        gap: 20px;
    }
  }
  
  /* Product Details Page Styles */
  .actions-group{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
  .actions-group .btn{min-width:180px;text-align:center}
  
  /* ===== PRODUCT PAGE ANIMATIONS ===== */
  
  /* Fade in animations for product cards */
  @keyframes fadeInUp {
    from {
      opacity: 0;
      transform: translateY(30px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }
  
  @keyframes fadeInScale {
    from {
      opacity: 0;
      transform: scale(0.9);
    }
    to {
      opacity: 1;
      transform: scale(1);
    }
  }
  
  @keyframes slideInLeft {
    from {
      opacity: 0;
      transform: translateX(-30px);
    }
    to {
      opacity: 1;
      transform: translateX(0);
    }
  }
  
  @keyframes slideInRight {
    from {
      opacity: 0;
      transform: translateX(30px);
    }
    to {
      opacity: 1;
      transform: translateX(0);
    }
  }
  
  @keyframes pulse {
    0%, 100% {
      transform: scale(1);
    }
    50% {
      transform: scale(1.05);
    }
  }
  
  @keyframes bounce {
    0%, 20%, 50%, 80%, 100% {
      transform: translateY(0);
    }
    40% {
      transform: translateY(-10px);
    }
    60% {
      transform: translateY(-5px);
    }
  }
  
  /* Animation classes */
  .animate-fade-in-up {
    animation: fadeInUp 0.6s ease-out forwards;
  }
  
  .animate-fade-in-scale {
    animation: fadeInScale 0.5s ease-out forwards;
  }
  
  .animate-slide-in-left {
    animation: slideInLeft 0.6s ease-out forwards;
  }
  
  .animate-slide-in-right {
    animation: slideInRight 0.6s ease-out forwards;
  }
  
  .animate-pulse {
    animation: pulse 2s infinite;
  }
  
  .animate-bounce {
    animation: bounce 1s infinite;
  }
  
  /* Staggered animations for product cards */
  .product-item {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.6s cubic-bezier(0.4, 0, 0.2, 1);
  }
  
  .product-item.animate-in {
    opacity: 1;
    transform: translateY(0);
  }
  
  /* Enhanced hover animations */
  .product-card {
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
  }
  
  .product-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: left 0.6s ease;
    z-index: 1;
  }
  
  .product-card:hover::before {
    left: 100%;
  }
  
  .product-card:hover {
    transform: translateY(-12px) scale(1.02);
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.2);
  }
  
  .product-image {
    transition: all 0.4s ease;
    position: relative;
    overflow: hidden;
  }
  
  .product-image::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(45deg, rgba(220, 11, 11, 0.1), transparent);
    opacity: 0;
    transition: opacity 0.3s ease;
  }
  
  .product-card:hover .product-image::after {
    opacity: 1;
  }
  
  .product-card:hover .product-image img {
    transform: scale(1.1) rotate(2deg);
  }
  
  .product-image img {
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  }
  
  /* Filter button animations */
  .filter-btn {
    position: relative;
    overflow: hidden;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  }
  
  .filter-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
    transition: left 0.5s ease;
  }
  
  .filter-btn:hover::before {
    left: 100%;
  }
  
  .filter-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(220, 38, 38, 0.3);
  }
  
  .filter-btn.active {
    transform: scale(1.05);
    box-shadow: 0 6px 16px rgba(220, 38, 38, 0.4);
  }
  
  /* Product category animations */
  .product-category {
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
  }
  
  .product-category.animate-in {
    opacity: 1;
    transform: translateY(0);
  }
  
  .product-category-head {
    position: relative;
    overflow: hidden;
  }
  
  .product-category-head::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: -100%;
    width: 100%;
    height: 2px;
    background: linear-gradient(90deg, transparent, #dc2626, transparent);
    transition: left 0.6s ease;
  }
  
  .product-category.animate-in .product-category-head::after {
    left: 100%;
  }
  
  /* Loading animations */
  .loading-shimmer {
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
  }
  
  @keyframes shimmer {
    0% {
      background-position: -200% 0;
    }
    100% {
      background-position: 200% 0;
    }
  }
  
  /* Product details page animations */
  .detail-card {
    opacity: 0;
    transform: scale(0.9);
    transition: all 0.5s ease;
  }
  
  .detail-card.animate-in {
    opacity: 1;
    transform: scale(1);
  }
  
  .explore-tab {
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease;
  }
  
  .explore-tab::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: left 0.5s ease;
  }
  
  .explore-tab:hover::before {
    left: 100%;
  }
  
  .explore-tab:hover {
    transform: translateY(-2px);
  }
  
  .explore-tab.active {
    transform: scale(1.05);
    box-shadow: 0 6px 16px rgba(220, 38, 38, 0.3);
  }
  
  /* Color chip animations */
  .color-chip {
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease;
  }
  
  .color-chip::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
    transition: left 0.4s ease;
  }
  
  .color-chip:hover::before {
    left: 100%;
  }
  
  .color-chip:hover {
    transform: translateX(5px);
    box-shadow: 0 4px 12px rgba(220, 38, 38, 0.2);
  }
  
  /* Gallery item animations */
  .gallery-item {
    opacity: 0;
    transform: scale(0.9);
    transition: all 0.4s ease;
  }
  
  .gallery-item.animate-in {
    opacity: 1;
    transform: scale(1);
  }
  
  .gallery-item:hover {
    transform: scale(1.05);
    z-index: 10;
  }
  
  /* Variant item animations */
  .variant-item {
    opacity: 0;
    transform: translateX(-20px);
    transition: all 0.3s ease;
  }
  
  .variant-item.animate-in {
    opacity: 1;
    transform: translateX(0);
  }
  
  /* Specs panel animations */
  .specs-panel {
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.4s ease;
  }
  
  .specs-panel.active {
    opacity: 1;
    transform: translateY(0);
  }
  
  /* Video container animations */
  .video-container {
    opacity: 0;
    transform: scale(0.95);
    transition: all 0.5s ease;
  }
  
  .video-container.animate-in {
    opacity: 1;
    transform: scale(1);
  }
  
  /* Test drive form animations */
  #test-drive {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.6s ease;
  }
  
  #test-drive.animate-in {
    opacity: 1;
    transform: translateY(0);
  }
  
  /* Mobile responsive animations */
  @media (max-width: 768px) {
    .product-card:hover {
      transform: translateY(-6px) scale(1.01);
    }
    
    .product-card:hover .product-image img {
      transform: scale(1.05);
    }
    
    .filter-btn:hover {
      transform: translateY(-1px);
    }
  }
  
  /* Reduce padding for product-details section */
  .product-details.section { padding: 0px 40px 0px; }
  @media (max-width: 768px) { .product-details.section { padding: 0px 16px 0px; } }
  
  @media(max-width:768px){.actions-group .btn{width:100%;max-width:280px}}
  
  /* Detail Grid */
  .detail-grid{display:grid;grid-template-columns:420px 420px;gap:12px;align-items:stretch;justify-content:center;margin:0 auto}
  .detail-stack{display:grid;gap:12px}
  .detail-card{background:#ffffff;border:1px solid #e5e7eb;border-radius:16px;height:170px;overflow:hidden}
  .detail-card-lg{grid-column:1;grid-row:span 2;height:360px}
  .detail-card img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;background:#ffffff}
  @media(max-width: 1200px){.detail-grid{grid-template-columns:360px 360px}}
  @media(max-width: 768px){.detail-grid{grid-template-columns:1fr;gap:16px}}
  
  /* Explorer section */
  .product-explorer { padding-left: 40px; padding-right: 40px; }
  .explore-title{margin:0 0 12px 0;text-align:center;font-weight:900;color:#111827}
  .explore-tabs{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin:0 0 16px}
  .explore-tab{padding:10px 14px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;color:#111827;font-weight:700;cursor:pointer}
  .explore-tab.active{background:linear-gradient(315deg,#dc0b0b 0%, #b30a0a 50%, #8f0808 100%);color:#fff;border-color:transparent}
  .explore-grid{display:grid;grid-template-columns:240px 1fr 360px;gap:24px;align-items:center}
  @media(min-width: 1280px){
    .explore-grid{grid-template-columns:280px 1fr 400px;}
  }
  .explore-colors{display:flex;flex-direction:column;gap:10px}
  .colors-head{font-size:12px;font-weight:800;color:#6b7280;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;padding:8px}
  .color-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
  .color-chip{display:block;width:100%;text-align:left;padding:10px 12px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;cursor:pointer;color:#111827;font-weight:600}
  .color-chip.active{background:linear-gradient(315deg,#dc0b0b 0%, #b30a0a 50%, #8f0808 100%);color:#fff;border-color:transparent}
  .color-chip:hover{border-color:#dc2626;color:#dc2626}
  .explore-visual{margin:0;display:grid;place-items:center}
  .explore-image{width:80%;height:auto;margin:0 auto;}
  @media(max-width: 768px){
    .explore-image{width:90%;}
  }
  .explore-specs{background:#fff;border-radius:12px;padding:14px}
  .specs-list{margin:0;}
  .spec-row{display:grid;grid-template-columns:140px 1fr;gap:10px;padding:6px 0}
  .spec-row dt{color:#6b7280;font-weight:600;font-size:14px}
  .spec-row dd{margin:0;color:#111827;font-weight:600;font-size:14px}
  .specs-panel{display:none}
  .specs-panel.active{display:block}
  @media(max-width:992px){.explore-grid{grid-template-columns:1fr;gap:12px}.explore-specs{order:3}}
  
  /* Product Variants & Pricing */
  .variants-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
  .video-section{display:flex;justify-content:center}
  .video-container{width:100%;height:300px;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,0.1)}
  .video-container iframe{width:100%;height:100%;border:none}
  .variants-content{display:flex;flex-direction:column;gap:12px}
  .variants-title{margin:0;font-size:24px;font-weight:800;color:#111827;text-align:Center}
  .variants-list{display:flex;flex-direction:column;gap:0px}
  .variant-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #e5e7eb}
  .variant-item:last-child{border-bottom:none}
  .variant-name{font-weight:600;color:#111827}
  .variant-price{font-weight:700;color:#111827}
  .variants-actions{display:flex;gap:12px;justify-content:center}
  .variants-actions .btn{min-width:140px;text-align:center}
  .price-disclaimer{margin:0;font-size:12px;color:#6b7280;text-align:center}
  @media(max-width:768px){.variants-grid{grid-template-columns:1fr;gap:20px}.variants-actions{flex-direction:column;align-items:center}}
  
  /* Product Gallery */
  .gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:32px;margin-bottom:32px}
  .gallery-item{text-align:center;width:100%;height:200px;overflow:hidden;border-radius:8px;display:block;background:#ffffff;display:flex;align-items:center;justify-content:center}
  .gallery-item img{width:100%;height:100%;object-fit:contain;object-position:center;transition:transform 0.3s ease;display:block;background:#ffffff}
  .gallery-item:hover img{transform:scale(1.05)}
  @media(max-width:768px){.gallery-grid{grid-template-columns:repeat(2,1fr);gap:12px}}
  @media(max-width:480px){.gallery-grid{grid-template-columns:1fr}}
  
  /* Products Hero Banner */
  .products-hero-banner { padding: 0 40px; }
  .products-hero-img { width: 100%; height: 500px; object-fit: cover; object-position: center; border-radius: 20px; box-shadow: 0 8px 24px rgba(0,0,0,0.08); display: block; }
  
  @media (max-width: 992px) {
    .products-hero-img { height: 300px; }
  }
  
  @media (max-width: 768px) {
    .products-hero-banner { padding: 0 16px; }
  }
  
  @media (max-width: 600px) {
    .products-hero-img { height: 200px !important; }
  }
  
  /* Quote Form Popup - Enhanced Design */
  .quote-popup-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(8px);
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
    animation: fadeIn 0.3s ease-out;
  }
  
  .quote-popup-overlay.active {
    display: flex;
  }
  
  @keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
  }
  
  @keyframes slideIn {
    from { 
      opacity: 0;
      transform: translateY(-30px) scale(0.95);
    }
    to { 
      opacity: 1;
      transform: translateY(0) scale(1);
    }
  }
  
  .quote-popup {
    background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%);
    border-radius: 24px;
    padding: 0;
    max-width: 600px;
    width: 100%;
    max-height: 90vh;
    overflow: hidden;
    position: relative;
    box-shadow: 0 32px 64px rgba(0, 0, 0, 0.25);
    border: 1px solid rgba(255, 255, 255, 0.2);
    animation: slideIn 0.4s ease-out;
    display: flex;
    flex-direction: column;
  }
  
  .quote-popup-header {
    background: linear-gradient(135deg, #dc2626 0%, #b91c1c 100%);
    padding: 24px 32px;
    color: white;
    position: relative;
    overflow: hidden;
  }
  
  .quote-popup-header::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="25" cy="25" r="1" fill="rgba(255,255,255,0.1)"/><circle cx="75" cy="75" r="1" fill="rgba(255,255,255,0.1)"/><circle cx="50" cy="10" r="0.5" fill="rgba(255,255,255,0.1)"/><circle cx="10" cy="60" r="0.5" fill="rgba(255,255,255,0.1)"/><circle cx="90" cy="40" r="0.5" fill="rgba(255,255,255,0.1)"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');
    opacity: 0.3;
  }
  
  .quote-popup-title {
    font-size: 28px;
    font-weight: 900;
    margin: 0;
    position: relative;
    z-index: 1;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  }
  
  .quote-popup-subtitle {
    font-size: 16px;
    margin: 8px 0 0 0;
    opacity: 0.9;
    position: relative;
    z-index: 1;
    font-weight: 400;
  }
  
  .quote-popup-close {
    position: absolute;
    top: 20px;
    right: 20px;
    background: rgba(255, 255, 255, 0.2);
    border: none;
    color: white;
    font-size: 24px;
    cursor: pointer;
    padding: 8px;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    backdrop-filter: blur(10px);
    z-index: 2;
  }
  
  .quote-popup-close:hover {
    background: rgba(255, 255, 255, 0.3);
    transform: scale(1.1);
  }
  
  .quote-form {
    padding: 32px;
    display: flex;
    flex-direction: column;
    gap: 20px;
    flex: 1;
    overflow-y: auto;
    max-height: calc(90vh - 120px);
  }
  
  /* Custom scrollbar for quote form */
  .quote-form::-webkit-scrollbar {
    width: 8px;
  }
  
  .quote-form::-webkit-scrollbar-track {
    background: #f1f5f9;
    border-radius: 4px;
  }
  
  .quote-form::-webkit-scrollbar-thumb {
    background: #dc2626;
    border-radius: 4px;
  }
  
  .quote-form::-webkit-scrollbar-thumb:hover {
    background: #b91c1c;
  }
  
  .form-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
  }
  
  .form-label {
    font-weight: 700;
    color: #1f2937;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
  }
  
  .form-input,
  .form-select,
  .form-textarea {
    padding: 16px 20px;
    border: 2px solid #e5e7eb;
    border-radius: 12px;
    font-size: 16px;
    transition: all 0.3s ease;
    font-family: inherit;
    background: #ffffff;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
  }
  
  .form-input:focus,
  .form-select:focus,
  .form-textarea:focus {
    outline: none;
    border-color: #dc2626;
    box-shadow: 0 0 0 4px rgba(220, 38, 38, 0.1);
    transform: translateY(-1px);
  }
  
  .form-input::placeholder,
  .form-textarea::placeholder {
    color: #9ca3af;
    font-style: italic;
  }
  
  .form-textarea {
    resize: vertical;
    min-height: 120px;
    font-family: inherit;
  }
  
  .form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }
  
  .form-submit {
    background: linear-gradient(135deg, #dc2626 0%, #b91c1c 100%);
    color: white;
    border: none;
    padding: 18px 32px;
    border-radius: 12px;
    font-size: 18px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s ease;
    margin-top: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    box-shadow: 0 8px 16px rgba(220, 38, 38, 0.3);
    position: relative;
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    min-height: 48px;
  }
  
  .form-submit::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: left 0.5s ease;
  }
  
  .form-submit:hover {
    background: linear-gradient(135deg, #b91c1c 0%, #991b1b 100%);
    transform: translateY(-2px);
    box-shadow: 0 12px 24px rgba(220, 38, 38, 0.4);
  }
  
  .form-submit:hover::before {
    left: 100%;
  }
  
  .form-submit:active {
    transform: translateY(0);
  }
  
  .form-submit:disabled {
    background: #9ca3af;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
  }
  
  .form-error {
    color: #dc2626;
    font-size: 14px;
    margin-top: 6px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 6px;
  }
  
  .form-error::before {
    content: '⚠';
    font-size: 16px;
  }
  
  .form-success {
    background: linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%);
    color: #065f46;
    padding: 20px 24px;
    border-radius: 12px;
    margin-top: 20px;
    display: none;
    border: 2px solid #10b981;
    font-weight: 600;
    text-align: center;
    position: relative;
    overflow: hidden;
  }
  
  .form-success::before {
    content: '✓';
    position: absolute;
    top: 50%;
    left: 20px;
    transform: translateY(-50%);
    font-size: 24px;
    color: #10b981;
  }
  
  .form-success-text {
    margin-left: 40px;
  }
  
  /* Enhanced mobile responsiveness */
  @media (max-width: 640px) {
    .quote-popup {
      margin: 10px;
      border-radius: 20px;
      max-height: 95vh;
    }
    
    .quote-popup-header {
      padding: 20px 24px;
    }
    
    .quote-popup-title {
      font-size: 24px;
    }
    
    .quote-form {
      padding: 24px;
      gap: 16px;
      max-height: calc(95vh - 100px);
    }
    
    .form-row {
      grid-template-columns: 1fr;
      gap: 16px;
    }
    
    .form-input,
    .form-select,
    .form-textarea {
      padding: 14px 16px;
    }
    
    .form-submit {
      padding: 16px 24px;
      font-size: 16px;
    }
  }
  
  /* Loading animation */
  .form-submit.loading {
    position: relative;
    color: transparent;
  }
  
  .form-submit.loading::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top: 2px solid white;
    border-radius: 50%;
    animation: spin 1s linear infinite;
  }
  
  @keyframes spin {
    0% { transform: translate(-50%, -50%) rotate(0deg); }
    100% { transform: translate(-50%, -50%) rotate(360deg); }
  }
  
  .product-filters.section { padding-bottom: 8px; }
  .products-grid.section { padding-top: 8px; }
  .filter-buttons { margin-bottom: 8px; }
  .products-grid { margin-top: 4px; }
  
  /* Products page spacing tweaks */
  .products-intro.section { padding-bottom: 8px; }
  .products-intro .section-head { margin-bottom: 8px; }
  .product-filters.section { padding-top: 8px; padding-bottom: 8px; }
  .filter-buttons { margin-bottom: 8px; }
  .products-grid.section { padding-top: 8px; }
  .products-grid { margin-top: 4px; }
  
  /* Call Now button reveal animation (desktop) */
  #call-now-btn { white-space: nowrap; position: relative; }
  #call-now-btn .label { display: inline-block; vertical-align: middle; }
  #call-now-btn .phone { display: inline-block; vertical-align: middle; overflow: hidden; max-width: 0; opacity: 0; margin-left: 0; transition: max-width 0.25s ease, opacity 0.2s ease, margin-left 0.2s ease; }
  @media (min-width: 769px) {
    #call-now-btn.show-number .phone { max-width: 240px; opacity: 1; margin-left: 8px; }
    #call-now-btn.show-number .label { display: none; }
  }
  
  /* Generic reveal behavior for other buttons (e.g., loan page) */
  .reveal-phone { white-space: nowrap; position: relative; }
  .reveal-phone .label { display: inline-block; vertical-align: middle; }
  .reveal-phone .phone { display: inline-block; vertical-align: middle; overflow: hidden; max-width: 0; opacity: 0; margin-left: 0; transition: max-width 0.25s ease, opacity 0.2s ease, margin-left 0.2s ease; }
  @media (min-width: 769px) {
    .reveal-phone.show-number .phone { max-width: 240px; opacity: 1; margin-left: 8px; }
    .reveal-phone.show-number .label { display: none; }
  }
  /* 180-degree turn animation */
  /* Call Now revolve (360°) animation */
  @keyframes vh-revolve-360 { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
  #call-now-btn.revolve-anim { animation: vh-revolve-360 0.4s ease; }
  
  .explore-specs .specs-panel[data-panel="tyres"] .spec-row { grid-template-columns: 220px 1fr; }
  .explore-specs .specs-panel[data-panel="tyres"] dt { white-space: nowrap; }
  
  .vh-footer-address { color: #6b7280 !important;font-weight: 600; }
  .vh-footer-bottom, .vh-footer-bottom p, .vh-footer-bottom a { color: #ffffff !important; }
  