:root {
    --main-color: #1e40af;
    --main-family: 'Roboto', sans-serif;
    --tw-text-opacity: rgb(100, 116, 139);
}

/* Base styles */
body {
    font-family: var(--main-family) !important;
    background-color: var(--main-color) !important;
}

body .wrapper {
    padding: 1.25rem 2rem !important;
}

/* Sidebar styles */
.sidebar {
    background-color: var(--main-color) !important;
    padding: 0 !important;
    box-shadow: none !important;
}

.main-header #header-logo a {
    padding: 0 !important;
}

/* Menu items base styles */
#main-menu .menu .menu-item {
    padding: 0 !important;
    transition: background-color 0.15s ease-in-out !important;
    border-top-left-radius: 9999px !important;
    border-bottom-left-radius: 9999px !important;
}

#main-menu .menu .menu-item a {
    margin: 0 !important;
    padding-bottom: 0 !important;
    padding-top: 0 !important;
}

/* Active menu item styles */
@media screen and (max-width:991.99px) {

    #main-menu .menu>.menu-item.active,
    #main-menu .menu>.menu-item.active:hover>a,
    #main-menu .menu>.menu-item.active>a,
    #main-menu .menu>.menu-item.active:not(:hover)>a,
    #main-menu .menu>.menu-item.active>a i {
        background-color: unset !important;
        color: white !important;
    }
}



#main-menu .menu .menu-item.active a {
    color: black !important;
}

#main-menu .menu .menu-item.active i {
    color: var(--main-color) !important;
}

#main-menu .menu .submenu .menu-item.active {
    background-color: unset !important;
}

#main-menu .menu .submenu .menu-item.active a,
#main-menu .menu .submenu .menu-item.active i,
#main-menu .menu .submenu .menu-item.active .menu-item-label {
    color: white !important;
}


/* Menu item hover state */
#main-menu .menu .menu-item:not(.expanded):not(.submenu .menu-item):hover {
    background-color: rgba(255, 255, 255, 0.05) !important;
}

/* Menu item contents styles */
#main-menu .menu .menu-item-contents,
#main-menu .menu .menu-item-contents i {
    color: white !important;
    margin-right: 2rem !important;
}

#main-menu .submenu .menu-item-contents,
#main-menu .submenu .menu-item-contents i,
#main-menu .submenu .menu-item-contents a,
#main-menu .submenu .menu-item-contents .menu-item-label {
    color: #ffffffb3 !important;
}

#main-menu .menu .menu-item-contents {
    font-size: 14px !important;
    font-variation-settings: normal !important;
    letter-spacing: 0.35px !important;
    line-height: 20px !important;
    font-weight: 300 !important;
    height: 50px !important;
    display: flex !important;
    align-items: center !important;
    padding-left: 1.25rem !important;
    color: #fff !important;
    margin-bottom: 0.25rem !important;
    position: relative !important;
    border-radius: 9999px !important;
}

#main-menu .menu .menu-item-contents i {
    font-size: 1.2rem !important;
}

/* Menu header and submenu styles */
#main-menu .menu .menu-header {
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    margin: 1.5rem 1.25rem 1.5rem 0 !important;
    padding: 0 !important;
}

#main-menu .menu .menu-item .submenu-toggle .submenu-toggle-icon {
    color: white !important;
    position: absolute !important;
    right: 1rem !important;
}

/* Submenu styles */
.has-submenu .submenu {
    background-color: rgba(0, 0, 0, 0.1) !important;
    border-radius: 8px !important;
    color: rgba(255, 255, 255, 0.7) !important;
}

/* Content area styles */
.content-wrapper {
    padding: 0 !important;
}

.main-content {
    background-color: rgb(241, 245, 249) !important;
    padding: 0 22px 3rem 22px !important;
    border-radius: 30px !important;
}

.custom-card,
.form-fieldset {
    background-color: white !important;
    box-shadow: rgba(0, 0, 0, 0.043) 0px 3px 5px 0px !important;
    border: 1px solid rgb(226, 232, 240);
    border-radius: 10px !important;
    padding: 1.25rem !important;
}

.main-content .content-header {
    background-color: rgb(241, 245, 249) !important;
    display: flex !important;
    vertical-align: middle !important;
    justify-content: center !important;
    align-items: center !important;
}

