/*
 * Neo-Luxury Design System
 * Motors Child Theme — Shared component styles for all custom pages
 * Loaded on ALL pages via wp_enqueue_style in functions.php
 *
 * Sections:
 *  1. CSS Custom Properties (Design Tokens)
 *  2. Global Dark Page Foundation
 *  3. Layout Wrapper
 *  4. Glassmorphic Card (.stm-request-part__glass)
 *  5. Neo Header Block
 *  6. Neo Badge
 *  7. Gradient Text
 *  8. Buttons (.stm-request-part__btn-neo)
 *  9. Form Elements
 * 10. Login / Auth Gate
 * 11. Action Bar
 * 12. Status Messages
 * 13. Animations & Utilities
 * 14. Responsive
 */

/* ==========================================================================
   1. CSS Custom Properties
   ========================================================================== */
:root {
    --neo-bg: #09090b;
    --neo-surface: rgba(24, 24, 27, 0.85);
    --neo-border: rgba(255, 255, 255, 0.08);
    --neo-accent: #e11d48;
    --neo-accent-glow: rgba(225, 29, 72, 0.3);
    --neo-glass-blur: blur(20px) saturate(1.4);
    --neo-text-main: #f8fafc;
    --neo-text-muted: #94a3b8;
}

/* ==========================================================================
   2. Global Dark Page Foundation
   ========================================================================== */
body.neo-page,
body.dokan-store-page {
    background-color: var(--neo-bg) !important;
    color: var(--neo-text-main) !important;
}

body.neo-page #page,
body.neo-page #wrapper,
body.neo-page .site,
body.neo-page .site-content,
body.dokan-store-page #page,
body.dokan-store-page #wrapper,
body.dokan-store-page .site,
body.dokan-store-page .site-content {
    background-color: var(--neo-bg) !important;
}

/* Radial glow backdrop effect */
body.neo-page::before,
body.dokan-store-page::before {
    content: '';
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background:
        radial-gradient(ellipse 90% 52% at 18% 8%, rgba(225, 29, 72, 0.1) 0%, rgba(225, 29, 72, 0.05) 24%, transparent 60%),
        radial-gradient(ellipse 72% 42% at 82% 78%, rgba(225, 29, 72, 0.07) 0%, rgba(225, 29, 72, 0.04) 22%, transparent 56%);
}

body.neo-page::after,
body.dokan-store-page::after {
    content: '';
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background:
        radial-gradient(circle at 14% 18%, rgba(225, 29, 72, 0.05) 0%, transparent 22%),
        radial-gradient(circle at 86% 70%, rgba(225, 29, 72, 0.04) 0%, transparent 20%);
    filter: blur(22px);
}

/* Hide redundant theme chrome on custom pages */
body.neo-page .stm_breadcrumbs_unit,
body.neo-page .entry-header,
body.neo-page #breadcrumbs,
body.neo-page p#breadcrumbs {
    display: none !important;
}

/* ==========================================================================
   3. Layout Wrapper
   ========================================================================== */
.stm-request-part-neo {
    font-family: 'Outfit', sans-serif;
    max-width: min(100vw, 1880px);
    margin: 0 auto 100px;
    padding: 30px 4px;
    color: var(--neo-text-main);
    position: relative;
    z-index: 1;
}

body.neo-page .container,
body.dokan-store-page .container {
    max-width: min(100vw, 1880px);
    padding-left: 4px;
    padding-right: 4px;
}

@media (max-width: 768px) {

    .stm-request-part-neo,
    body.neo-page .container,
    body.dokan-store-page .container {
        padding-left: 4px;
        padding-right: 4px;
    }
}

body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container {
    max-width: min(100vw, 1880px);
    padding-left: 4px;
    padding-right: 4px;
}

body.neo-page .site-content,
body.dokan-store-page .site-content,
body.neo-page .content-area,
body.dokan-store-page .content-area {
    padding-left: 0;
    padding-right: 0;
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    box-sizing: border-box;
    width: 100%;
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    max-width: min(100vw, 1880px);
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    padding-left: 4px;
    padding-right: 4px;
}

body.neo-page .site-content,
body.dokan-store-page .site-content,
body.neo-page .content-area,
body.dokan-store-page .content-area {
    max-width: 100%;
}

body.neo-page .site-content,
body.dokan-store-page .site-content,
body.neo-page .content-area,
body.dokan-store-page .content-area {
    margin-left: auto;
    margin-right: auto;
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    margin-left: auto;
    margin-right: auto;
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    width: min(100vw, 1880px);
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    max-width: min(100vw, 1880px);
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    padding-left: 4px !important;
    padding-right: 4px !important;
}

body.neo-page .site-content,
body.dokan-store-page .site-content,
body.neo-page .content-area,
body.dokan-store-page .content-area {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    max-width: min(100vw, 1880px) !important;
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    width: 100%;
}

body.neo-page,
body.dokan-store-page {
    --neo-page-gap: 4px;
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    padding-left: var(--neo-page-gap) !important;
    padding-right: var(--neo-page-gap) !important;
}

@media (max-width: 768px) {

    body.neo-page,
    body.dokan-store-page {
        --neo-page-gap: 4px;
    }
}

body.neo-page .site-content,
body.dokan-store-page .site-content,
body.neo-page .content-area,
body.dokan-store-page .content-area,
body.neo-page .entry-content,
body.dokan-store-page .entry-content {
    max-width: 100%;
}

body.neo-page .site-content,
body.dokan-store-page .site-content,
body.neo-page .content-area,
body.dokan-store-page .content-area,
body.neo-page .entry-content,
body.dokan-store-page .entry-content {
    width: 100%;
}

body.neo-page .site-content,
body.dokan-store-page .site-content,
body.neo-page .content-area,
body.dokan-store-page .content-area,
body.neo-page .entry-content,
body.dokan-store-page .entry-content {
    box-sizing: border-box;
}

body.neo-page .site-content,
body.dokan-store-page .site-content,
body.neo-page .content-area,
body.dokan-store-page .content-area,
body.neo-page .entry-content,
body.dokan-store-page .entry-content {
    margin-left: auto;
    margin-right: auto;
}

body.neo-page .site-content,
body.dokan-store-page .site-content,
body.neo-page .content-area,
body.dokan-store-page .content-area,
body.neo-page .entry-content,
body.dokan-store-page .entry-content {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    margin-bottom: 100px;
}

@media (max-width: 768px) {

    body.neo-page .container,
    body.dokan-store-page .container,
    body.neo-page .site-content>.container,
    body.dokan-store-page .site-content>.container,
    body.neo-page #main>.container,
    body.dokan-store-page #main>.container,
    .stm-request-part-neo {
        margin-bottom: 80px;
    }
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    padding-top: 30px;
    padding-bottom: 0;
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container {
    overflow: visible;
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    position: relative;
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    z-index: 1;
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    min-width: 0;
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    width: 100%;
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    max-width: min(100vw, 1880px);
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    padding-left: 4px;
    padding-right: 4px;
}

body.neo-page .site-content,
body.dokan-store-page .site-content,
body.neo-page .content-area,
body.dokan-store-page .content-area,
body.neo-page .entry-content,
body.dokan-store-page .entry-content {
    padding-left: 0;
    padding-right: 0;
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    box-sizing: border-box;
}

body.neo-page .site-content,
body.dokan-store-page .site-content,
body.neo-page .content-area,
body.dokan-store-page .content-area,
body.neo-page .entry-content,
body.dokan-store-page .entry-content {
    box-sizing: border-box;
}

body.neo-page .site-content,
body.dokan-store-page .site-content,
body.neo-page .content-area,
body.dokan-store-page .content-area,
body.neo-page .entry-content,
body.dokan-store-page .entry-content {
    width: 100%;
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    width: 100%;
}

body.neo-page .site-content,
body.dokan-store-page .site-content,
body.neo-page .content-area,
body.dokan-store-page .content-area,
body.neo-page .entry-content,
body.dokan-store-page .entry-content,
body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    max-width: 100%;
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    width: 100%;
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    max-width: min(100vw, 1880px);
}

