/* Bootstrap Dialog Fix - Beautiful modal styling */

/* Fix modal backdrop transparency */
.modal-backdrop {
    background-color: rgba(0, 0, 0, 0.5) !important;
    opacity: 1 !important;
}

/* Beautiful modal content styling - fix flexbox issues */
.modal-content {
    background-color: #fff !important;
    border: 1px solid rgba(0, 0, 0, 0.2) !important;
    border-radius: 6px !important;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5) !important;
    display: block !important;
    width: 550px !important;
    height: auto !important;
    margin: 10px !important;
    position: relative !important;
    box-sizing: border-box !important;
}

/* Ensure AdModalSmall dialog is centered */
#AdModalSmall .modal-dialog {
    margin: 0 auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* Fix modal dialog dimensions */
.modal-dialog {
    width: 550px !important;
    margin: 30px auto !important;
}

/* Make modal-content transparent for token rewards modal (contains card-small) */
#AdModalSmall .modal-content {
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
    display: flex !important;
}

/* Override the transparent override for AdModalSmall specifically */
#AdModalSmall .modal-content[style*="background-color: transparent"],
#AdModalSmall .modal-content[style*="background-color:rgba(0,0,0,0)"],
#AdModalSmall .modal-content[style*="background: transparent"] {
    background-color: transparent !important;
}

/* Responsive design for mobile and smaller screens */
@media (max-width: 768px) {
    .modal-content {
        width: 95% !important;
        margin: 5px !important;
    }
    
    .modal-dialog {
        width: 95% !important;
        margin: 10px auto !important;
    }
}

@media (max-width: 480px) {
    .modal-content {
        width: 98% !important;
        margin: 2px !important;
    }
    
    .modal-dialog {
        width: 98% !important;
        margin: 5px auto !important;
    }
    
    .modal-header,
    .modal-body,
    .modal-footer {
        padding: 10px !important;
    }
    
    .form-control.input-lg {
        height: 40px !important;
        padding: 8px 12px !important;
        font-size: 16px !important;
    }
    
    .btn {
        padding: 6px 10px !important;
        font-size: 12px !important;
        margin-left: 3px !important;
    }
    
    .bootstrap-dialog-footer-buttons .btn {
        display: inline-block !important;
        width: auto !important;
        margin-left: 3px !important;
        margin-bottom: 0 !important;
    }
    
    .bootstrap-dialog-footer-buttons .btn:first-child {
        margin-left: 0 !important;
    }
}

@media (max-width: 320px) {
    .modal-content {
        width: 100% !important;
        margin: 0 !important;
        border-radius: 0 !important;
    }
    
    .modal-dialog {
        width: 100% !important;
        margin: 0 !important;
    }
    
    .modal-header,
    .modal-body,
    .modal-footer {
        padding: 8px !important;
    }
    
    .btn {
        padding: 5px 8px !important;
        font-size: 11px !important;
        margin-left: 2px !important;
    }
    
    .bootstrap-dialog-footer-buttons .btn {
        margin-left: 2px !important;
    }
}

/* Beautiful modal header styling */
.modal-header {
    background-color: #fff !important;
    border-bottom: 1px solid #e5e5e5 !important;
    border-radius: 6px 6px 0 0 !important;
    padding: 15px !important;
}

/* Beautiful modal body styling */
.modal-body {
    background-color: #fff !important;
    padding: 15px !important;
}

/* Beautiful modal footer styling */
.modal-footer {
    background-color: #fff !important;
    border-top: 1px solid #e5e5e5 !important;
    border-radius: 0 0 6px 6px !important;
    padding: 15px !important;
    text-align: right !important;
}

/* Beautiful text styling */
.bootstrap-dialog-title {
    color: #000 !important;
    font-weight: normal !important;
    margin: 0 !important;
    line-height: 1.42857143 !important;
}

.bootstrap-dialog-message {
    color: #333 !important;
}

/* Beautiful form control styling */
.form-control {
    background-color: #fff !important;
    color: #555 !important;
    border: 1px solid #ccc !important;
    border-radius: 4px !important;
    padding: 10px 12px !important;
    font-size: 14px !important;
    line-height: 1.42857143 !important;
    transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s !important;
}

.form-control:focus {
    border-color: #66afe9 !important;
    outline: 0 !important;
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 8px rgba(102, 175, 233, 0.6) !important;
}

.form-control.input-lg {
    height: 46px !important;
    padding: 10px 16px !important;
    font-size: 18px !important;
    line-height: 1.3333333 !important;
}