.main-content .content-header .title {
    font-family: var(--main-family) !important;
    font-size: 1.125rem !important;
    font-weight: 500 !important;
    color: rgb(71, 85, 105) !important;
    letter-spacing: 0.35px !important;
    line-height: 28px !important;
}

.main-content .content-body {
    margin-top: 1.125rem !important;
}

/* Celui avant et apres l'active */
#main-menu .menu .menu-item {
    padding-right: 1.25rem !important;
}

#main-menu .menu .menu-item:has(+ .menu-item.active) a {
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 10000px !important;
}

#main-menu .menu .menu-item.active+.menu-item a {
    border-top-right-radius: 10px !important;
    border-bottom-right-radius: 0 !important;
}

.btn-primary {
    transition: all 0.2s ease-in-out !important;
    border: 1px solid !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0.5rem 0.75rem !important;
    border-radius: 0.375rem !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    margin-right: 0.5rem !important;
    box-shadow: rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.1) 0px 2px 4px -2px !important;
}

.btn-primary:focus {
    --ring-color: rgb(30, 58, 138) !important;
    --ring-opacity: 0.2 !important;
    box-shadow: 0 0 0 4px var(--ring-color) !important;
    outline: none !important;
}

.btn-primary:hover:not(:disabled) {
    background-color: rgba(30, 58, 138, 0.9) !important;
    border-color: rgba(30, 58, 138, 0.9) !important;
}

.btn-primary:not(button) {
    text-align: center !important;
}

.btn-primary:disabled {
    opacity: 0.7 !important;
    cursor: not-allowed !important;
}

.btn-primary {
    background-color: rgb(30, 58, 138) !important;
    border-color: rgb(30, 58, 138) !important;
    color: white !important;
}

.btn-secondary {
    transition: all 0.2s ease-in-out !important;
    border: 1px solid !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0.5rem 0.75rem !important;
    border-radius: 0.375rem !important;
    cursor: pointer !important;
    font-weight: 300 !important;
    box-shadow: rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.1) 0px 2px 4px -2px !important;
}

.btn-secondary:focus {
    --ring-color: rgb(30, 58, 138) !important;
    --ring-opacity: 0.2 !important;
    box-shadow: 0 0 0 4px var(--ring-color) !important;
    outline: none !important;
}

.btn-secondary:hover:not(:disabled) {
    background-color: rgba(226, 232, 240, 0.9) !important;
    border-color: rgba(226, 232, 240, 0.9) !important;
}

.btn-secondary:not(button) {
    text-align: center !important;
}

.btn-secondary:disabled {
    opacity: 0.7 !important;
    cursor: not-allowed !important;
}

.btn-secondary {
    background-color: white !important;
    border-color: white !important;
    color: rgb(15, 23, 42) !important;
}

.btn-danger {
    transition: all 0.2s ease-in-out !important;
    border: 1px solid !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0.5rem 0.75rem !important;
    border-radius: 0.375rem !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    margin-right: 0.5rem !important;
    box-shadow: rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.1) 0px 2px 4px -2px !important;
}

.btn-danger:focus {
    --ring-color: rgb(220, 38, 38) !important;
    --ring-opacity: 0.2 !important;
    box-shadow: 0 0 0 4px var(--ring-color) !important;
    outline: none !important;
}

.btn-danger:hover:not(:disabled) {
    background-color: rgba(220, 38, 38, 0.9) !important;
    border-color: rgba(220, 38, 38, 0.9) !important;
}

.btn-danger:not(button) {
    text-align: center !important;
}

.btn-danger:disabled {
    opacity: 0.7 !important;
    cursor: not-allowed !important;
}

.btn-danger {
    background-color: rgb(220, 38, 38) !important;
    border-color: rgb(220, 38, 38) !important;
    color: white !important;
}




/** Table **/
.main-content .table thead th {
    background-color: rgb(248, 250, 252) !important;
    border-top: 1px solid rgb(229, 231, 235) !important;
    border-bottom: 1px solid rgb(229, 231, 235) !important;
    box-shadow: none !important;
}

.main-content .table thead th * {
    padding: 0 !important;
}