body.neo-page .container,
body.dokan-store-page .container,
body.neo-page .site-content>.container,
body.dokan-store-page .site-content>.container,
body.neo-page #main>.container,
body.dokan-store-page #main>.container,
.stm-request-part-neo {
    padding-left: 4px;
    padding-right: 4px;
}

body.neo-page .site-content,
body.dokan-store-page .site-content,
body.neo-page .content-area,
body.dokan-store-page .content-area,
body.neo-page .entry-content,
body.dokan-store-page .entry-content {
    padding-left: 0;
    padding-right: 0;
}

body.dokan-store-page .stm-request-part-neo::before {
    content: '';
    position: absolute;
    top: 40px;
    left: 50%;
    transform: translateX(-50%);
    width: min(1180px, 96%);
    height: 520px;
    pointer-events: none;
    z-index: -1;
    background:
        radial-gradient(ellipse 42% 34% at 24% 18%, rgba(225, 29, 72, 0.22) 0%, rgba(225, 29, 72, 0.12) 28%, transparent 66%),
        radial-gradient(ellipse 38% 30% at 76% 28%, rgba(225, 29, 72, 0.16) 0%, rgba(225, 29, 72, 0.08) 24%, transparent 62%),
        radial-gradient(ellipse 32% 26% at 50% 72%, rgba(190, 24, 93, 0.1) 0%, transparent 58%);
    filter: blur(28px);
}

/* ==========================================================================
   4. Glassmorphic Card
   ========================================================================== */
.stm-request-part__glass {
    background: var(--neo-surface);
    backdrop-filter: var(--neo-glass-blur);
    -webkit-backdrop-filter: var(--neo-glass-blur);
    border: 1px solid var(--neo-border);
    border-radius: 28px;
    padding: 30px;
    height: 100%;
    box-shadow:
        0 18px 50px rgba(0, 0, 0, 0.28),
        0 0 0 1px rgba(225, 29, 72, 0.06),
        0 0 44px rgba(225, 29, 72, 0.08);
}

@media (max-width: 768px) {
    body.dokan-store-page .stm-request-part-neo::before {
        top: 24px;
        width: 96%;
        height: 420px;
        background:
            radial-gradient(ellipse 56% 34% at 30% 16%, rgba(225, 29, 72, 0.2) 0%, rgba(225, 29, 72, 0.1) 28%, transparent 64%),
            radial-gradient(ellipse 50% 30% at 72% 30%, rgba(225, 29, 72, 0.14) 0%, rgba(225, 29, 72, 0.07) 24%, transparent 60%);
    }
}

/* ==========================================================================
   5. Neo Header Block
   ========================================================================== */
.neo-header {
    margin-bottom: 40px;
}

.neo-header h1,
.neo-header h2 {
    margin: 8px 0 12px;
    line-height: 1.1;
}

.neo-subtitle {
    color: var(--neo-text-muted);
    font-size: 16px;
    margin: 0;
    line-height: 1.6;
    max-width: 650px;
}

/* ==========================================================================
   6. Neo Badge
   ========================================================================== */
.neo-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 12px;
    background: rgba(225, 29, 72, 0.1);
    border: 1px solid rgba(225, 29, 72, 0.25);
    border-radius: 999px;
    color: var(--neo-accent);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    font-family: 'Outfit', sans-serif;
}

/* ==========================================================================
   7. Gradient Text
   ========================================================================== */
.gradient-text {
    background: linear-gradient(135deg, #ffffff 0%, #94a3b8 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ==========================================================================
   8. Buttons
   ========================================================================== */
.stm-request-part__btn-neo {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 28px;
    background: var(--neo-accent);
    color: #fff;
    text-decoration: none;
    border: none;
    border-radius: 14px;
    font-family: 'Outfit', sans-serif;
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    position: relative;
    overflow: hidden;
}

.stm-request-part__btn-neo:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 30px var(--neo-accent-glow);
    color: #fff;
}

.stm-request-part__btn-neo.secondary {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid var(--neo-border);
    color: var(--neo-text-muted);
}

.stm-request-part__btn-neo.secondary:hover {
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
    box-shadow: none;
}

.stm-request-part__btn-neo.ghost {
    background: transparent;
    border: 1px solid var(--neo-border);
    color: var(--neo-text-muted);
}

.stm-request-part__btn-neo.ghost:hover {
    border-color: var(--neo-accent);
    color: var(--neo-accent);
    background: rgba(225, 29, 72, 0.05);
    box-shadow: none;
}

/* Animated glow layer inside button */
.stm-request-part__btn-neo .btn-glow {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.15) 0%, transparent 60%);
    pointer-events: none;
}

/* ==========================================================================
   9. Form Elements
   ========================================================================== */
.stm-request-part__form-neo input[type="text"],
.stm-request-part__form-neo input[type="email"],
.stm-request-part__form-neo input[type="number"],
.stm-request-part__form-neo input[type="tel"],
.stm-request-part__form-neo select,
.stm-request-part__form-neo textarea {
    width: 100%;
    background: rgba(9, 9, 11, 0.6);
    border: 1px solid var(--neo-border);
    border-radius: 12px;
    color: var(--neo-text-main);
    font-family: 'Outfit', sans-serif;
    font-size: 14px;
    padding: 12px 16px;
    outline: none;
    transition: border-color 0.3s, box-shadow 0.3s;
}

.stm-request-part__form-neo input[type="number"] {
    appearance: textfield;
    -moz-appearance: textfield;
}

.stm-request-part__form-neo input[type="number"]::-webkit-outer-spin-button,
.stm-request-part__form-neo input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.stm-request-part__form-neo input:focus,
.stm-request-part__form-neo select:focus,
.stm-request-part__form-neo textarea:focus {
    border-color: var(--neo-accent);
    box-shadow: 0 0 0 3px var(--neo-accent-glow);
}

.stm-request-part__form-neo input::placeholder,
.stm-request-part__form-neo textarea::placeholder {
    color: var(--neo-text-muted);
}

.stm-request-part__form-neo label {
    display: block;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: var(--neo-text-muted);
    margin-bottom: 8px;
}

.neo-field-group {
    display: flex;
    flex-direction: column;
    gap: 18px;
    flex: 1 1 auto;
}

.neo-field {
    min-width: 0;
}

.neo-field-row {
    display: grid;
    grid-template-columns: minmax(140px, 1fr) minmax(0, 2fr);
    gap: 16px;
    align-items: start;
}

.neo-field-row .neo-field {
    display: flex;
    flex-direction: column;
}