/* Email field styling - make it grey */
#mdlLogin_txtEmailAddress {
    background-color: #f5f5f5 !important;
    color: #666 !important;
}

/* Beautiful button styling */
.btn {
    border-radius: 4px !important;
    padding: 8px 16px !important;
    font-size: 14px !important;
    line-height: 1.42857143 !important;
    transition: all 0.15s ease-in-out !important;
    display: inline-block !important;
    margin-left: 5px !important;
}

.btn:first-child {
    margin-left: 0 !important;
}

.btn-primary {
    background-color: #337ab7 !important;
    border-color: #2e6da4 !important;
    color: #fff !important;
}

.btn-primary:hover {
    background-color: #286090 !important;
    border-color: #204d74 !important;
}

.btn-default {
    background-color: #fff !important;
    border-color: #ccc !important;
    color: #333 !important;
}

.btn-default:hover {
    background-color: #e6e6e6 !important;
    border-color: #adadad !important;
}

/* Beautiful close button styling */
.close {
    color: #000 !important;
    opacity: 0.2 !important;
    font-size: 21px !important;
    font-weight: bold !important;
    line-height: 1 !important;
    text-shadow: 0 1px 0 #fff !important;
    background: transparent !important;
    border: 0 !important;
    padding: 0 !important;
    cursor: pointer !important;
}

.close:hover {
    color: #000 !important;
    opacity: 0.5 !important;
}

/* Form group spacing */
.form-group {
    margin-bottom: 15px !important;
}

/* Bootstrap dialog footer buttons layout */
.bootstrap-dialog-footer-buttons {
    text-align: right !important;
}

.bootstrap-dialog-footer-buttons .btn {
    float: none !important;
    display: inline-block !important;
    margin-left: 5px !important;
}

.bootstrap-dialog-footer-buttons .btn:first-child {
    margin-left: 0 !important;
}

/* Override any inline styles that make elements transparent */
.modal-backdrop[style*="opacity: 0"],
.modal-backdrop[style*="opacity:0"],
.modal-backdrop[style*="background-color: transparent"],
.modal-backdrop[style*="background-color:rgba(0,0,0,0)"] {
    background-color: rgba(0, 0, 0, 0.5) !important;
    opacity: 1 !important;
}

.modal-content[style*="background-color: transparent"],
.modal-content[style*="background-color:rgba(0,0,0,0)"],
.modal-content[style*="background: transparent"] {
    background-color: #fff !important;
}

.modal-header[style*="background-color: transparent"],
.modal-header[style*="background-color:rgba(0,0,0,0)"] {
    background-color: #fff !important;
}

.modal-body[style*="background-color: transparent"],
.modal-body[style*="background-color:rgba(0,0,0,0)"] {
    background-color: #fff !important;
}

.modal-footer[style*="background-color: transparent"],
.modal-footer[style*="background-color:rgba(0,0,0,0)"] {
    background-color: #fff !important;
}

.bootstrap-dialog-title[style*="color: transparent"],
.bootstrap-dialog-title[style*="color:rgba(0,0,0,0)"],
.bootstrap-dialog-message[style*="color: transparent"],
.bootstrap-dialog-message[style*="color:rgba(0,0,0,0)"] {
    color: #333 !important;
}

.form-control[style*="background-color: transparent"],
.form-control[style*="background-color:rgba(0,0,0,0)"] {
    background-color: #fff !important;
}

.form-control[style*="color: transparent"],
.form-control[style*="color:rgba(0,0,0,0)"] {
    color: #555 !important;
}

/* Force mobile viewport behavior */
@media screen and (max-device-width: 480px) {
    .modal-content {
        width: 95% !important;
        max-width: 95% !important;
        min-width: 280px !important;
    }
    
    .modal-dialog {
        width: 95% !important;
        max-width: 95% !important;
        min-width: 280px !important;
    }
}

/* Touch device specific rules */
@media (pointer: coarse) {
    .modal-content {
        width: 95% !important;
        max-width: 95% !important;
        min-width: 280px !important;
    }
    
    .modal-dialog {
        width: 95% !important;
        max-width: 95% !important;
        min-width: 280px !important;
    }
    
    .btn {
        min-height: 44px !important; /* iOS touch target minimum */
        min-width: 44px !important;
    }
}

/* iOS Safari specific fixes */
@supports (-webkit-touch-callout: none) {
    @media screen and (max-width: 480px) {
        .modal-content {
            width: 95% !important;
            max-width: 95% !important;
            min-width: 280px !important;
            -webkit-transform: translateZ(0) !important;
            transform: translateZ(0) !important;
        }
        
        .modal-dialog {
            width: 95% !important;
            max-width: 95% !important;
            min-width: 280px !important;
            -webkit-transform: translateZ(0) !important;
            transform: translateZ(0) !important;
        }
    }
}

