/* modals/slide_in_right/modal_slide_in_right.css */

.modal-slide-in-right {
    position: fixed;
    top: 0;
    left: 0; 
    width: 100%;
    height: 100%;
    z-index: 10000000055 !important; 
    display: flex; 
    opacity: 0; 
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0s linear 0.3s;
    pointer-events: none; 
}

.modal-slide-in-right.show {
    opacity: 1;
    visibility: visible;
    transition-delay: 0s;
    pointer-events: auto; 
}

.modal-slide-in-right .modal-backdrop {
    position: absolute; 
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5); 
    opacity: 0;
    transition: opacity 0.3s ease;
    pointer-events: none; 
    cursor: pointer; 
}
.modal-slide-in-right.show .modal-backdrop {
    opacity: 1;
    pointer-events: auto; 
}

.modal-slide-in-right .modal-dialog {
    position: fixed; 
    top: 0;
    right: 0;
    bottom: 0; /* <<< CORRECTION: Remplacer height: 100vh; par ceci */
    z-index: 10; 
    background: var(--primary-light); 
    color: #fff;
    box-shadow: -5px 0 20px rgba(0, 0, 0, 0.35); 
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.35s cubic-bezier(0.25, 0.1, 0.25, 1), width 0.3s ease-in-out; 
    max-width: 100%; 
    border-left: 1px solid var(--primary-bg, rgba(19, 20, 31, 0.5)); 
}

/* Tailles (Desktop) */
.modal-slide-in-right.modal-size-small .modal-dialog {
    width: 380px; 
}
.modal-slide-in-right.modal-size-large .modal-dialog {
    width: 600px; 
}
@media (min-width: 1280px) { /* xl */
    .modal-slide-in-right.modal-size-large .modal-dialog {
        width: 900px;
    }
}

.modal-slide-in-right.show .modal-dialog {
    transform: translateX(0); 
}

.modal-slide-in-right .modal-content {
   display: flex;
   flex-direction: column;
   height: 100%; 
   overflow: hidden; 
   border-radius: 0; 
}

.modal-slide-in-right .modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 1rem; 
    border-bottom: 1px solid var(--gray-700, #374151);
    flex-shrink: 0;
    background: var(--primary-bg); 
}

.modal-slide-in-right .modal-title {
    margin: 0;
    font-size: 1.1rem; 
    font-weight: 500;
    color: #f3f4f6; 
    overflow-wrap: break-word;
    word-wrap: break-word; 
    word-break: break-word; 
    hyphens: auto; 
}

.modal-slide-in-right .modal-header button {
     background: none; border: none; color: #9ca3af; cursor: pointer;
     padding: 0.4rem; line-height: 1; opacity: 0.7; transition: all 0.2s ease;
}
.modal-slide-in-right .modal-header button:hover { color: #fff; opacity: 1; transform: scale(1.1); }
.modal-slide-in-right .modal-close { font-size: 1.5rem; }
.modal-slide-in-right .modal-toggle-size { font-size: 0.9rem; }

.modal-slide-in-right .modal-body {
    padding: 0; 
    overflow-y: auto; 
    flex-grow: 1;
    background-color: var(--primary-light); 
    overflow-wrap: break-word; 
    word-wrap: break-word;  
    word-break: break-word; 
}
.modal-slide-in-right .modal-body > .widget { 
    height: 100%; 
    display: flex; 
    flex-direction: column; 
}

.modal-slide-in-right .modal-body.no-header {
    padding-top: 0; 
}
.modal-slide-in-right .modal-content:has(> .modal-body.no-header) {
    border-top-left-radius: 8px; 
}

@media (max-width: 767px) { 
    .modal-slide-in-right .modal-backdrop {
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        background-color: rgba(0, 0, 0, 0.65);
    }
    .modal-slide-in-right .modal-dialog {
        will-change: transform; 
    }
}