.neo-field-row .neo-field label {
    min-height: 32px;
}

.neo-field.w-50 {
    grid-column: span 1;
}

.neo-field.w-100 {
    grid-column: span 1;
}

.neo-section-header {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 22px;
}

.neo-icon-wrapper {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: rgba(225, 29, 72, 0.1);
    border: 1px solid rgba(225, 29, 72, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--neo-accent);
    flex-shrink: 0;
}

.neo-section-header h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 700;
    color: var(--neo-text-main);
    line-height: 1.25;
}

.neo-select-wrapper {
    position: relative;
}

.neo-select-arrow {
    position: absolute;
    top: 50%;
    right: 14px;
    transform: translateY(-50%);
    width: 8px;
    height: 8px;
    border-right: 2px solid var(--neo-text-muted);
    border-bottom: 2px solid var(--neo-text-muted);
    transform: translateY(-65%) rotate(45deg);
    pointer-events: none;
}

.neo-select-wrapper .select2-container {
    width: 100% !important;
}

.neo-select-wrapper .select2-container--default .select2-selection--single {
    height: 50px;
    display: flex;
    align-items: center;
    background: rgba(9, 9, 11, 0.6);
    border: 1px solid var(--neo-border);
    border-radius: 12px;
    box-shadow: none;
    transition: border-color 0.3s, box-shadow 0.3s;
}

.neo-select-wrapper .select2-container--default .select2-selection--single .select2-selection__rendered {
    width: 100%;
    padding: 0 44px 0 16px;
    color: var(--neo-text-main);
    font-size: 14px;
    line-height: 48px;
}

.neo-select-wrapper .select2-container--default .select2-selection--single .select2-selection__placeholder {
    color: var(--neo-text-muted);
}

.neo-select-wrapper .select2-container--default .select2-selection--single .select2-selection__arrow {
    display: none;
}

.neo-select-wrapper .select2-container--default.select2-container--open .select2-selection--single,
.neo-select-wrapper .select2-container--default.select2-container--focus .select2-selection--single {
    border-color: var(--neo-accent);
    box-shadow: 0 0 0 3px var(--neo-accent-glow);
}

.select2-dropdown.neo-select2-dropdown {
    background: rgba(10, 10, 14, 0.96);
    border: 1px solid rgba(225, 29, 72, 0.18);
    border-radius: 16px;
    overflow: hidden;
    box-shadow:
        0 24px 60px rgba(0, 0, 0, 0.42),
        0 0 0 1px rgba(225, 29, 72, 0.06);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}

.select2-dropdown.neo-select2-dropdown .select2-search--dropdown {
    padding: 12px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.select2-dropdown.neo-select2-dropdown .select2-search--dropdown .select2-search__field {
    height: 42px;
    padding: 0 14px;
    border-radius: 10px;
    border: 1px solid var(--neo-border);
    background: rgba(255, 255, 255, 0.03);
    color: var(--neo-text-main);
    outline: none;
}

.select2-dropdown.neo-select2-dropdown .select2-results__options {
    max-height: 280px;
    padding: 8px;
}

.select2-dropdown.neo-select2-dropdown .select2-results__option {
    min-height: 40px;
    padding: 10px 12px;
    border-radius: 10px;
    color: var(--neo-text-main);
    font-size: 14px;
    transition: background 0.2s ease, color 0.2s ease;
}

.select2-dropdown.neo-select2-dropdown .select2-results__option--highlighted[aria-selected] {
    background: rgba(225, 29, 72, 0.16);
    color: #fff;
}

.select2-dropdown.neo-select2-dropdown .select2-results__option[aria-selected="true"] {
    background: rgba(225, 29, 72, 0.1);
    color: #fff;
}

/* Grid layout for form sections */
.neo-grid-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
    align-items: stretch;
}

.neo-grid-layout>.full-width {
    grid-column: 1 / -1;
}

.neo-grid-layout>.stm-request-part__glass {
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.neo-grid-layout>.stm-request-part__glass .neo-field-group {
    justify-content: flex-start;
}

.neo-hint {
    color: var(--neo-text-muted);
    font-size: 11px;
    font-weight: 400;
}

.large-input {
    font-size: 16px !important;
    padding: 14px 18px !important;
}

.mt-10 {
    margin-top: 10px;
}

/* Upload zone */
.neo-upload-zone {
    position: relative;
    border: 1px dashed rgba(225, 29, 72, 0.28);
    border-radius: 22px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.02), rgba(255, 255, 255, 0)),
        rgba(9, 9, 11, 0.42);
    min-height: 220px;
    overflow: hidden;
    transition: border-color 0.25s ease, background 0.25s ease, transform 0.25s ease;
}

.neo-upload-zone:hover {
    border-color: rgba(225, 29, 72, 0.45);
    background:
        linear-gradient(180deg, rgba(225, 29, 72, 0.06), rgba(255, 255, 255, 0)),
        rgba(9, 9, 11, 0.48);
}

.neo-file-input {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
    z-index: 2;
}

.neo-upload-content {
    min-height: 220px;
    padding: 28px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 14px;
    text-align: center;
}

.neo-upload-icon {
    position: relative;
    width: 72px;
    height: 72px;
    border-radius: 20px;
    border: 1px solid rgba(225, 29, 72, 0.2);
    background: rgba(225, 29, 72, 0.08);
    color: var(--neo-accent);
    display: flex;
    align-items: center;
    justify-content: center;
}

.neo-pulse {
    position: absolute;
    inset: -8px;
    border-radius: 24px;
    border: 1px solid rgba(225, 29, 72, 0.16);
    animation: neo-pulse 2.2s ease-out infinite;
}

.neo-upload-content h4 {
    margin: 0;
    font-size: 20px;
    line-height: 1.2;
    color: var(--neo-text-main);
}

.neo-upload-content p {
    margin: 0;
    max-width: 460px;
    font-size: 14px;
    line-height: 1.6;
    color: var(--neo-text-muted);
}

.neo-upload-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 10px 18px;
    border-radius: 999px;
    border: 1px solid rgba(225, 29, 72, 0.28);
    background: rgba(225, 29, 72, 0.1);
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.neo-preview-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 14px;
    margin-top: 18px;
}

.stm-request-part__preview {
    position: relative;
    aspect-ratio: 1;
    border-radius: 18px;
    overflow: hidden;
    background-color: rgba(9, 9, 11, 0.7);
    background-position: center;
    background-size: cover;
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.stm-request-part__preview span {
    position: absolute;
    left: 10px;
    bottom: 10px;
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(9, 9, 11, 0.72);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

/* ==========================================================================
   10. Login / Auth Gate
   ========================================================================== */
.stm-request-part__login-neo {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 400px;
    text-align: center;
}

.neo-login-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    max-width: 480px;
}

.neo-login-content h2 {
    font-size: 28px;
    font-weight: 800;
    color: var(--neo-text-main);
    margin: 0;
}

.neo-login-content p {
    color: var(--neo-text-muted);
    font-size: 15px;
    margin: 0;
    line-height: 1.6;
}

.neo-lock-icon {
    color: var(--neo-text-muted);
}

/* ==========================================================================
   11. Action Bar
   ========================================================================== */
.neo-action-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-top: 32px;
}

