/*variable*/
:root{
    --primary-blue-light : #086572;
    --primary-blue-dark : #094754;
    --black-font: #1D1E1C;
    --delete : #E42E31;
    --delete-dark : #aa1618;
    --disable : #A3A3A3;
    --check : #5cae09;
    --check-dark: #3a6e05;
    --secondary : #cc664c;
    --secondary-dark : #a5543d;
    --warning : #d2b200;
    --warning-dark: #c4a600;
}

html {
    margin: 0;
    padding: 0;
}

body {
    position: relative;
    font-family:  lato;
    font-weight: 400;
}

#containerPublic {
    min-height:100vh;
}

/* Login card responsive */
.login-card {
    width: 100%;
    max-width: 400px;
}

.login-logo {
    max-height: 80px;
    object-fit: contain;
}

@media (max-width: 575.98px) {
    .login-card {
        max-width: none;
    }

    .login-logo {
        max-height: 60px;
    }
}

@media (min-width: 576px) and (max-width: 767.98px) {
    .login-card {
        max-width: 380px;
    }
}

@media (min-width: 768px) and (max-width: 991.98px) {
    .login-card {
        max-width: 400px;
    }
}

.toggle-password{
    background-color: transparent;
    border: none;
    position: absolute;
    right: 0.5rem;
    top: 50%;
    transform: translateY(-50%);
    height: auto;
    font-size: .875rem;
    padding: 0.25rem 0.5rem;
    cursor: pointer;
    z-index: 10;
    color: #6c757d;
    transition: right 0.15s ease;
}

.toggle-password:hover {
    color: var(--primary-blue-light);
}

/* Espace pour le bouton toggle dans les inputs password */
input[type="password"] ~ .toggle-password,
input[type="text"] ~ .toggle-password {
    right: 0.5rem;
}

input[type="password"],
input[type="text"].form-control {
    padding-right: 5.5rem;
}

/* Quand les icônes de validation Bootstrap sont présentes, décaler le toggle à gauche */
input.is-valid ~ .toggle-password,
input.is-invalid ~ .toggle-password {
    right: 2rem;
}

input.is-valid,
input.is-invalid {
    padding-right: 6.5rem;
    background-position: right 0.5rem center;
}

/* Position relative for password wrapper generated by UX bundle */
.form-control-wrapper {
    position: relative !important;
    display: block !important;
}

.container-scroller {
    overflow: hidden;
}

.page-body-wrapper {
    min-height: calc(100vh - 60px);
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: row;
    flex-direction: row;
    padding-left: 0;
    padding-right: 0;
    padding-top: 60px;

    &.full-page-wrapper {
        width: 100%;
        min-height: 100vh;
        padding-top: 0;
    }
}

.main-panel {
    transition: width 0.25s ease, margin 0.25s ease;
    width: calc(100% - 235px);
    min-height: calc(100vh - 60px);
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: column;
    flex-direction: column;
}

.content-wrapper {
    background: #EEF0FD;
    width: 100%;
    -webkit-flex-grow: 1;
    flex-grow: 1;
    display: flex;
}

.footer {
    background: #fff;
    padding: 10px 2.45rem;
    transition: all 0.25s ease;
    -moz-transition: all 0.25s ease;
    -webkit-transition: all 0.25s ease;
    -ms-transition: all 0.25s ease;
    font-size: calc(0.875rem - 0.05rem);
    font-family: "Nunito", sans-serif;
    font-weight: 400;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
}

/* Boutons Primary */
.btn-primary {
    background: var(--primary-blue-light) !important;
    color: #FFFFFF !important;
    border: 1px solid var(--primary-blue-light) !important;
    border-radius: 0.375rem;
}
.btn-primary:hover {
    background: var(--primary-blue-dark) !important;
    color: #FFFFFF !important;
    border: 1px solid var(--primary-blue-dark) !important;
}

.btn-outline-primary {
    background: transparent !important;
    color: var(--primary-blue-light) !important;
    border: 1px solid var(--primary-blue-light) !important;
    border-radius: 0.375rem;
}
.btn-outline-primary:hover {
    background: var(--primary-blue-light) !important;
    color: #FFFFFF !important;
    border: 1px solid var(--primary-blue-light) !important;
}


.text-primary{
    color: var(--primary-blue-light) !important;
}

/* Boutons Success */
.btn-success{
    background: var(--check) !important;
    color: #FFFFFF !important;
    border: 1px solid var(--check) !important;
    border-radius: 0.375rem !important;
}
.btn-success:hover{
    background: var(--check-dark) !important;
    color: #FFFFFF !important;
    border: 1px solid var(--check-dark) !important;
}

.btn-outline-success{
    background: transparent !important;
    color: var(--check) !important;
    border: 1px solid var(--check) !important;
    border-radius: 0.375rem !important;
}
.btn-outline-success:hover{
    background: var(--check) !important;
    color: #FFFFFF !important;
    border: 1px solid var(--check) !important;
}