.main-content .table thead th,
.main-content .table tbody td {
    padding: 1rem 1.25rem !important;
    text-align: center !important;
}

.main-content .table thead th a,
.main-content .table thead th .action-label,
.main-content .table thead th span {
    color: rgb(100, 116, 139) !important;
    font-family: var(--main-family) !important;
    font-size: 14px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.35px !important;
    line-height: 20px !important;
}

.datagrid thead .icon,
.datagrid thead i {
    float: right !important;
}

.main-content .table tbody td {
    border-bottom: 1px dashed rgb(229, 231, 235) !important;
    box-shadow: none !important;
}


.main-content .table tbody tr:nth-child(even) td {
    background-color: #f8fafc !important;
}

.main-content .table tbody tr:hover td {
    background-color: #f1f5f9cc !important;
}

.datagrid td.actions a:not(.dropdown-item) {
    font-size: 14px !important;
    font-weight: 500 !important;
    letter-spacing: 0.35px !important;
    line-height: 20px !important;
}







.content-top {
    block-size: unset !important;
    padding: 11px 0 !important;
}



/** Button **/
.custom-button {
    transition: all 0.2s !important;
    border: 1px solid #e2e8f0 !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0.5rem 0.75rem !important;
    border-radius: 0.375rem !important;
    font-weight: 400 !important;
    cursor: pointer !important;
    min-width: 40px !important;
    height: 38px !important;
    margin-right: 0.5rem !important;
    text-align: center !important;
    color: rgb(100, 116, 139) !important;
}

.custom-button-hover:hover {
    @apply bg-gray-50;
}

.page-item-previous {
    text-align: right !important;
}

.page-item.active .custom-button {
    @apply bg-blue-600 text-white border-blue-600;
}

.page-item.disabled .custom-button {
    @apply opacity-50 cursor-not-allowed;
}

.custom-button-hover {
    border: none !important;
    box-shadow: none !important;
}

.custom-button-hover:hover:not(:disabled) {
    border: 1px solid #e2e8f0 !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05) !important;
}


.custom-button:focus {
    outline: none !important;
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color) !important;
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color) !important;
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000) !important;
    --tw-ring-opacity: 0.2 !important;
}


.custom-button:hover:not(:disabled) {
    background-color: rgba(226, 232, 240, 0.2) !important;
    border-opacity: 0.9 !important;
}



.custom-button:disabled {
    opacity: 0.7 !important;
    cursor: not-allowed !important;
}

.dark .custom-button {
    border-color: rgba(255, 255, 255, 0.1) !important;
    color: rgb(203, 213, 225) !important;
}

.dark .custom-button:focus {
    --tw-ring-color: rgb(51, 65, 85) !important;
    --tw-ring-opacity: 0.5 !important;
}

.dark .custom-button:hover:not(:disabled) {
    background-color: rgba(255, 255, 255, 0.1) !important;
}

.list-pagination {
    @apply flex items-center justify-between mt-4;
}

.list-pagination-counter {
    @apply flex items-center;
}

.pagination {
    @apply flex items-center gap-2;
}







/** Form **/
input,
textarea,
select {
    transition: all 200ms ease-in-out !important;
    width: 100% !important;
    font-size: 0.875rem !important;
    border: 1px solid rgb(226, 232, 240) !important;
    box-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05) !important;
    border-radius: 0.375rem !important;
    padding: 0.5rem 0.75rem !important;
    block-size: unset !important;
}

input::placeholder {
    color: rgba(148, 163, 184, 0.9) !important;
}

input:disabled {
    background-color: rgb(241, 245, 249) !important;
    cursor: not-allowed !important;
    border-color: transparent !important;
}

input[readonly]:not(.not-read-only) {
    background-color: rgb(241, 245, 249) !important;
    cursor: not-allowed !important;
    border-color: transparent !important;
}

bg-white-important {
    background-color: white !important;
}

.form-widget .custom-file-input:focus~.custom-file-label,
.form-widget .form-select:focus,
.form-widget input.form-check-input:focus,
.form-widget input.form-control:focus,
.form-widget textarea.form-control:focus {
    box-shadow: 0px 0px 0px 4px rgba(30, 58, 138, 0.2) !important;
    border-color: rgba(30, 58, 138, 0.4) !important;
}

