/* =========================================
   BLAYHUB LANDING PAGE STYLES - V20.0 (TRUE SHOP SYNC & UI FIXES)
   ========================================= */

:root {
    --primary: #e5383b;
    --dark-bg: #0b090a;
    --border: #1a1a1a;
    --font-heading: 'Oswald', sans-serif;
    --font-body: 'Inter', sans-serif;
}

html, body { overflow-x: hidden !important; width: 100%; position: relative; max-width: 100vw; background-color: var(--dark-bg); color: #fff; font-family: var(--font-body); }

.grain-overlay { position: fixed; inset: 0; pointer-events: none; z-index: 9999; }

/* --- 1. HERO SECTION --- */
.hero { min-height: 100svh; margin-top: -105px; padding-top: 105px; position: relative; display: flex; align-items: center; padding-left: 5%; padding-right: 5%; background: url('https://wallpaperaccess.com/full/3460990.jpg') no-repeat center center/cover; overflow: hidden; }
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(11,9,10,0.95) 0%, rgba(11,9,10,0.4) 100%); z-index: 1; }
.tech-grid { position: absolute; inset: 0; z-index: 2; pointer-events: none; opacity: 0.2; background-image: linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px); background-size: 60px 60px; animation: moveGrid 30s linear infinite; will-change: transform; }
@keyframes moveGrid { from { background-position: 0 0; } to { background-position: 60px 60px; } }
.hero-content { position: relative; z-index: 3; width: 100%; max-width: 850px; }
.hero-label { color: var(--primary); font-family: var(--font-heading); letter-spacing: 3px; font-weight: 500; margin-bottom: 15px; font-size: 0.8rem; display: inline-block; border-bottom: 1px solid rgba(229, 56, 59, 0.5); padding-bottom: 5px; }
.hero h1 { font-family: var(--font-heading); font-size: 6.5rem; line-height: 0.9; letter-spacing: -2px; color: white; margin-bottom: 25px; }
.text-stroke { -webkit-text-stroke: 1.5px rgba(255,255,255,0.9); color: transparent; }
.hero p { color: #a1a1aa; font-size: 1.1rem; border-left: 2px solid var(--primary); padding-left: 20px; max-width: 600px; font-weight: 300; letter-spacing: 0.5px; }

/* GARAGE WIDGET */
.hero-garage-widget { background: rgba(11, 9, 10, 0.4); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); border: 1px solid rgba(255, 255, 255, 0.24); border-radius: 12px; padding: 20px; display: flex; align-items: center; gap: 25px; margin-top: 40px; box-shadow: 0 20px 40px rgba(0,0,0,0.5); max-width: 700px; }
.garage-graphic { position: relative; width: 110px; height: 80px; display: flex; align-items: center; justify-content: center; border-right: 1px solid rgba(255,255,255,0.08); padding-right: 25px; }
.blueprint-svg { width: 100%; max-width: 140px; height: auto; overflow: visible; }
.cad-lines path, .cad-lines circle, .cad-lines line { fill: transparent; stroke: #ffffff; stroke-width: 2; stroke-dasharray: 40 20; filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.4)); animation: dashFlow 1.5s linear infinite; }
@keyframes dashFlow { from { stroke-dashoffset: 120; } to { stroke-dashoffset: 0; } }
.garage-form { display: flex; flex: 1; gap: 12px; flex-wrap: wrap; }
.garage-select-wrapper { position: relative; flex: 1; min-width: 120px; }
.garage-select-wrapper select { width: 100%; appearance: none; background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08); color: white; padding: 12px 20px; border-radius: 50px; font-family: var(--font-heading); font-size: 0.8rem; letter-spacing: 1.5px; cursor: pointer; outline: none; transition: 0.3s; }
.garage-select-wrapper select:focus, .garage-select-wrapper select:hover:not(:disabled) { border-color: rgba(229, 56, 59, 0.5); background: rgba(0, 0, 0, 0.6); }
.garage-select-wrapper select:disabled { opacity: 0.3; cursor: not-allowed; }
.garage-select-wrapper select option { background: #0b090a; color: white; }
.garage-select-wrapper i { position: absolute; right: 18px; top: 50%; transform: translateY(-50%); color: #666; pointer-events: none; font-size: 0.75rem; transition: 0.3s; }

/* 🌟 FIXED: PILL SHAPE BUTTON OVERRIDE & CUT-PATH FIX */
#btn-find-parts { 
    width: 100%; 
    display: flex; 
    justify-content: center; 
    align-items: center; 
    gap: 10px; 
    padding: 12px; 
    border-radius: 50px !important; 
    clip-path: none !important; 
    -webkit-clip-path: none !important;
    transition: transform 0.2s ease, background 0.3s ease; 
    font-size: 0.85rem; 
}

.scroll-indicator { position: absolute; bottom: 30px; right: 50px; z-index: 5; color: #666; display: flex; flex-direction: column; align-items: center; gap: 10px; font-family: var(--font-heading); font-size: 0.65rem; letter-spacing: 3px; cursor: pointer; transition: color 0.3s ease; }
.scroll-indicator:hover { color: white; }
.scroll-indicator .line { width: 1px; height: 50px; background: rgba(255,255,255,0.1); position: relative; overflow: hidden; }
.scroll-indicator .line::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: var(--primary); animation: scrollDrop 2s infinite; }
@keyframes scrollDrop { 0% { transform: translateY(-100%); } 100% { transform: translateY(100%); } }

/* --- 2. MARQUEE STRIP --- */
.marquee-container { background: var(--primary); padding: 12px 0; overflow: hidden; white-space: nowrap; transform: rotate(-1deg) scale(1.02); z-index: 4; position: relative; border-top: 1px solid black; border-bottom: 1px solid black; }
.marquee-content { display: inline-block; animation: marquee 35s linear infinite; will-change: transform; font-family: var(--font-heading); font-weight: 700; font-size: 1.1rem; color: black; letter-spacing: 2px; }
.marquee-content span { margin: 0 40px; }
.marquee-content .dot { opacity: 0.4; }
@keyframes marquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* --- 3. CATEGORY GRID --- */
.category-section { padding: 100px 5%; background: var(--dark-bg); }
.section-header { text-align: center; margin-bottom: 60px; }
.section-header h2 { font-size: 2.2rem; font-family: var(--font-heading); color: white; letter-spacing: 2px; }
.line-divider { width: 30px; height: 3px; background: var(--primary); margin: 15px auto; }
.bento-category-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 15px; grid-auto-rows: 150px; width: 100%; max-width: 1200px; margin: 0 auto; }
@media (min-width: 768px) { .bento-category-grid { grid-template-columns: repeat(4, 1fr); grid-auto-rows: 130px; } }
@media (min-width: 1024px) { .bento-category-grid { grid-template-columns: repeat(5, 1fr); } }
.bento-wide { grid-column: span 2; }
.bento-tall { grid-row: span 2; }
.stealth-card { background: linear-gradient(145deg, #111, #050505); border: 1px solid var(--border); border-radius: 8px; padding: 15px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-decoration: none; position: relative; overflow: hidden; transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1); height: 100%; width: 100%; }
.stealth-card::after { content: ''; position: absolute; bottom: 0; left: 0; width: 100%; height: 2px; background: var(--primary); transform: scaleX(0); transform-origin: center; transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1); }
.stealth-card:hover { transform: translateY(-4px); border-color: #333; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.6); background: linear-gradient(145deg, #161616, #050505); z-index: 2; }
.stealth-card:hover::after { transform: scaleX(1); }
.stealth-card h3 { font-family: var(--font-heading); color: #888; font-size: 0.75rem; font-weight: 500; letter-spacing: 2px; margin: 0; text-align: center; text-transform: uppercase; transition: color 0.3s ease, transform 0.3s ease; }
.stealth-card:hover h3 { color: #ffffff; transform: translateY(-2px); }

/* --- 4. SHOWROOM & SHOP IDENTICAL PRODUCT CARDS --- */
.showroom-section { padding: 100px 5%; background: var(--dark-bg); }
.alt-bg { background: #080808; border-top: 1px solid #111; border-bottom: 1px solid #111; }
.vertical-marquee-wrapper { position: relative; height: 750px; overflow: hidden; max-width: 1400px; margin: 0 auto; border-radius: 6px; }

.marquee-fade-top { position: absolute; top: 0; left: 0; width: 100%; height: 180px; background: linear-gradient(180deg, var(--dark-bg) 0%, transparent 100%); z-index: 10; pointer-events: none; }
.alt-bg .marquee-fade-top { background: linear-gradient(180deg, #080808 0%, transparent 100%); }

.marquee-fade-bottom { position: absolute; bottom: 0; left: 0; width: 100%; height: 180px; background: linear-gradient(0deg, var(--dark-bg) 0%, transparent 100%); z-index: 10; pointer-events: none; }
.alt-bg .marquee-fade-bottom { background: linear-gradient(0deg, #080808 0%, transparent 100%); }

.vertical-marquee-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; height: 100%; }
.v-column { position: relative; height: 100%; overflow: hidden; }
.v-track { display: flex; flex-direction: column; gap: 20px; will-change: transform; }

.dir-up .v-track { animation: scrollUp 45s linear infinite; }
.dir-down .v-track { animation: scrollDown 55s linear infinite; }
.vertical-marquee-grid:hover .v-track { animation-play-state: paused !important; }
@keyframes scrollUp { 0% { transform: translateY(0); } 100% { transform: translateY(-50%); } }
@keyframes scrollDown { 0% { transform: translateY(-50%); } 100% { transform: translateY(0); } }

/* EXACT SHOP CARD CSS */
.premium-product-card { background: linear-gradient(145deg, #18181b, #0f0f11); border: 1px solid #27272a; border-radius: 8px; overflow: hidden; display: flex; flex-direction: column; width: 100%; transition: box-shadow 0.3s cubic-bezier(0.16, 1, 0.3, 1); box-shadow: 0 4px 10px rgba(0,0,0,0.3); position: relative; perspective: 1000px; transform-style: preserve-3d; }
.premium-product-card:hover { border-color: #3f3f46; box-shadow: 0 25px 45px rgba(0,0,0,0.8); z-index: 5; }
.premium-product-card::before { content: ''; position: absolute; inset: 0; border-radius: inherit; background: radial-gradient(800px circle at var(--mouse-x, 50%) var(--mouse-y, 50%), rgba(255, 255, 255, 0.08), transparent 40%); opacity: 0; transition: opacity 0.3s ease; pointer-events: none; z-index: 10; }
.premium-product-card:hover::before { opacity: 1; }
.premium-product-card.magnetic-reset { transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1), box-shadow 0.3s ease; }

.premium-img-box { height: 200px; background: #0a0b0c; position: relative; display: flex; align-items: center; justify-content: center; overflow: hidden; padding: 15px; }
.premium-img-box img { max-width: 100%; max-height: 100%; object-fit: contain; transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1); z-index: 1; }
.premium-product-card:hover .premium-img-box img { transform: scale(1.1); }

.product-badge { position: absolute; top: 12px; left: 12px; z-index: 2; background: var(--primary); color: #fff; font-family: var(--font-heading); font-size: 0.65rem; font-weight: 500; letter-spacing: 1.5px; padding: 3px 10px; border-radius: 3px; }

.product-hover-actions { position: absolute; bottom: 0; left: 0; right: 0; padding: 14px; background: linear-gradient(0deg, rgba(0,0,0,0.88) 0%, transparent 100%); transform: translateY(101%); transition: transform 0.28s ease; z-index: 3; display: flex; }
.premium-product-card:hover .product-hover-actions { transform: translateY(0); }
.btn-quick-view { flex: 1; background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.18); color: #fff; padding: 9px; font-family: var(--font-heading); font-size: 0.78rem; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase; text-decoration: none; text-align: center; border-radius: 4px; backdrop-filter: blur(6px); transition: background 0.18s; cursor: pointer; }
.btn-quick-view:hover { background: rgba(255,255,255,0.2); }

.btn-save-part { position: absolute; top: 12px; right: 12px; z-index: 25; background: rgba(11, 9, 10, 0.5); border: 1px solid rgba(255, 255, 255, 0.1); color: #a1a1aa; width: 34px; height: 34px; border-radius: 50%; display: flex; align-items: center; justify-content: center; cursor: pointer; backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); transition: transform 0.15s ease, background 0.3s, color 0.3s; }
.btn-save-part:hover { color: var(--primary); background: rgba(11, 9, 10, 0.9); }
.btn-save-part:active { transform: scale(0.85); }
.btn-save-part.saved-active { background: rgba(229, 56, 59, 0.15); border-color: var(--primary); color: var(--primary); animation: heartPulse 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards; }
.btn-save-part.saved-active i { color: var(--primary) !important; }
@keyframes heartPulse { 0% { transform: scale(0.85); box-shadow: 0 0 0 0 rgba(229, 56, 59, 0.6); } 50% { transform: scale(1.15); box-shadow: 0 0 0 10px rgba(229, 56, 59, 0); } 100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(229, 56, 59, 0); } }

.premium-details { padding: 20px; display: flex; flex-direction: column; flex-grow: 1; }
.premium-category { font-size: 10px; color: #e11d48; text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 8px; font-weight: 700; }
.premium-title { font-family: var(--font-heading); color: #ffffff; font-size: 16px; margin: 0 0 8px 0; line-height: 1.3; letter-spacing: 0.5px; transition: color 0.3s ease; }
.premium-product-card:hover .premium-title { color: #e11d48; }

.product-rating { display: flex; align-items: center; gap: 7px; margin-bottom: 12px; }
.rating-count { font-family: var(--font-body); font-size: 0.7rem; color: #6b6e72; }
.product-price-row { display: flex; align-items: baseline; gap: 9px; margin-top: auto; margin-bottom: 15px; }
.premium-price { font-size: 20px; color: #ffffff; font-family: var(--font-heading); font-weight: 700; letter-spacing: 0.5px; }
.product-price-original { color: #6b6e72; font-family: var(--font-body); font-size: 0.85rem; text-decoration: line-through; }

.btn-stealth-add { position: relative; overflow: hidden; background: transparent; border: 1px solid #e11d48; color: #e11d48; padding: 12px; font-family: var(--font-body); font-size: 12px; font-weight: 600; letter-spacing: 1px; border-radius: 4px; cursor: pointer; text-align: center; width: 100%; transition: all 0.3s ease; }
.btn-stealth-add:hover { background: #e11d48; color: #ffffff; box-shadow: 0 0 10px rgba(225, 29, 72, 0.4); }
.btn-oos-state { background: rgba(255, 255, 255, 0.05) !important; border-color: rgba(255, 255, 255, 0.1) !important; color: #6b6e72 !important; cursor: not-allowed; }
.btn-oos-state:hover { box-shadow: none !important; transform: none !important; }

/* 🌟 QUICK VIEW MODAL */
.qv-overlay { position: fixed; inset: 0; background: rgba(5, 6, 8, 0.85); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); z-index: 9999; display: flex; align-items: center; justify-content: center; opacity: 0; visibility: hidden; transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1); }
.qv-overlay.active { opacity: 1; visibility: visible; }
.qv-content { background: linear-gradient(145deg, rgba(24, 24, 27, 0.95), rgba(15, 15, 17, 0.98)); border: 1px solid rgba(255, 255, 255, 0.08); border-top: 3px solid #e5383b; border-radius: 16px; width: 92%; max-width: 950px; position: relative; transform: scale(0.96) translateY(30px); transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1); box-shadow: 0 30px 60px rgba(0,0,0,0.9), 0 0 40px rgba(229, 56, 59, 0.1); overflow: hidden; }
.qv-overlay.active .qv-content { transform: scale(1) translateY(0); }
.qv-close { position: absolute; top: 20px; right: 20px; background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.1); color: #a1a1aa; width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; cursor: pointer; z-index: 10; transition: all 0.2s; backdrop-filter: blur(4px); }
.qv-close:hover { background: #e5383b; color: #fff; border-color: #e5383b; transform: rotate(90deg); }
.qv-layout { display: flex; flex-direction: row; min-height: 450px; }
.qv-image-col { flex: 1.1; display: flex; align-items: center; justify-content: center; padding: 40px; border-right: 1px solid rgba(255,255,255,0.05); background: radial-gradient(circle at center, rgba(255,255,255,0.08) 0%, transparent 60%), #0a0b0c; }
.qv-image-col img { max-width: 100%; max-height: 380px; object-fit: contain; z-index: 2; filter: drop-shadow(0 25px 35px rgba(0,0,0,0.6)); }
.qv-details-col { flex: 1; padding: 50px 40px; display: flex; flex-direction: column; justify-content: center; }

/* --- 5. PERFORMANCE BANNER --- */
.performance-banner { position: relative; height: 450px; background: url('https://images.hdqwalls.com/download/honda-fireblade-4k-1b-2560x1440.jpg') no-repeat center center/cover; background-attachment: fixed; display: flex; align-items: center; justify-content: flex-start; padding: 0 10%; margin-top: 50px; }
.performance-banner::before { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, #0b090a 0%, rgba(11,9,10,0.1) 100%); }
.perf-content { position: relative; z-index: 2; max-width: 500px; }
.perf-label { color: #888; font-family: var(--font-heading); font-size: 0.75rem; letter-spacing: 3px; margin-bottom: 15px; display: inline-block; border-bottom: 1px solid var(--primary); padding-bottom: 5px; }
.perf-content h2 { font-family: var(--font-heading); font-size: 3rem; color: white; line-height: 1.1; margin-bottom: 15px; letter-spacing: 1px; }
.perf-content p { color: #aaa; font-size: 1rem; margin-bottom: 30px; line-height: 1.6; font-weight: 300; }

/* --- 6. FAQ SECTION --- */
.faq-section { padding: 100px 5%; background: #0b090a; }
.faq-container { max-width: 900px; margin: 0 auto; display: grid; grid-template-columns: 1fr 2fr; gap: 50px; }
.faq-header h2 { font-family: var(--font-heading); font-size: 2.2rem; color: white; letter-spacing: 1px; line-height: 1.2; }
.faq-header p { color: #666; font-family: var(--font-body); font-size: 0.85rem; margin-top: 10px; }
.faq-list { border-top: 1px solid var(--border); }
.faq-item { border-bottom: 1px solid var(--border); }
.faq-btn { width: 100%; background: none; border: none; padding: 25px 0; text-align: left; color: #ccc; font-size: 0.95rem; font-family: var(--font-heading); letter-spacing: 1.5px; cursor: pointer; display: flex; justify-content: space-between; align-items: center; transition: color 0.3s; }
.faq-btn span { flex: 1; padding-right: 20px; }
.faq-btn:hover { color: white; }
.faq-btn i { font-size: 0.7rem; color: #555; transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), color 0.3s; }
.faq-btn.active i { transform: rotate(135deg); color: var(--primary); }
.faq-content { max-height: 0; overflow: hidden; transition: max-height 0.4s cubic-bezier(0.16, 1, 0.3, 1); color: #888; line-height: 1.6; font-size: 0.9rem; }
.faq-content p { padding-bottom: 25px; }

/* --- 7. MAP SECTION --- */
.map-section { position: relative; height: 500px; background: #0b090a; display: flex; align-items: center; justify-content: center; }
.map-container { width: 100%; height: 100%; position: relative; }
.leaflet-pane { z-index: 1; }
.leaflet-top, .leaflet-bottom { z-index: 2; }
.leaflet-control-container { display: none !important; }
.map-card { position: absolute; top: 50%; left: 10%; transform: translateY(-50%); background: rgba(11, 9, 10, 0.85); padding: 40px 35px; border: 1px solid var(--border); border-left: 3px solid var(--primary); box-shadow: 0 15px 40px rgba(0,0,0,0.8); backdrop-filter: blur(20px); width: 320px; border-radius: 6px; z-index: 10; }
.map-card h3 { font-family: var(--font-heading); font-size: 1.4rem; color: white; margin-bottom: 15px; letter-spacing: 1.5px; }
.map-card .address { color: #aaa; margin-bottom: 20px; font-size: 0.85rem; line-height: 1.6; }
.map-card .hours { display: flex; justify-content: space-between; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 15px 0; color: #777; margin-bottom: 25px; font-size: 0.75rem; font-family: var(--font-heading); letter-spacing: 1.5px; }

/* --- 8. NEWSLETTER SECTION --- */
.newsletter-section { padding: 90px 5%; background: #050505; text-align: center; border-top: 1px solid #111; }
.newsletter-content { max-width: 500px; margin: 0 auto; }
.newsletter-content h2 { font-family: var(--font-heading); font-size: 2rem; color: white; margin-bottom: 10px; letter-spacing: 1.5px; }
.newsletter-content p { color: #666; margin-bottom: 35px; font-size: 0.85rem; letter-spacing: 0.5px; }
.input-group { display: flex; border: 1px solid #222; background: #0a0a0a; transition: border-color 0.3s ease; border-radius: 50px; overflow: hidden; }
.input-group:focus-within { border-color: rgba(229, 56, 59, 0.5); }
.input-group input { flex: 1; padding: 15px 25px; background: transparent; border: none; color: white; outline: none; font-family: var(--font-body); font-size: 0.85rem; letter-spacing: 1px; }
.input-group button { padding: 0 30px; background: transparent; border: none; color: var(--primary); font-family: var(--font-heading); font-weight: 600; letter-spacing: 1.5px; cursor: pointer; transition: 0.3s; font-size: 0.8rem; }
.input-group button:hover { background: var(--primary); color: white; }

/* --- ANIMATIONS --- */
.reveal { opacity: 0; transform: translateY(30px); transition: opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1), transform 0.8s cubic-bezier(0.16, 1, 0.3, 1); }
.reveal.active { opacity: 1; transform: translateY(0); }

/* =========================================
   MOBILE RESPONSIVE FIXES
   ========================================= */
@media (max-width: 1024px) {
    .hero h1 { font-size: 5rem; }
    .map-card { left: 5%; }
    .faq-container { grid-template-columns: 1fr; gap: 30px; }
    .vertical-marquee-grid { grid-template-columns: repeat(3, 1fr); }
    .v-column:nth-child(4) { display: none; } 
}

@media (max-width: 768px) {
    .hero, .performance-banner { background-attachment: scroll !important; }
    .hero { min-height: 100svh; margin-top: -70px; padding-top: 70px; text-align: center; justify-content: center; }
    .hero-content { margin: 0 auto; display: flex; flex-direction: column; align-items: center; transform: translateY(-5%); } 
    .hero-label { font-size: 0.65rem; margin-bottom: 10px; border-bottom: none; }
    .hero h1 { font-size: 3.5rem; line-height: 1; margin-bottom: 15px; letter-spacing: -1px; }
    .hero p { font-size: 0.85rem; border-left: none; padding-left: 0; color: #888; margin-bottom: 30px; max-width: 90%; }
    
    .hero-garage-widget { flex-direction: column; gap: 15px; padding: 20px 15px; width: 100%; border-radius: 8px; }
    .garage-graphic { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.05); padding-right: 0; padding-bottom: 15px; width: 100%; height: auto; display: flex; justify-content: center; }
    .blueprint-svg { max-width: 90px; }
    .garage-form { width: 100%; flex-direction: column; }
    .garage-select-wrapper { width: 100%; }
    .garage-select-wrapper select { text-align: center; padding-left: 0; }

    .scroll-indicator { left: 50%; transform: translateX(-50%); right: auto; bottom: 15px; font-size: 0.55rem; gap: 6px; }
    .scroll-indicator .line { height: 30px; margin: 0 auto; }
    
    .category-section { padding: 60px 0; }
    .bento-category-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; grid-auto-rows: 100px; padding: 0 15px; }
    .stealth-card { flex: auto; height: 100%; padding: 10px 5px; justify-content: center; border-radius: 6px; }
    .bento-wide { grid-column: span 1; } 
    .bento-tall { grid-column: span 3; grid-row: span 1; height: 60px; }
    .bento-tall .stealth-card { flex-direction: row; gap: 15px; }
    .stealth-card h3 { font-size: 0.65rem; letter-spacing: 1px; }
    
    .showroom-section { padding: 60px 15px; }
    .vertical-marquee-wrapper { height: 400px; }
    .vertical-marquee-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .v-column:nth-child(3) { display: none; } 
    .premium-img-box { height: 150px; }
    .premium-title { font-size: 0.8rem; }
    .btn-stealth-add { font-size: 11px; padding: 10px; }

    .qv-layout { flex-direction: column; }
    .qv-image-col { padding: 30px; border-right: none; border-bottom: 1px solid rgba(255,255,255,0.05); }
    .qv-image-col img { max-height: 220px; }
    .qv-details-col { padding: 30px 25px; }

    .performance-banner { height: 350px; }
    .perf-content { text-align: center; margin: 0 auto; }

    .faq-section { padding: 60px 15px; }
    .faq-container { display: flex; flex-direction: column; gap: 20px; align-items: center; text-align: center; }
    .faq-header h2 { font-size: 1.8rem; margin-bottom: 5px; }
    .faq-header p { font-size: 0.8rem; margin-bottom: 20px; }
    .faq-list { width: 100%; max-width: 500px; }
    .faq-btn { padding: 15px 0; font-size: 0.8rem; }
    .faq-content p { font-size: 0.8rem; padding-bottom: 15px; color: #777; text-align: center; }

    .map-section { height: 400px; display: block; }
    .map-container { height: 100%; }
    .map-card { position: absolute; bottom: 20px; left: 50%; transform: translateX(-50%); width: 90%; max-width: 280px; padding: 20px; background: rgba(11, 9, 10, 0.95); text-align: center; display: flex; flex-direction: column; gap: 8px; border-left: none; border-top: 2px solid var(--primary); }
    .map-card h3 { font-size: 1.2rem; margin: 0; }
    .map-card .address { font-size: 0.75rem; margin: 0; }
    .map-card .hours { padding: 8px 0; margin: 0; font-size: 0.65rem; justify-content: space-around; }
    .map-card .btn { padding: 10px 15px; font-size: 0.7rem; width: 100%; margin-top: 5px; border-radius: 50px; }

    .newsletter-section { padding: 60px 15px; }
    .newsletter-content h2 { font-size: 1.5rem; }
    .newsletter-content p { font-size: 0.75rem; margin-bottom: 25px; }
    .input-group { flex-direction: column; background: transparent; border: none; gap: 10px; border-radius: 0; }
    .input-group input { width: 100%; border: 1px solid var(--border); background: #0f0f0f; border-radius: 50px; padding: 15px 20px; text-align: center; }
    .input-group button { width: 100%; padding: 15px; border-radius: 50px; border: 1px solid var(--primary); }
}

@media (max-width: 460px) {
    .hero h1 { font-size: 2.8rem; }
    .section-header h2 { font-size: 1.6rem; }
    .perf-content h2 { font-size: 2rem; }
}