.neo-status-message {
    flex: 1 1 320px;
    min-height: 24px;
    padding: 0;
    color: var(--neo-text-muted);
    font-size: 14px;
    line-height: 1.5;
}

.neo-status-message:empty {
    display: none;
}

.neo-status-message.is-success,
.neo-status-message.is-error {
    min-height: auto;
    padding: 12px 16px;
    border-radius: 14px;
    border: 1px solid transparent;
}

.neo-status-message.is-success {
    color: #86efac;
    background: rgba(34, 197, 94, 0.1);
    border-color: rgba(34, 197, 94, 0.2);
}

.neo-status-message.is-error {
    color: #fca5a5;
    background: rgba(239, 68, 68, 0.1);
    border-color: rgba(239, 68, 68, 0.2);
}

.neo-action-bar .stm-request-part__btn-neo.primary {
    flex: 0 0 auto;
    min-width: 240px;
    justify-content: center;
}

.neo-action-bar-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 24px;
}

.neo-action-bar-top .neo-status-message {
    flex: 1 1 auto;
}

.neo-private-request-banner {
    margin-bottom: 24px;
    padding: 24px 26px;
    border-color: rgba(225, 29, 72, 0.26);
    background:
        radial-gradient(circle at top left, rgba(225, 29, 72, 0.16), transparent 42%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.02)),
        rgba(15, 23, 42, 0.76);
}

.neo-private-request-banner.is-error {
    border-color: rgba(239, 68, 68, 0.28);
}

.neo-private-request-banner__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 10px;
    color: var(--neo-accent);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.neo-private-request-banner__title {
    color: var(--neo-text-main);
    font-size: 22px;
    font-weight: 700;
    line-height: 1.2;
}

.neo-private-request-banner__text {
    margin: 10px 0 0;
    color: var(--neo-text-muted);
    line-height: 1.6;
}

.neo-private-request-banner__meta {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 14px;
    margin-top: 18px;
}

.neo-private-request-banner__meta span {
    display: block;
    margin-bottom: 4px;
    color: var(--neo-text-muted);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.neo-private-request-banner__meta strong {
    color: var(--neo-text-main);
    font-size: 14px;
    line-height: 1.5;
}

/* Booking */
.neo-booking-card {
    padding: 30px 28px;
}

.neo-booking-fee-wrapper {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 20px 22px;
    border-radius: 22px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background:
        radial-gradient(circle at top left, rgba(225, 29, 72, 0.14), transparent 45%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.02)),
        rgba(10, 10, 14, 0.52);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.neo-fee-amount {
    color: var(--neo-text-main);
    font-size: 24px;
    font-weight: 800;
    line-height: 1.2;
}

.neo-fee-label {
    color: var(--neo-text-muted);
    font-size: 13px;
    line-height: 1.5;
}

.neo-booking-card .neo-grid-layout {
    margin-top: 26px !important;
}

.neo-booking-card .neo-field {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.neo-booking-card .neo-field label {
    display: block;
    margin: 0;
    color: var(--neo-text-main);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.neo-booking-card .neo-field input {
    width: 100%;
    min-width: 0;
    min-height: 54px;
    padding: 0 16px;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.02)),
        rgba(10, 10, 14, 0.62);
    color: var(--neo-text-main);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
    transition: border-color 0.25s ease, box-shadow 0.25s ease, background-color 0.25s ease;
}

.neo-booking-card .neo-field input::placeholder {
    color: var(--neo-text-muted);
}

.neo-booking-card .neo-field input:focus {
    border-color: rgba(225, 29, 72, 0.38);
    box-shadow: 0 0 0 3px rgba(225, 29, 72, 0.12);
    outline: none;
}

.neo-booking-card .neo-field input[type="date"],
.neo-booking-card .neo-field input[type="time"] {
    appearance: none;
    -webkit-appearance: none;
}

.neo-booking-card .neo-field input[type="date"]::-webkit-calendar-picker-indicator,
.neo-booking-card .neo-field input[type="time"]::-webkit-calendar-picker-indicator {
    opacity: 0.85;
    cursor: pointer;
    filter: invert(1);
}

.neo-booking-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-top: 28px;
}

.neo-booking-actions .neo-status-text {
    flex: 1 1 280px;
    min-height: 24px;
}

.neo-booking-actions .stm-request-part__btn-neo.primary {
    flex: 0 0 auto;
    min-width: 260px;
    justify-content: center;
}

.neo-list-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
    align-items: start;
    margin-bottom: 36px;
}

.neo-skeleton-item {
    min-height: 180px;
    border-radius: 28px;
    animation: neo-pulse 1.8s ease-in-out infinite;
}

.neo-empty-card {
    min-height: 320px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.neo-empty-state {
    width: 100%;
    max-width: 540px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 14px;
    text-align: center;
    margin: 0 auto;
}

.neo-empty-icon {
    width: 72px;
    height: 72px;
    border-radius: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--neo-accent);
    background: rgba(225, 29, 72, 0.08);
    border: 1px solid rgba(225, 29, 72, 0.18);
}

.neo-empty-state h3 {
    margin: 0;
    font-size: 24px;
    line-height: 1.2;
    color: var(--neo-text-main);
}

.neo-empty-state p {
    margin: 0;
    font-size: 15px;
    line-height: 1.6;
    color: var(--neo-text-muted);
}

.stm-request-item {
    position: relative;
}

.neo-item-badge {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: #fff;
    background: rgba(148, 163, 184, 0.2);
    border: 1px solid rgba(148, 163, 184, 0.18);
}

.neo-item-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.neo-item-badge--secondary {
    background: rgba(225, 29, 72, 0.12);
    border-color: rgba(225, 29, 72, 0.24);
    color: #fda4af;
}

.neo-item-badge--accent {
    background: rgba(59, 130, 246, 0.14);
    border-color: rgba(59, 130, 246, 0.24);
    color: #93c5fd;
}

.neo-item-badge.status-pending,
.neo-item-badge.status-pr-pending {
    background: rgba(245, 158, 11, 0.14);
    border-color: rgba(245, 158, 11, 0.24);
    color: #fbbf24;
}

.neo-item-badge.status-approved,
.neo-item-badge.status-pr-approved {
    background: rgba(34, 197, 94, 0.14);
    border-color: rgba(34, 197, 94, 0.24);
    color: #86efac;
}

.neo-item-badge.status-cancelled,
.neo-item-badge.status-pr-cancelled,
.neo-item-badge.status-rejected,
.neo-item-badge.status-pr-rejected {
    background: rgba(239, 68, 68, 0.14);
    border-color: rgba(239, 68, 68, 0.24);
    color: #fca5a5;
}

.neo-item-title {
    margin: 16px 0 12px;
    font-size: 22px;
    line-height: 1.25;
    color: var(--neo-text-main);
}

.neo-item-meta {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.neo-meta-row {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--neo-text-muted);
    font-size: 14px;
    line-height: 1.5;
}

.neo-meta-row svg {
    flex-shrink: 0;
    color: var(--neo-accent);
}

/* ==========================================================================
   12. Status & Progress
   ========================================================================== */
.neo-status-message-wrap {
    margin-bottom: 20px;
}

.neo-status-message-wrap:empty {
    display: none;
}

.neo-status-ok,
.neo-status-error {
    padding: 12px 18px;
    border-radius: 12px;
    font-weight: 600;
    font-size: 14px;
}

