/* ── DS Garage Enquiry — Frontend Styles ── */

/* ── Wrapper ── */
div.dsge-wrapper {
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

/* ── Trigger Button ── */
button.dsge-open-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 9px !important;
    background: #e62020 !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 6px !important;
    padding: 14px 28px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    letter-spacing: 0.8px !important;
    cursor: pointer !important;
    text-transform: uppercase !important;
    font-family: inherit !important;
    width: 100% !important;
    justify-content: center !important;
    box-sizing: border-box !important;
    /*box-shadow: 0 4px 20px rgba(230, 32, 32, 0.4) !important;*/
    transition: background 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease !important;
    text-decoration: none !important;
    line-height: 1.4 !important;
    outline: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}

button.dsge-open-btn:hover {
    background: #c41a1a !important;
    transform: translateY(-2px) !important;
    /*box-shadow: 0 7px 24px rgba(230, 32, 32, 0.50) !important;*/
    color: #ffffff !important;
}

button.dsge-open-btn:active {
    transform: translateY(0) !important;
    /*box-shadow: 0 3px 12px rgba(230, 32, 32, 0.35) !important;*/
}

button.dsge-open-btn:focus {
    outline: none !important;
    /*box-shadow: 0 0 0 3px rgba(230, 32, 32, 0.30) !important;*/
}

.dsge-btn-icon {
    display: flex !important;
    align-items: center !important;
    flex-shrink: 0 !important;
    pointer-events: none !important;
}

.dsge-btn-icon svg {
    display: block !important;
}

/* ── Overlay ── */
#dsge-overlay.dsge-overlay {
    display: none;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: rgba(0, 0, 0, 0.75) !important;
    z-index: 9999999 !important;
    justify-content: center !important;
    align-items: flex-start !important;
    padding: 20px 16px !important;
    box-sizing: border-box !important;
    overflow-y: auto !important;
    backdrop-filter: blur(4px) !important;
    -webkit-backdrop-filter: blur(4px) !important;
}

#dsge-overlay.dsge-overlay.dsge-active {
    display: flex !important;
}

/* ── Modal Container ── */
#dsge-overlay .dsge-modal {
    background: #ffffff !important;
    border-radius: 14px !important;
    width: 100% !important;
    max-width: 700px !important;
    margin: auto !important;
    box-shadow: 0 28px 90px rgba(0, 0, 0, 0.40) !important;
    animation: dsge-slidein 0.28s cubic-bezier(0.34, 1.1, 0.64, 1) !important;
    overflow: hidden !important;
    position: relative !important;
    box-sizing: border-box !important;
}

@keyframes dsge-slidein {
    from { opacity: 0; transform: translateY(-30px) scale(0.97); }
    to   { opacity: 1; transform: translateY(0)    scale(1);    }
}

/* ── Modal Header ── */
#dsge-overlay .dsge-modal-header {
    background: linear-gradient(135deg, #111111 0%, #2a2a2a 100%) !important;
    padding: 18px 24px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    border-bottom: 3px solid #e62020 !important;
    box-sizing: border-box !important;
}

#dsge-overlay .dsge-logo-area {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
}

#dsge-overlay .dsge-logo-area span {
    color: #ffffff !important;
    font-size: 17px !important;
    font-weight: 700 !important;
    letter-spacing: 0.4px !important;
    font-family: inherit !important;
}

/* ── Close Button ── */
#dsge-overlay button.dsge-close-btn {
    background: rgba(255, 255, 255, 0.12) !important;
    border: none !important;
    color: #ffffff !important;
    cursor: pointer !important;
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    min-height: 36px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background 0.2s ease, transform 0.2s ease !important;
    flex-shrink: 0 !important;
    padding: 0 !important;
    outline: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    box-shadow: none !important;
    line-height: 1 !important;
}

#dsge-overlay button.dsge-close-btn:hover {
    background: #e62020 !important;
    transform: rotate(90deg) !important;
    color: #ffffff !important;
}

#dsge-overlay button.dsge-close-btn svg {
    display: block !important;
    pointer-events: none !important;
}

/* ── Modal Body ── */
#dsge-overlay .dsge-modal-body {
    padding: 26px 24px !important;
    max-height: calc(100vh - 160px) !important;
    overflow-y: auto !important;
    box-sizing: border-box !important;
    background: #ffffff !important;
}

/* ── Form Grid ── */
#dsge-overlay .dsge-form-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
}

#dsge-overlay .dsge-field {
    display: flex !important;
    flex-direction: column !important;
    gap: 5px !important;
}

#dsge-overlay .dsge-field.dsge-full {
    grid-column: 1 / -1 !important;
}

/* ── Labels ── */
#dsge-overlay .dsge-field label {
    font-size: 11px !important;
    font-weight: 700 !important;
    color: #444444 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.7px !important;
    font-family: inherit !important;
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
}

#dsge-overlay .dsge-field label span {
    color: #e62020 !important;
}