/* Boutons Warning */
.btn-warning{
    background: var(--warning) !important;
    color: #FFFFFF !important;
    border: 1px solid var(--warning) !important;
    border-radius: 0.375rem;
}
.btn-warning:hover{
    background: var(--warning-dark) !important;
    color: #FFFFFF !important;
    border: 1px solid var(--warning-dark) !important;
}

.btn-outline-warning{
    background: transparent !important;
    color: var(--warning) !important;
    border: 1px solid var(--warning) !important;
    border-radius: 0.375rem !important;
}
.btn-outline-warning:hover{
    background: var(--warning) !important;
    color: #FFFFFF !important;
    border: 1px solid var(--warning) !important;
}

/* Boutons Danger */
.btn-danger{
    background: var(--delete) !important;
    color: #FFFFFF !important;
    border: 1px solid var(--delete) !important;
    border-radius: 0.375rem !important;
}
.btn-danger:hover{
    background: var(--delete-dark) !important;
    color: #FFFFFF !important;
    border: 1px solid var(--delete-dark) !important;
}

.btn-outline-danger{
    background: transparent !important;
    color: var(--delete) !important;
    border: 1px solid var(--delete) !important;
    border-radius: 0.375rem !important;
}
.btn-outline-danger:hover{
    background: var(--delete) !important;
    color: #FFFFFF !important;
    border: 1px solid var(--delete) !important;
}

/* Boutons Info */
.btn-info{
    background: #0dcaf0 !important;
    color: #000 !important;
    border: 1px solid #0dcaf0 !important;
    border-radius: 0.375rem !important;
}
.btn-info:hover{
    background: #31d2f2 !important;
    color: #000 !important;
    border: 1px solid #31d2f2 !important;
}

.btn-outline-info{
    background: transparent !important;
    color: #0dcaf0 !important;
    border: 1px solid #0dcaf0 !important;
    border-radius: 0.375rem !important;
}
.btn-outline-info:hover{
    background: #0dcaf0 !important;
    color: #000 !important;
    border: 1px solid #0dcaf0 !important;
}

/* Boutons Secondary */
.btn-secondary{
    background: #6c757d !important;
    color: #FFFFFF !important;
    border: 1px solid #6c757d !important;
    border-radius: 0.375rem !important;
}
.btn-secondary:hover{
    background: #5c636a !important;
    color: #FFFFFF !important;
    border: 1px solid #5c636a !important;
}

.btn-outline-secondary{
    background: transparent !important;
    color: #6c757d !important;
    border: 1px solid #6c757d !important;
    border-radius: 0.375rem !important;
}
.btn-outline-secondary:hover{
    background: #6c757d !important;
    color: #FFFFFF !important;
    border: 1px solid #6c757d !important;
}

/* Classes de couleur */
.color-primary{
    color: var(--primary-blue-light) !important;
}
.color-primary-dark{
    color: var(--primary-blue-dark);
}

.color-delete{
    color: var(--delete) !important;
}
.color-delete-dark{
    color: var(--delete-dark);
}

.color-secondary{
    color: var(--secondary);
}

.bg-primary{
    background-color: var(--primary-blue-light) !important;
}

.bg-warning{
    background-color: var(--secondary) !important;
}

/* Address Autocomplete */
.address-autocomplete-results {
    position: absolute;
    z-index: 1000;
    background: white;
    border: 1px solid #ced4da;
    border-top: none;
    border-radius: 0 0 0.25rem 0.25rem;
    max-height: 200px;
    overflow-y: auto;
    width: 100%;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.address-autocomplete-item {
    padding: 0.5rem 0.75rem;
    cursor: pointer;
    transition: background-color 0.15s ease;
}

.address-autocomplete-item:hover {
    background-color: #f8f9fa;
}

.address-autocomplete-item:active {
    background-color: #9ec8de;
}

/* International Phone Input - Force full width and proper display */
.iti {
    display: block !important;
    width: 100% !important;
}

.iti__input {
    width: 100% !important;
}

/* Ensure the phone input container takes full width */
[data-controller="phone"] {
    display: block !important;
    width: 100% !important;
}

[data-controller="phone"] .iti {
    display: block !important;
    width: 100% !important;
}

/* Password Strength Requirements */
.password-requirements {
    padding: 0.5rem 0.75rem;
    background-color: #f8f9fa;
    border-radius: 0.25rem;
    border: 1px solid #dee2e6;
}

.requirements-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.25rem 0.5rem;
}

.requirement-item {
    font-size: 0.8rem;
    display: flex;
    align-items: center;
    transition: color 0.2s ease;
}

.requirement-item .icon {
    margin-right: 0.35rem;
    font-size: 0.9rem;
    display: inline-block;
    width: 1rem;
    text-align: center;
    flex-shrink: 0;
}

.requirement-invalid {
    color: #6c757d;
}

.requirement-invalid .icon {
    color: #dc3545;
}

.requirement-valid {
    color: #198754;
    font-weight: 500;
}

.requirement-valid .icon {
    color: #198754;
}