.neo-status-ok {
    background: rgba(34, 197, 94, 0.1);
    border: 1px solid rgba(34, 197, 94, 0.2);
    color: #4ade80;
}

.neo-status-error {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.2);
    color: #f87171;
}

.neo-progress-bar {
    height: 3px;
    background: var(--neo-border);
    border-radius: 2px;
    margin-bottom: 32px;
    overflow: hidden;
}

.neo-progress-fill {
    height: 100%;
    width: 0;
    background: var(--neo-accent);
    transition: width 0.4s ease;
}

/* ==========================================================================
   13. Summary Grid (Vendor Dashboard)
   ========================================================================== */
.neo-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 20px;
    margin-bottom: 32px;
}

.neo-summary-loading-card {
    height: 100px;
    animation: neo-pulse 1.5s ease-in-out infinite;
}

.neo-cta-section {
    margin-bottom: 28px;
}

/* ==========================================================================
   14. Vendors Directory (Parts Vendors)
   ========================================================================== */
.neo-search-wrapper {
    margin-bottom: 40px;
}

.neo-search-form {
    display: flex;
    gap: 16px;
    max-width: 600px;
}

.neo-search-input-group {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
}

.neo-search-input-group svg {
    position: absolute;
    left: 16px;
    color: var(--neo-text-muted);
    pointer-events: none;
}

.neo-search-input-group input {
    width: 100%;
    background: rgba(9, 9, 11, 0.6);
    border: 1px solid var(--neo-border);
    border-radius: 14px;
    color: var(--neo-text-main);
    font-family: 'Outfit', sans-serif;
    font-size: 15px;
    padding: 14px 16px 14px 44px;
    outline: none;
    transition: border-color 0.3s, box-shadow 0.3s;
}

.neo-search-input-group input:focus {
    border-color: var(--neo-accent);
    box-shadow: 0 0 0 3px var(--neo-accent-glow);
}

.neo-vendors-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 24px;
    margin-bottom: 40px;
}

.neo-vendor-card {
    padding: 24px;
    transition: transform 0.3s ease, border-color 0.3s ease;
    display: flex;
    flex-direction: column;
    min-height: 100%;
}

.neo-vendor-card:hover {
    transform: translateY(-4px);
    border-color: rgba(225, 29, 72, 0.4);
}

.neo-vendor-link {
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.neo-vendor-avatar {
    width: 100%;
    height: 208px;
    flex: 0 0 208px;
    align-self: stretch;
    border-radius: 24px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    margin-bottom: 20px;
    overflow: hidden;
    background:
        radial-gradient(circle at top left, rgba(225, 29, 72, 0.14), transparent 48%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.02)),
        rgba(12, 18, 31, 0.92);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 18px 34px rgba(0, 0, 0, 0.24);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 14px;
}

.neo-vendor-avatar img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.02);
}

.neo-avatar-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 52px;
    font-weight: 700;
    color: var(--neo-text-muted);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.03);
}

.neo-vendor-info {
    flex: 1;
    margin-bottom: 20px;
}

.neo-vendor-name {
    font-size: 20px;
    font-weight: 700;
    margin: 0 0 10px 0;
    color: var(--neo-text-main);
    line-height: 1.3;
}

.neo-vendor-rating {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
}

.neo-stars {
    color: var(--neo-text-muted);
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 15px;
    letter-spacing: 0;
}

.neo-star.filled {
    color: #fbbf24;
}

.neo-star.half {
    color: #fbbf24;
    position: relative;
}

/* simple half star fallback */
.neo-star.empty {
    color: var(--neo-border);
}

.neo-rating-count {
    font-size: 13px;
    color: var(--neo-text-muted);
}

.neo-rating-pill {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: var(--neo-text-muted);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.neo-vendor-action {
    margin-top: auto;
    padding-top: 16px;
}

.stm-request-part__btn-neo.small {
    width: 100%;
    padding: 10px 16px;
    font-size: 14px;
    justify-content: space-between;
}

/* Pagination */
.neo-pagination-wrapper {
    display: flex;
    justify-content: center;
    margin-top: 50px;
}

.neo-pagination-wrapper .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 12px;
    border: 1px solid var(--neo-border);
    background: var(--neo-surface);
    color: var(--neo-text-main);
    text-decoration: none;
    margin: 0 4px;
    font-weight: 600;
    transition: all 0.2s;
}

.neo-pagination-wrapper .page-numbers:hover {
    border-color: var(--neo-accent);
    color: var(--neo-accent);
}

.neo-pagination-wrapper .page-numbers.current {
    background: var(--neo-accent);
    border-color: var(--neo-accent);
    color: #fff;
}

/* ==========================================================================
   15. Vendor Supported Makes Checklist
   ========================================================================== */
.neo-makes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: 16px;
}

.neo-make-check {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 20px 16px;
    cursor: pointer;
    position: relative;
    border: 1px solid var(--neo-border);
    transition: all 0.3s ease;
    text-align: center;
}

.neo-make-check:hover {
    border-color: rgba(255, 255, 255, 0.2);
    transform: translateY(-2px);
}

.neo-make-check.is-selected {
    border-color: var(--neo-accent);
    background: rgba(225, 29, 72, 0.05);
}

.neo-make-media {
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    border-radius: 12px;
    padding: 8px;
    overflow: hidden;
}

.neo-make-media img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.neo-make-media.fallback {
    background: rgba(255, 255, 255, 0.05);
    color: var(--neo-text-muted);
    font-size: 24px;
    font-weight: 700;
}

.neo-make-text {
    font-size: 14px;
    font-weight: 600;
    color: var(--neo-text-main);
}

.neo-check-orb {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    border: 2px solid var(--neo-border);
    background: var(--neo-surface);
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.neo-make-check.is-selected .neo-check-orb {
    border-color: var(--neo-accent);
    background: var(--neo-accent);
}

.neo-make-check.is-selected .neo-check-orb::after {
    content: '';
    width: 6px;
    height: 10px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
    margin-top: -2px;
}

/* ==========================================================================
   16. Animations & Utilities
   ========================================================================== */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(24px);
    }

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

@keyframes neo-pulse {

    0%,
    100% {
        opacity: 0.5;
    }

    50% {
        opacity: 0.9;
    }
}

.fade-in-up {
    opacity: 0;
    transform: translateY(20px);
    animation: fadeInUp 0.8s ease forwards;
}

.fade-in-up[style*="animation-delay: 0.1s"] {
    animation-delay: 0.1s;
}

.fade-in-up[style*="animation-delay: 0.2s"] {
    animation-delay: 0.2s;
}

.fade-in-up[style*="animation-delay: 0.3s"] {
    animation-delay: 0.3s;
}

.fade-in-up[style*="animation-delay: 0.4s"] {
    animation-delay: 0.4s;
}

.neo-section-divider {
    border: none;
    border-top: 1px solid var(--neo-border);
    margin: 18px 0;
}

/* ==========================================================================
   15. Bulldozer Dealers Page
   ========================================================================== */
.neo-bulldozer-dealers-page {
    gap: 26px;
}

.neo-bulldozer-map-card {
    padding: 26px;
}

.neo-bulldozer-map-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 18px;
}

.neo-bulldozer-map-header>div:first-child {
    min-width: 0;
    flex: 1 1 auto;
}