/* ── Inputs, Selects, Textareas ── */
#dsge-overlay .dsge-field input,
#dsge-overlay .dsge-field select,
#dsge-overlay .dsge-field textarea {
    border: 1.5px solid #dddddd !important;
    border-radius: 7px !important;
    padding: 11px 13px !important;
    font-size: 14px !important;
    color: #1a1a1a !important;
    background: #f9f9f9 !important;
    transition: border-color 0.2s, box-shadow 0.2s, background 0.2s !important;
    outline: none !important;
    font-family: inherit !important;
    width: 100% !important;
    box-sizing: border-box !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    display: block !important;
    margin: 0 !important;
    box-shadow: none !important;
    line-height: 1.4 !important;
}

#dsge-overlay .dsge-field select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23555' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 13px center !important;
    padding-right: 36px !important;
    cursor: pointer !important;
}

#dsge-overlay .dsge-field input:focus,
#dsge-overlay .dsge-field select:focus,
#dsge-overlay .dsge-field textarea:focus {
    border-color: #e62020 !important;
    box-shadow: 0 0 0 3px rgba(230, 32, 32, 0.13) !important;
    background: #ffffff !important;
    outline: none !important;
}

#dsge-overlay .dsge-field input.dsge-input-error,
#dsge-overlay .dsge-field select.dsge-input-error,
#dsge-overlay .dsge-field textarea.dsge-input-error {
    border-color: #e62020 !important;
    background: #fff5f5 !important;
    box-shadow: 0 0 0 3px rgba(230, 32, 32, 0.08) !important;
}

#dsge-overlay .dsge-field textarea {
    resize: vertical !important;
    min-height: 84px !important;
}

/* ── Error Messages ── */
#dsge-overlay .dsge-error {
    font-size: 11px !important;
    color: #e62020 !important;
    font-weight: 600 !important;
    min-height: 16px !important;
    display: block !important;
    font-family: inherit !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ── Submit Area ── */
#dsge-overlay .dsge-submit-area {
    margin-top: 22px !important;
}

#dsge-overlay button.dsge-submit-btn {
    width: 100% !important;
    padding: 15px 20px !important;
    background: #e62020 !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 8px !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    transition: background 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease !important;
    box-shadow: 0 4px 20px rgba(230, 32, 32, 0.35) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 9px !important;
    letter-spacing: 0.6px !important;
    font-family: inherit !important;
    text-transform: uppercase !important;
    outline: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    line-height: 1.4 !important;
    box-sizing: border-box !important;
}

#dsge-overlay button.dsge-submit-btn:hover:not(:disabled) {
    background: #c41a1a !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 7px 24px rgba(230, 32, 32, 0.45) !important;
    color: #ffffff !important;
}

#dsge-overlay button.dsge-submit-btn:disabled {
    opacity: 0.68 !important;
    cursor: not-allowed !important;
    transform: none !important;
}

/* ── Spinner ── */
.dsge-spin {
    animation: dsge-rotate 0.85s linear infinite !important;
    display: block !important;
}

@keyframes dsge-rotate {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}

/* ── Success & Error Messages ── */
#dsge-overlay .dsge-success {
    display: none !important;
    align-items: center !important;
    gap: 10px !important;
    background: #f0fdf4 !important;
    border: 1.5px solid #22c55e !important;
    border-radius: 8px !important;
    color: #15803d !important;
    padding: 13px 16px !important;
    margin-top: 14px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    box-sizing: border-box !important;
}

#dsge-overlay .dsge-form-error {
    background: #fff5f5 !important;
    border: 1.5px solid #e62020 !important;
    border-radius: 8px !important;
    color: #c41a1a !important;
    padding: 12px 16px !important;
    margin-top: 14px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    display: none !important;
    box-sizing: border-box !important;
}

/* ── Responsive: Tablet ── */
@media (max-width: 768px) {
    #dsge-overlay .dsge-modal {
        max-width: 100% !important;
    }
}

/* ── Responsive: Mobile ── */
@media (max-width: 600px) {
    #dsge-overlay.dsge-overlay {
        padding: 0 !important;
        align-items: flex-end !important;
    }

    #dsge-overlay .dsge-modal {
        border-radius: 18px 18px 0 0 !important;
        margin: 0 !important;
        max-width: 100% !important;
        animation: dsge-slidein-mobile 0.28s cubic-bezier(0.34, 1.1, 0.64, 1) !important;
    }

    @keyframes dsge-slidein-mobile {
        from { opacity: 0; transform: translateY(70px); }
        to   { opacity: 1; transform: translateY(0);   }
    }

    #dsge-overlay .dsge-form-grid {
        grid-template-columns: 1fr !important;
    }

    #dsge-overlay .dsge-field.dsge-full {
        grid-column: 1 !important;
    }

    #dsge-overlay .dsge-modal-body {
        padding: 18px 16px !important;
    }

    #dsge-overlay .dsge-modal-header {
        padding: 15px 16px !important;
    }

    #dsge-overlay .dsge-logo-area span {
        font-size: 15px !important;
    }

    button.dsge-open-btn {
        padding: 13px 20px !important;
        font-size: 13px !important;
    }
}

@media (max-width: 360px) {
    button.dsge-open-btn {
        padding: 12px 16px !important;
        font-size: 12px !important;
        letter-spacing: 0.5px !important;
    }
}