.form-group label,
.form-group legend.col-form-label {
    font-size: 14px !important;
    font-weight: 300 !important;
    letter-spacing: 0.35px !important;
    line-height: 20px !important;
    color: rgb(71, 85, 105) !important;
}

.form-inline input {
    flex: 1 !important;
}

.input-group input {
    border-radius: 0 !important;
    z-index: 10 !important;
}

.input-group input:first-child {
    border-top-left-radius: 0.375rem !important;
    border-bottom-left-radius: 0.375rem !important;
}

.input-group input:last-child {
    border-top-right-radius: 0.375rem !important;
    border-bottom-right-radius: 0.375rem !important;
}

.input-group input:not(:first-child) {
    border-left-color: transparent !important;
}

.form-fieldset {
    padding: 0 !important;
}

.form-fieldset-header {
    padding-bottom: 1.25rem !important;
    border-bottom: 1px solid rgb(226, 232, 240) !important;
    color: rgb(71, 85, 105) !important;
    letter-spacing: 0.35px !important;
    line-height: 20px !important;
}

.form-fieldset-header .form-fieldset-title .form-fieldset-title-content {
    font-weight: 500 !important;
}

.form-fieldset-body {
    padding-top: 1.25rem !important;
}

/* Style du checkbox dans le header */
.form-check-input,
.form-check-input {
    width: 16px !important;
    height: 16px !important;
    margin: 0 !important;
    cursor: pointer !important;
    border-radius: 3px !important;
    border: 1px solid rgb(226, 232, 240) !important;
    padding: 0 !important;
}

/* Style quand coché */
.form-check-input:checked,
.form-check-input:checked {
    background-color: rgb(30, 58, 138) !important;
    border-color: rgb(30, 58, 138) !important;
}



/** Responsive **/
.responsive-header {
    background-color: var(--main-color) !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 0 1.25rem 0 !important;
    transition: all 0.3s ease-in-out !important;
}

.responsive-header #responsive-header-logo {
    padding: 0 !important;
    margin: 0 !important;
}

.responsive-header #navigation-toggler {
    filter: opacity(100%) !important;
}

.responsive-header.fixed {
    position: fixed !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 1000 !important;
    padding: 1rem !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
    background-color: rgba(30, 64, 175, 0.9) !important;
}







/** Dropdown **/
.dropdown-menu .dropdown-header,
.dropdown-menu .dropdown-item {
    padding: 1.20rem 1rem !important;
    font-size: 14px !important;
    letter-spacing: 0.35px !important;
    line-height: 20px !important;
    font-weight: 400 !important;
}

.dropdown-menu {
    border-radius: 0.375rem !important;
}

.modal-backdrop.show {
    opacity: 0.85 !important;
}

.modal-content {
    border: none !important;
    border-radius: 8px !important;
    box-shadow: rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.1) 0px 1px 2px -1px !important;
}

.modal-body {
    border-radius: 8px !important;
    color: rgb(107, 114, 128) !important;
    font-weight: 400 !important;
}

.modal-footer {
    background-color: white !important;
}

/** Mobile Only **/
@media screen and (max-width:767px) {

    .form-check-input {
        height: 20px !important;
        width: 20px !important;
    }


}

/** Responsive Mobile & tablet **/
@media screen and (max-width:991.98px) {
    .menu-header:has(.hidden-md) {
        display: none !important;
    }

    #main-menu .menu .menu-item:not(.expanded):hover {
        background-color: unset !important;
    }


    #main-menu .menu .menu-item.active,
    #main-menu .menu .menu-item.active:hover a,
    #main-menu .menu .menu-item.active a,
    #main-menu .menu .menu-item.active:not(:hover) a,
    #main-menu .menu .menu-item.active a i {
        background-color: unset !important;
        color: white !important;
    }

    .sidebar {
        background-color: rgb(30, 58, 138) !important;
        padding-top: 0.8rem !important;
    }

    #main-menu .menu .menu-item-contents {
        padding: 0 2rem !important;
    }

    #main-menu .menu .menu-item {
        padding-left: 1.25rem !important;
    }

    #main-menu .menu .submenu a {
        padding: 0 0.5rem !important;
    }
}

@media (min-width: 640px) {
    .custom-button {
        width: auto !important;
    }
}