.neo-bulldozer-map-header .stm-request-part__btn-neo {
    width: auto;
    min-width: 220px;
    max-width: 320px;
    flex: 0 0 auto;
    align-self: center;
    justify-content: center;
    white-space: nowrap;
}

.neo-map-caption {
    margin: 8px 0 0;
    color: var(--neo-text-muted);
    font-size: 0.95rem;
    line-height: 1.55;
}

.neo-bulldozer-map-shell {
    overflow: hidden;
    border-radius: 24px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background:
        radial-gradient(circle at top, rgba(225, 29, 72, 0.18), transparent 42%),
        rgba(9, 11, 21, 0.92);
    min-height: 420px;
}

.neo-bulldozer-map-shell .wpgmza_map,
.neo-bulldozer-map-shell .neo-bulldozer-map-canvas {
    width: 100% !important;
    height: 420px !important;
    border-radius: 24px;
}

.neo-bulldozer-map-shell .wpgmza_map>div,
.neo-bulldozer-map-shell .neo-bulldozer-map-canvas>div {
    height: 420px !important;
}

.neo-bulldozer-map-shell .wpgmza-inner-stack,
.neo-bulldozer-map-shell .wpgmza-store-locator,
.neo-bulldozer-map-shell .wpgmza-marker-listing-category-filter,
.neo-bulldozer-map-shell .wpgmza-marker-listing {
    display: none !important;
}

.neo-bulldozer-map-fallback {
    min-height: 420px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    color: var(--neo-text-muted);
    text-align: center;
    padding: 24px;
}

.neo-bulldozer-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
}

.neo-bulldozer-search-form {
    width: 100%;
    display: flex;
    align-items: stretch;
    gap: 14px;
}

.neo-bulldozer-search-form .neo-search-input-group {
    min-height: 58px;
    flex: 1 1 auto;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 0 18px;
    border-radius: 18px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(14, 17, 30, 0.88);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.neo-bulldozer-search-form .neo-search-input-group svg {
    color: var(--neo-text-muted);
    flex-shrink: 0;
}

.neo-bulldozer-search-form .neo-search-input-group input {
    width: 100%;
    min-width: 0;
    height: auto;
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
    color: var(--neo-text-main);
    font-size: 0.98rem;
}

.neo-bulldozer-search-form .neo-search-input-group input::placeholder {
    color: rgba(255, 255, 255, 0.44);
}

.neo-bulldozer-search-form .neo-search-input-group input:focus {
    outline: none;
}

.neo-bulldozer-search-form .stm-request-part__btn-neo {
    width: auto;
    min-width: 180px;
    flex: 0 0 auto;
    justify-content: center;
}

.neo-bulldozer-dealers-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 22px;
}

.neo-bulldozer-dealer-card {
    padding: 0;
    overflow: hidden;
    min-width: 0;
}

.neo-bulldozer-dealer-link {
    display: flex;
    flex-direction: column;
    height: 100%;
    color: inherit;
    text-decoration: none;
}

.neo-bulldozer-dealer-media {
    position: relative;
    min-height: 160px;
    background:
        linear-gradient(180deg, rgba(225, 29, 72, 0.16), transparent 60%),
        rgba(14, 17, 31, 0.9);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    padding: 18px;
}

.neo-bulldozer-dealer-media img {
    width: 100%;
    height: 124px;
    object-fit: contain;
    background: rgba(4, 6, 13, 0.78);
    display: block;
    border-radius: 18px;
}

.neo-bulldozer-dealer-placeholder {
    width: 88px;
    height: 88px;
    border-radius: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.09);
    border: 1px solid rgba(255, 255, 255, 0.08);
    font-size: 2rem;
    font-weight: 800;
    color: #fff;
    box-shadow: 0 18px 34px rgba(0, 0, 0, 0.26);
}

.neo-bulldozer-dealer-content {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 22px;
    min-width: 0;
    flex: 1;
}

.neo-bulldozer-dealer-topline {
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

.neo-bulldozer-dealer-name {
    margin: 0;
    font-size: 1.2rem;
    line-height: 1.3;
    font-weight: 700;
    color: #fff;
}

.neo-bulldozer-dealer-location {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    color: var(--neo-text-muted);
    font-size: 0.95rem;
}

.neo-bulldozer-dealer-location i {
    margin-top: 3px;
    color: var(--neo-accent);
    flex-shrink: 0;
}

.neo-bulldozer-dealer-about {
    margin: 0;
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.96rem;
    line-height: 1.65;
}

.neo-bulldozer-dealer-footer {
    margin-top: auto;
    display: flex;
    justify-content: flex-start;
}

.neo-bulldozer-empty-state {
    padding: 54px 24px;
    text-align: center;
}

.neo-bulldozer-empty-state .neo-empty-icon {
    opacity: 0.38;
    margin-bottom: 18px;
}

body.page-template-page-bulldozer-dealers .footer_widgets_wrapper,
body.page-template-page-bulldozer-dealers .widgets-footer,
body.page-template-page-bulldozer-dealers .footer_widgets,
body.page-template-page-accident-dealers .footer_widgets_wrapper,
body.page-template-page-accident-dealers .widgets-footer,
body.page-template-page-accident-dealers .footer_widgets,
body.page-template-page-new-car-dealers .footer_widgets_wrapper,
body.page-template-page-new-car-dealers .widgets-footer,
body.page-template-page-new-car-dealers .footer_widgets {
    display: none !important;
}

body.page-template-page-bulldozer-dealers #trp-floater-ls,
body.page-template-page-accident-dealers #trp-floater-ls,
body.page-template-page-new-car-dealers #trp-floater-ls {
    left: auto !important;
    right: 24px !important;
    bottom: 24px !important;
}

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

/* ==========================================================================
   16. Responsive
   ========================================================================== */
@media (max-width: 900px) {
    .stm-request-part-neo {
        padding: 20px 16px;
    }

    .stm-request-part__glass {
        padding: 20px;
        border-radius: 20px;
    }

    .neo-grid-layout {
        grid-template-columns: 1fr;
    }

    .neo-field-row {
        grid-template-columns: 1fr;
    }

    .neo-section-header {
        align-items: flex-start;
    }

    .neo-action-bar {
        flex-direction: column;
        align-items: stretch;
    }

    .neo-action-bar-top {
        flex-direction: column;
        align-items: stretch;
    }

    .stm-request-part__btn-neo {
        width: 100%;
        justify-content: center;
    }

    .neo-upload-content {
        min-height: 190px;
        padding: 22px 18px;
    }

    body.page-template-page-bulldozer-dealers #trp-floater-ls,
    body.page-template-page-accident-dealers #trp-floater-ls,
    body.page-template-page-new-car-dealers #trp-floater-ls {
        right: 16px !important;
        bottom: 16px !important;
    }

    .neo-bulldozer-map-card {
        padding: 20px;
    }

    .neo-bulldozer-map-header {
        flex-direction: column;
        align-items: stretch;
    }

    .neo-bulldozer-map-header .stm-request-part__btn-neo {
        width: 100%;
        max-width: none;
        min-width: 0;
        align-self: stretch;
    }

    .neo-bulldozer-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    .neo-bulldozer-search-form {
        flex-direction: column;
    }

    .neo-bulldozer-map-shell,
    .neo-bulldozer-map-shell .wpgmza_map,
    .neo-bulldozer-map-shell .neo-bulldozer-map-canvas,
    .neo-bulldozer-map-fallback {
        min-height: 320px;
        height: 320px !important;
    }

    .neo-bulldozer-map-shell .wpgmza_map>div,
    .neo-bulldozer-map-shell .neo-bulldozer-map-canvas>div {
        height: 320px !important;
    }

    .neo-bulldozer-dealers-grid {
        grid-template-columns: 1fr;
    }
}