/* Android Chrome specific fixes */
@media screen and (-webkit-min-device-pixel-ratio: 0) {
    @media screen and (max-width: 480px) {
        .modal-content {
            width: 95% !important;
            max-width: 95% !important;
            min-width: 280px !important;
        }
        
        .modal-dialog {
            width: 95% !important;
            max-width: 95% !important;
            min-width: 280px !important;
        }
    }
}

/* Force mobile behavior for small screens regardless of device */
@media only screen and (max-width: 480px) {
    .modal-content {
        width: 95% !important;
        max-width: 95% !important;
        min-width: 280px !important;
    }
    
    .modal-dialog {
        width: 95% !important;
        max-width: 95% !important;
        min-width: 280px !important;
    }
}

/* Ensure form controls are properly sized on mobile */
@media screen and (max-width: 480px) {
    .form-group {
        margin-bottom: 15px !important;
        width: 100% !important;
    }
    
    .form-control {
        width: 100% !important;
        box-sizing: border-box !important;
    }
}

/* Force mobile behavior regardless of JavaScript interference */
@media (max-width: 480px) {
    .modal-content,
    .modal-content[style] {
        width: 95% !important;
        max-width: 95% !important;
        min-width: 280px !important;
        position: relative !important;
        left: auto !important;
        right: auto !important;
        top: auto !important;
        bottom: auto !important;
        transform: none !important;
        -webkit-transform: none !important;
    }
    
    .modal-dialog,
    .modal-dialog[style] {
        width: 95% !important;
        max-width: 95% !important;
        min-width: 280px !important;
        position: relative !important;
        left: auto !important;
        right: auto !important;
        top: auto !important;
        bottom: auto !important;
        transform: none !important;
        -webkit-transform: none !important;
    }
}

/* Override JavaScript inline styles that prevent mobile responsiveness */
@media (max-width: 480px) {
    .modal-content[style*="position: absolute"],
    .modal-content[style*="position:absolute"],
    .modal-content[style*="position: fixed"],
    .modal-content[style*="position:fixed"] {
        position: relative !important;
        width: 95% !important;
        max-width: 95% !important;
        min-width: 280px !important;
    }
    
    .modal-dialog[style*="position: absolute"],
    .modal-dialog[style*="position:absolute"],
    .modal-dialog[style*="position: fixed"],
    .modal-dialog[style*="position:fixed"] {
        position: relative !important;
        width: 95% !important;
        max-width: 95% !important;
        min-width: 280px !important;
    }
}

/* Force mobile behavior with higher specificity */
@media (max-width: 480px) {
    body .modal-content,
    html .modal-content {
        width: 95% !important;
        max-width: 95% !important;
        min-width: 280px !important;
    }
    
    body .modal-dialog,
    html .modal-dialog {
        width: 95% !important;
        max-width: 95% !important;
        min-width: 280px !important;
    }
}

/* Ensure modal backdrop works on mobile */
@media (max-width: 480px) {
    .modal-backdrop {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        width: 100% !important;
        height: 100% !important;
    }
}

/* Additional mobile-specific rules for actual mobile devices */
@media only screen and (max-width: 480px) {
    .modal-content {
        width: 95% !important;
        max-width: 95% !important;
        min-width: 280px !important;
        margin: 2.5% auto !important;
    }
    
    .modal-dialog {
        width: 95% !important;
        max-width: 95% !important;
        min-width: 280px !important;
        margin: 2.5% auto !important;
    }
}

/* Force mobile behavior for touch devices */
@media (hover: none) and (pointer: coarse) {
    .modal-content {
        width: 95% !important;
        max-width: 95% !important;
        min-width: 280px !important;
    }
    
    .modal-dialog {
        width: 95% !important;
        max-width: 95% !important;
        min-width: 280px !important;
    }
}

/* Mobile-first approach - start with mobile styles */
@media (max-width: 480px) {
    .modal-content {
        width: 95% !important;
        max-width: 95% !important;
        min-width: 280px !important;
        margin: 2.5% auto !important;
        position: relative !important;
        transform: none !important;
        -webkit-transform: none !important;
    }
    
    .modal-dialog {
        width: 95% !important;
        max-width: 95% !important;
        min-width: 280px !important;
        margin: 2.5% auto !important;
        position: relative !important;
        transform: none !important;
        -webkit-transform: none !important;
    }
}