/* Rehlatac-aligned light marketplace overrides */
:root {
    --neo-bg: #f7f1ea;
    --neo-surface: rgba(255, 252, 247, 0.92);
    --neo-border: rgba(104, 76, 41, 0.14);
    --neo-accent: #c8952f;
    --neo-accent-glow: rgba(200, 149, 47, 0.22);
    --neo-text-main: #1f1811;
    --neo-text-muted: #776a59;
    --neo-glass-blur: blur(18px) saturate(1.1);
}

body.neo-page,
body.dokan-store-page {
    background:
        radial-gradient(circle at top left, rgba(210, 164, 84, 0.12), transparent 22%),
        radial-gradient(circle at 100% 0%, rgba(255, 232, 194, 0.4), transparent 18%),
        linear-gradient(180deg, #fffdfa 0%, #faf6f0 44%, #f4ede3 100%) !important;
    color: var(--neo-text-main) !important;
}

body.neo-page #page,
body.neo-page #wrapper,
body.neo-page .site,
body.neo-page .site-content,
body.dokan-store-page #page,
body.dokan-store-page #wrapper,
body.dokan-store-page .site,
body.dokan-store-page .site-content {
    background: transparent !important;
}

body.neo-page::before,
body.dokan-store-page::before {
    background:
        radial-gradient(ellipse 68% 42% at 14% 10%, rgba(200, 149, 47, 0.12) 0%, rgba(200, 149, 47, 0.06) 28%, transparent 62%),
        radial-gradient(ellipse 58% 34% at 88% 76%, rgba(94, 66, 35, 0.06) 0%, transparent 54%);
}

body.neo-page::after,
body.dokan-store-page::after {
    background:
        radial-gradient(circle at 16% 18%, rgba(255, 255, 255, 0.75) 0%, transparent 20%),
        radial-gradient(circle at 82% 72%, rgba(214, 180, 118, 0.14) 0%, transparent 18%);
    filter: blur(18px);
}

.stm-request-part-neo {
    font-family: 'Manrope', sans-serif;
    color: var(--neo-text-main);
}

.stm-request-part__glass,
.neo-vendor-card,
.neo-request-card,
.neo-offer-card,
.neo-summary-card,
.neo-bulldozer-dealer-card,
.neo-bulldozer-map-card,
.neo-empty-state,
.neo-bulldozer-empty-state,
.neo-empty-requests,
.neo-empty-requests-card {
    background: linear-gradient(180deg, rgba(255, 253, 249, 0.96) 0%, rgba(247, 241, 232, 0.96) 100%) !important;
    backdrop-filter: var(--neo-glass-blur);
    -webkit-backdrop-filter: var(--neo-glass-blur);
    border: 1px solid rgba(115, 87, 51, 0.12) !important;
    box-shadow: 0 22px 52px rgba(39, 29, 20, 0.08) !important;
    color: var(--neo-text-main) !important;
}

.neo-header h1,
.neo-header h2,
.neo-section-header h2,
.neo-section-header h3,
.neo-bulldozer-map-header h3 {
    color: #1d1711 !important;
    font-family: 'Sora', sans-serif;
    letter-spacing: -0.04em;
}

.neo-subtitle,
.neo-map-caption,
.neo-empty-state p,
.neo-bulldozer-empty-state p,
.neo-search-form input,
.neo-vendor-info p,
.neo-summary-card p {
    color: var(--neo-text-muted) !important;
}

.neo-badge,
.neo-rating-pill,
.neo-status-badge,
.stm-request-part__status {
    background: rgba(255, 241, 207, 0.9) !important;
    border: 1px solid rgba(200, 149, 47, 0.2) !important;
    color: #9a6d16 !important;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.neo-badge::before,
.neo-rating-pill::before,
.neo-status-badge::before,
.stm-request-part__status::before {
    background: #c8952f !important;
}

.stm-request-part__btn-neo,
.neo-action-btn.primary,
.neo-search-form button,
.neo-bulldozer-map-header .stm-request-part__btn-neo {
    background: linear-gradient(180deg, #f4d48c 0%, #d8aa4b 100%) !important;
    border: 1px solid rgba(179, 129, 28, 0.14) !important;
    box-shadow: 0 16px 28px rgba(200, 149, 47, 0.18) !important;
    color: #24190e !important;
    font-weight: 800 !important;
}

.stm-request-part__btn-neo span,
.neo-bulldozer-map-header .stm-request-part__btn-neo span,
.neo-search-form button span {
    color: inherit !important;
}

.stm-request-part__btn-neo:hover,
.neo-bulldozer-map-header .stm-request-part__btn-neo:hover,
.neo-search-form button:hover {
    background: linear-gradient(180deg, #f7ddb0 0%, #ca9528 100%) !important;
    color: #24190e !important;
    transform: translateY(-2px);
}

.stm-request-part__btn-neo.secondary,
.stm-request-part__btn-neo.small,
.neo-action-btn.sms,
.neo-action-btn.call,
.neo-action-btn.wa {
    background: rgba(255, 253, 249, 0.96) !important;
    border: 1px solid rgba(115, 87, 51, 0.14) !important;
    box-shadow: 0 10px 22px rgba(39, 29, 20, 0.06) !important;
    color: #24190e !important;
}

.neo-action-bar,
.neo-action-bar-top,
.neo-filter-bar,
.neo-bulldozer-toolbar,
.neo-hours-card,
.neo-store-times-dropdown,
.neo-search-input-group {
    background: rgba(255, 252, 247, 0.95) !important;
    border: 1px solid rgba(115, 87, 51, 0.12) !important;
    box-shadow: 0 14px 34px rgba(39, 29, 20, 0.06) !important;
    color: var(--neo-text-main) !important;
}

.neo-search-input-group input,
.neo-search-form input,
.stm-request-part-neo input[type='text'],
.stm-request-part-neo input[type='search'],
.stm-request-part-neo input[type='email'],
.stm-request-part-neo input[type='number'],
.stm-request-part-neo input[type='tel'],
.stm-request-part-neo textarea,
.stm-request-part-neo select {
    background: rgba(255, 255, 255, 0.96) !important;
    border: 1px solid rgba(115, 87, 51, 0.12) !important;
    color: #221910 !important;
    border-radius: 16px !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.stm-request-part-neo input:focus,
.stm-request-part-neo textarea:focus,
.stm-request-part-neo select:focus {
    border-color: rgba(200, 149, 47, 0.42) !important;
    box-shadow: 0 0 0 4px rgba(200, 149, 47, 0.12) !important;
    outline: 0;
}

.neo-stat-item,
.neo-summary-metric,
.neo-request-meta-chip,
.neo-make-chip {
    background: rgba(255, 248, 235, 0.9) !important;
    border: 1px solid rgba(200, 149, 47, 0.14) !important;
    color: #7f5d1d !important;
}

.neo-stat-value,
.neo-summary-metric__value,
.neo-vendor-name,
.neo-bulldozer-dealer-name,
.neo-empty-state h2,
.neo-bulldozer-empty-state h2 {
    color: #1d1711 !important;
}

.neo-stat-label,
.neo-bulldozer-dealer-location span,
.neo-bulldozer-dealer-about,
.neo-about-text,
.neo-hours-card__summary,
.neo-hours-card__line,
.neo-empty-state p,
.neo-bulldozer-empty-state p {
    color: var(--neo-text-muted) !important;
}

.neo-empty-icon,
.neo-status-icon,
.neo-stat-icon {
    background: rgba(255, 241, 207, 0.84) !important;
    color: #b27b18 !important;
}

.neo-bulldozer-map-shell,
.neo-map-card {
    background: #efe5d7 !important;
    border-radius: 24px;
    overflow: hidden;
}

.neo-vendor-card:hover,
.neo-request-card:hover,
.neo-offer-card:hover,
.neo-summary-card:hover,
.neo-bulldozer-dealer-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 26px 56px rgba(39, 29, 20, 0.11) !important;
}

body.site-rtl.neo-page .neo-header,
body.site-rtl.neo-page .neo-hours-card,
body.site-rtl.neo-page .neo-about-section,
body.site-rtl.neo-page .neo-vendor-info,
body.site-rtl.dokan-store-page .neo-header,
body.site-rtl.dokan-store-page .neo-hours-card,
body.site-rtl.dokan-store-page .neo-about-section,
body.site-rtl.dokan-store-page .neo-vendor-info {
    text-align: right;
}

body.site-rtl.neo-page .neo-profile-actions,
body.site-rtl.neo-page .neo-makes-heading,
body.site-rtl.neo-page .neo-hours-card__title-wrap,
body.site-rtl.dokan-store-page .neo-profile-actions,
body.site-rtl.dokan-store-page .neo-makes-heading,
body.site-rtl.dokan-store-page .neo-hours-card__title-wrap {
    flex-direction: row-reverse;
}

@media (max-width: 768px) {

    .neo-stat-item,
    .neo-summary-card,
    .neo-request-card,
    .neo-offer-card,
    .neo-vendor-card,
    .neo-bulldozer-dealer-card {
        border-radius: 20px !important;
    }
}

/* ==========================================================================
   17. Shared Template Utilities
   ========================================================================== */
.neo-delay-05 {
    animation-delay: 0.05s;
}

.neo-delay-1 {
    animation-delay: 0.1s;
}

.neo-delay-2 {
    animation-delay: 0.2s;
}

.neo-delay-25 {
    animation-delay: 0.25s;
}

.neo-delay-3 {
    animation-delay: 0.3s;
}

.neo-delay-4 {
    animation-delay: 0.4s;
}

.neo-is-hidden {
    display: none !important;
}

.neo-plugin-alert-shell {
    padding: 40px 15px;
}

.neo-map-container--directory {
    margin-block-end: 30px;
    border-radius: 24px;
    overflow: hidden;
    border: 1px solid var(--neo-border);
}

.neo-map-fallback--spacious {
    padding: 40px;
}

.neo-section-header--tight {
    margin-block-end: 20px;
}

.neo-empty-directory-state {
    padding: 60px 20px;
    text-align: center;
}

.neo-empty-icon--muted {
    margin-block-end: 20px;
    opacity: 0.3;
}

.neo-empty-title {
    margin: 0;
    font-weight: 600;
}

.neo-empty-copy {
    margin: 12px auto 0;
    max-width: 44rem;
    color: var(--neo-text-muted) !important;
}

.neo-empty-action {
    margin-top: 20px;
}

.neo-vendor-rating--stack {
    margin-block-end: 10px;
}

.neo-bulldozer-dealer-location--compact {
    margin-block-start: 8px;
}

.neo-search-input-group svg {
    left: auto;
    inset-inline-start: 16px;
}

.neo-search-input-group input {
    padding-inline-end: 16px;
    padding-inline-start: 44px;
}

.neo-private-request-banner {
    margin-block-end: 20px;
}

.neo-private-request-banner.is-error {
    border-color: rgba(180, 58, 58, 0.2) !important;
}

body.page-template-page-request-part .neo-header {
    margin-block-end: 18px;
    max-width: 56rem;
}

body.page-template-page-request-part .neo-progress-bar {
    margin-block: 0 24px;
}

body.page-template-page-request-part .neo-grid-layout {
    align-items: start;
    gap: 24px;
}

body.page-template-page-request-part .neo-upload-zone {
    min-height: 280px;
}

body.page-template-page-request-part .neo-action-bar {
    align-items: center;
    border-radius: 24px;
    gap: 16px;
    justify-content: space-between;
    margin-top: 24px;
    padding: 18px 20px;
}

body.page-template-page-request-part .neo-action-bar .stm-request-part__btn-neo {
    min-width: min(100%, 280px);
}

body.page-template-page-request-part .neo-status-message {
    flex: 1 1 280px;
    min-height: 24px;
}

body.site-rtl.neo-page .neo-search-input-group svg,
body.site-rtl.dokan-store-page .neo-search-input-group svg {
    inset-inline-end: 16px;
    inset-inline-start: auto;
}

body.site-rtl.neo-page .neo-search-input-group input,
body.site-rtl.dokan-store-page .neo-search-input-group input {
    padding-inline-end: 44px;
    padding-inline-start: 16px;
}

@media (max-width: 900px) {
    .neo-map-container--directory {
        margin-block-end: 24px;
    }

    .neo-map-fallback--spacious {
        padding: 28px 20px;
    }

    .neo-empty-directory-state {
        padding: 44px 18px;
    }

    body.page-template-page-request-part .neo-upload-zone {
        min-height: 0;
    }
}

/* Red Button Overrides - Decisive specificity to resolve all conflicts */
html body.motors-website-ui .neo-bulldozer-search-form .stm-request-part__btn-neo,
html body.motors-website-ui .neo-bulldozer-map-header .stm-request-part__btn-neo,
html body.motors-website-ui .stm-request-part__btn-neo.primary,
html body.motors-website-ui .stm-request-part__btn-neo.small {
    background: linear-gradient(180deg, #ef4444 0%, #b91c1c 100%) !important;
    border: 1px solid rgba(153, 27, 27, 0.2) !important;
    box-shadow: 0 16px 28px rgba(185, 28, 28, 0.25) !important;
    color: #ffffff !important;
}

html body.motors-website-ui .neo-bulldozer-search-form .stm-request-part__btn-neo span,
html body.motors-website-ui .neo-bulldozer-map-header .stm-request-part__btn-neo span,
html body.motors-website-ui .stm-request-part__btn-neo.primary span,
html body.motors-website-ui .stm-request-part__btn-neo.small span {
    color: #ffffff !important;
}

html body.motors-website-ui .neo-bulldozer-search-form .stm-request-part__btn-neo:hover,
html body.motors-website-ui .neo-bulldozer-map-header .stm-request-part__btn-neo:hover,
html body.motors-website-ui .stm-request-part__btn-neo.primary:hover,
html body.motors-website-ui .stm-request-part__btn-neo.small:hover {
    background: linear-gradient(180deg, #f87171 0%, #dc2626 100%) !important;
    color: #ffffff !important;
}