/* Champs du formulaire */

/* Placeholder */
.input::placeholder {
    color: var(--gray-600);
    font-style: italic;
}

/* Liens */
.label a {
    color: inherit;
    text-decoration: underline;
}

.options-list {
    padding: 0;
    margin: 0;
    list-style: none;
}

.text-ellipsis {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/*****************/
/* Mise en forme du label + input + icônes */
.form-input {
    position: relative;

    flex-grow: 1;
    flex-basis: 15rem;
}

.form-input .label .icon {
    color: var(--black);
    line-height: 1;
    -ms-flex-item-align: center;
}

.form-input .label:not(.visually-hidden) {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    color: var(--black);
    font-weight: 700;
    font-size: var(--font-size-small-mobile);
    line-height: 1.6rem;
    padding: 0.4rem 0 0.4rem 0;
}

.form-input .label .label-end {
    margin-left: auto;
    display: flex;
    align-items: center;
}

.form-input .label .label-end > img {
    margin-right: 4px;
}

.form-input .label .label-end > * {
    margin-left: 4px;
}

.form-input .label .label-end > img.success-icon {
    display: none;
}

.form-input.success .label .label-end > img.success-icon {
    margin-right: 0px;
    display: block;
}

.form-input > .form-input-row {
    color: var(--black);
    padding: 0.7rem;
    border-radius: 0.4rem;
    border: 1px solid rgba(0, 0, 0, 0.32);
    /*-webkit-box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.24) inset, 0 2px 4px 0 rgba(0, 0, 0, 0.08) inset;*/
    /*box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.24) inset, 0 2px 4px 0 rgba(0, 0, 0, 0.08) inset;*/
}

/* Ajout de la classe "filled" lorsqu'un champ est rempli */
.form-input.filled > .form-input-row {
    background-color: var(--gray-025);
    border: 1px solid var(--black);
    /*-webkit-box-shadow: 0 0 0 1px var(--black) inset, 0 1px 2px 0 rgba(0, 0, 0, 0.2) inset;*/
    /*box-shadow: 0 0 0 1px var(--black) inset, 0 1px 2px 0 rgba(0, 0, 0, 0.2) inset;*/
}

/* Ajout de la classe "focus" lorsque l'on est positionné sur un champ */
.form-input.focus:not(.readonly):not(.error) > .form-input-row {
    -webkit-box-shadow: 0px 0px 4px var(--cyan), 0px 0px 16px rgba(6, 147, 146, 0.24), inset 0px 0px 8px rgba(6, 147, 146, 0.56);
    box-shadow: 0px 0px 4px var(--cyan), 0px 0px 16px rgba(6, 147, 146, 0.24), inset 0px 0px 8px rgba(6, 147, 146, 0.56);
}

/* Ajout de la classe "disabled" sur un champ dont le contenu ne peut être modifié */
.form-input.disabled > .form-input-row {
    color: var(--gray-600);
    background-color: rgba(255, 255, 255, 0.24);
    -webkit-box-shadow: 0 0 0 1px rgba(102, 112, 112, 0.24) inset;
    box-shadow: 0 0 0 1px rgba(102, 112, 112, 0.24) inset;
}

/* Fix autofill changing color on chromium based browsers */
input:-webkit-autofill,
input:-webkit-autofill:focus {
    transition: background-color 600000s 0s, color 600000s 0s;
}

input[data-autocompleted] {
    background-color: transparent !important;
}

/*
|--------------------------------------------------------------------------
| Styles spécifiques "stacked"
|--------------------------------------------------------------------------
*/

.form-input.stacked > .label {
    position: absolute;
    top: 1rem;
    left: var(--spacer-pop-tiny);
    z-index: 2;
}

.form-input.stacked.icon-left .label .icon {
    margin-right: .4rem;
    margin-left: -.1rem;
}

.form-input.stacked.filled .label {
    color: var(--gray-600);
    font-weight: 400;
}

/*
|--------------------------------------------------------------------------
| FIN - Styles spécifiques "stacked"
|--------------------------------------------------------------------------
*/

/*
|--------------------------------------------------------------------------
| Styles spécifiques "simple"
|--------------------------------------------------------------------------
*/

.form-input.simple .label {
    color: var(--gray-600);
}

.form-input.simple.icon-left > .form-input-row .input,
.form-input.simple.icon-left > .form-input-row .textarea,
.form-input.simple.icon-left > .form-input-row .select-text {
    padding-left: var(--spacer-pop-large);
}

.form-input.simple.icon-left > .form-input-row .input-wrapper > .icon {
    left: 0;
}

.form-input.simple.icon-right > .form-input-row .input,
.form-input.simple.icon-right > .form-input-row .textarea,
.form-input.simple.icon-right > .form-input-row .select-text {
    padding-right: var(--spacer-pop-large);
}

.form-input.simple.icon-right > .form-input-row .input-wrapper > .icon {
    right: 0;
}

/*
|--------------------------------------------------------------------------
| FIN - Styles spécifiques "simple"
|--------------------------------------------------------------------------
*/

.form-input-container {
    border-radius: 4px;
    z-index: 2;
    width: 100%;
}

/* form-input-row : Container du champ input */
.form-input-row {
    background-color: var(--white);
    position: relative;
    display: inline-block;
    width: 100%;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    min-height: 4rem;
    margin: 0;
    -webkit-transition: background-color .2s;
    transition: background-color .2s;
    font-size: var(--font-size-base-mobile);
    border-radius: 4px;
}

.form-input-row .input-button {
    border: none;
    background: none;
    cursor: pointer;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 0;
}

.form-input-row .input-wrapper {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
}

.form-input-row > .icon,
.form-input-row .input-wrapper > .icon {
    position: absolute;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: var(--spacer-pop-tiny);
    z-index: 2;
    pointer-events: none;
}

.form-input-row .input,
.form-input-row .select-text,
.form-input-row .textarea {
    color: inherit;
    font-family: inherit;
    font-size: inherit;
    width: 100%;
    border: 0;
    margin: 0;
    background: transparent;
    -webkit-box-shadow: none;
    box-shadow: none;
    height: 2.4rem;
}

input::placeholder {
    color: var(--gray-600);
    font-style: italic;
    font-size: 16px;
    font-weight: 400;
}

.submit .button-content {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;

    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;

    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;

    font-size: var(--font-size-small-mobile);
}

.form-input [id^="hide-password"] {
    display: none;
}

/*****************/
/* Composant recherche établissement */
.select-custom {
    position: relative;
    background-color: white;
    border-radius: 0.4rem;

}
.select-form-input {
    padding: var(--spacer-pop-tiny);
}

.form-input.filled .select-custom {
    background-color: var(--gray-025);
    border: 1px solid var(--black);
    /*-webkit-box-shadow: 0 0 0 1px var(--black) inset, 0 1px 2px 0 rgba(0, 0, 0, 0.2) inset;*/
    /*box-shadow: 0 0 0 1px var(--black) inset, 0 1px 2px 0 rgba(0, 0, 0, 0.2) inset;*/
}

.form-input.filled .form-input-row {
  background-color: var(--gray-025);
}

.form-input.focus .select-arrow  {
  transform: rotate(180deg);
}

/* Ajout de la classe "focus" lorsque l'on est positionné sur un champ */
.form-input.focus:not(.readonly):not(.error) .select-custom {
    -webkit-box-shadow: 0px 0px 4px var(--cyan), 0px 0px 16px rgba(6, 147, 146, 0.24), inset 0px 0px 8px rgba(6, 147, 146, 0.56);
    box-shadow: 0px 0px 4px var(--cyan), 0px 0px 16px rgba(6, 147, 146, 0.24), inset 0px 0px 8px rgba(6, 147, 146, 0.56);
}

/* Ajout de la classe "disabled" sur un champ dont le contenu ne peut être modifié */
.form-input.disabled > .select-custom {
    color: var(--gray-600);
    background-color: rgba(255, 255, 255, 0.24);
    -webkit-box-shadow: 0 0 0 1px rgba(102, 112, 112, 0.24) inset;
    box-shadow: 0 0 0 1px rgba(102, 112, 112, 0.24) inset;
}

.select-custom .select-button {
    border: none;
    width: 100%;
    text-align: left;
    cursor: pointer;
    padding: 0 var(--spacer-pop-tiny);
}

.select-dropdown {
    position: absolute;
    width: 100%;
    max-height: 32rem;
    top: calc(100% + 1px);
    padding: var(--spacer-pop-tiny);
    background: var(--white);
    border-radius: 4px;
    z-index: 300;
    -webkit-box-shadow: 0 2px 4px 0 rgb(0 0 0 / 20%);
    box-shadow: 0 2px 4px 0 rgb(0 0 0 / 20%);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
}

.select-dropdown.dropdown-over {
    width: 100%;
    top: calc(var(--spacer-pop-tiny) * -1);
}

.select-dropdown.dropdown-over {
    top: 8.5rem;
}

.select-custom .select-placeholder {
    font-style: italic;
    color: var(--gray-600);
    opacity: .5;
}

/* Liste des résultats */
.select-dropdown .options-list {
    color: var(--black);
    overflow-y: auto;
}

.select-dropdown .form-input + * {
    margin-top: var(--spacer-pop-tiny);
}

.select-dropdown .form-input {
    flex-basis: auto;
}

.select-dropdown .options-list-item > button {
    padding: var(--spacer-pop-small) var(--spacer-pop-tiny);
    width: 100%;
    font-size: 1.4rem;
    border-radius: .4rem;
    position: relative;
    text-align: inherit;
    .select-checkbox .checkbox{
        display: none;
    }
}

.select-dropdown .options-list-item:not(:last-child) > button::after {
    content: "";
    display: block;
    position: absolute;
    height: 1px;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, .04);
}

.select-dropdown .options-list-item > button:not(:disabled):hover,
.select-dropdown .options-list-item > button:not(:disabled):focus {
    background-color: rgba(0, 0, 0, .08);
    -webkit-transition: background-color .24s;
    transition: background-color .24s;
    .select-checkbox .checkbox{
       display:block;
    }
}

.select-dropdown .options-list-item > button:not(:disabled):hover::after,
.select-dropdown .options-list-item > button:not(:disabled):focus::after {
    opacity: 0;
}

.select-school {
    justify-content: space-between;
}

.select-school:hover .select-checkbox {
    display: flex;
}

/*
|--------------------------------------------------------------------------
| Validations formulaire
|--------------------------------------------------------------------------
*/

/* Ajout de la classe "error" lorsqu'une erreur de saisie est détectée */

.form-input.error > .form-input-row {
    border: 1px solid var(--red);
    border-radius: 0.4rem;
}

.form-input.error .label {
    color: var(--red) !important;
}

.form-input.error .input-validation {
    color: var(--red);
    fill: var(--red);
}

/* Ajout de la classe "success" lorsqu'aucune erreur de saisie n'est détectée (avant validation du form) */
.form-input.success > .form-input-row {
    border: 1px solid var(--green);
}

.form-input.success .input-validation {
    color: var(--green);
    fill: var(--green);
}

/* Ajout de la classe "warning" lorsqu'une erreur de saisie est détectée (avant validation du form) */
.form-input.warning > .form-input-row {
    border: 1px solid var(--orange);
}

.form-input.warning .input-validation {
    color: var(--orange);
    fill: var(--orange);
}

/*
|--------------------------------------------------------------------------
| FIN - Validations formulaire
|--------------------------------------------------------------------------
*/

/*****************/
/* CGU */
.form-input-checkable.input-medium {
    font-size: 1.2rem;
}

.form-input-checkable {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: flex-start;
    font-size: var(--font-size-base-mobile);
    color: var(--gray-600);
}

.form-input-checkable:hover {
    color: var(--black);
}
/*****************/
/* Checkbox */
.form-input-checkable.grey .checkbox {
    appearance: none;
    background-color: transparent;
    -webkit-box-shadow: inset 0 0 0 2px var(--gray-600);
    box-shadow: inset 0 0 0 2px var(--gray-600);
    border-radius: 2px;
}

.form-input-checkable.grey .radio {
    border-radius: 100%;
    appearance: none;
    background-color: transparent;
    margin: 0 .3rem;
    -webkit-box-shadow: inset 0 0 0 2px var(--gray-600);
    box-shadow: inset 0 0 0 2px var(--gray-600);
}

.form-input-checkable.grey:hover .checkbox, .form-input-checkable.grey:hover .radio {
    -webkit-box-shadow: inset 0 0 0 2px var(--black);
    box-shadow: inset 0 0 0 2px var(--black);
}

.form-input-checkable.input-medium > .checkbox, .form-input-checkable .radio {
    width: 1.8rem;
    height: 1.8rem;
}

.form-input-checkable .checkbox {
    margin: 0;
}

.form-input-checkable:not(.input-right) .label {
    margin-left: var(--spacer-pop-tiny);
}

/* Checkbox état checked */
.form-input-checkable.grey .checkbox:checked {
    background-image: url(../img/checked.svg);
    background-color: var(--cyan);
    background-position: 50%;
    background-repeat: no-repeat;
    -webkit-box-shadow: inset 0 0 0 2px var(--black);
    box-shadow: inset 0 0 0 2px var(--black);
}

.form-input-checkable.grey .radio:checked {
    background-size: 80% 80%;
    background-position: center;
    background-repeat: no-repeat;
    background-color: var(--black);
    box-shadow:
      inset 0 0 0 2px var(--black),
      inset 0 0 0 4px var(--cyan);
}


.form-input-checkable.grey .checkbox:checked + label, .form-input-checkable > .radio:checked {
  color: var(--black);
}

.form-input-checkable.input-medium .checkbox:checked {
    background-size: 1.4rem;
}

/* Checkbox état focus */
.checkbox:focus {
    outline: .1rem dotted var(--gray-600);
}

@media (min-width: 576px) {

    .form-input-row {
        font-size: var(--font-size-base);
    }

    .form-input-checkable.input-medium {
        font-size: var(--font-size-base-mobile);
    }

    .helper-content > .button--tiny:nth-child(even) {
        float: right;
    }
}

/* Le badge recaptcha n'est pas affiché */
.grecaptcha-badge {
    visibility: hidden;
}

.return-btn {
    position: absolute;
    width: 4rem;
    height: 4rem;
    top: 2.4rem;
    right: 2.4rem;
    z-index: 10;
    display: flex;
    background-color: rgba(0, 0, 0, 0.08);
    border-radius: 2rem;
    color: black;
}

.return-btn:hover {
    background-color: var(--black);
    color: var(--yellow);
}

.return-btn > .icon {
    width: 1rem;
    height: 1rem;
    margin: auto;
}

.success-form {
    border-bottom: solid 4px var(--green);
    padding: 1.6rem 1.6rem 1.2rem 1.6rem;
    background-color: var(--white);
    color: var(--green);
    display: flex;
}

.success-form .icon {
    margin-right: 26px;
}

.success-form .title {
    font-weight: 800;
    font-size: 24px;
    line-height: 32px;
}

.success-form .text {
    font-weight: 400;
    font-size: 16px;
    line-height: 24px;
    color: var(--black);
}

.helper-content {
    padding-bottom: 0.8rem;
    padding-top: 0.4rem;
    display: inline-block;
    width: 100%;
}

.helper-content:last-child {
    padding-bottom: 0;
}

.helper-content > .button--tiny {
    padding: 0;
}

@media (max-width: 576px) {
    .helper-content > .button--tiny:last-child {
        margin-top: 0.5rem;
    }
}

.submit {
    margin: auto;
    width: fit-content;
}

.provider-separator {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.provider-separator-text {
    width: auto;
    font-size: 16px;
    font-weight: 700;
    line-height: 24px;
}
.line {
    height: 1px;
    width: 40%;
    border: 1px solid var(--transparent-black);
}

.social-providers-box {
    border-radius: var(--radius-rad-xl);
    z-index: 2;
    width: 100%;
}
.ul-social-providers {
    background-color: var(--white);
    list-style-type: none;
    display: flex;
    padding: 0;
    margin: 0;
    border-radius: var(--radius-rad-xl);
    background: var(--efx-overlay-inverted-56);
}
.social-provider-li {
    min-width: 132px;
    width: 100%;
    height: 4rem;
}

.ul-social-providers:hover {
    background-color: #dbe1e1;
    border-radius: 24px;
}

.ul-social-providers:hover .social-provider-li:hover {
    background-color: var(--white);
    color: var(--black);
    border-radius: 24px;
}
/* Mobile et tablette */
@media (max-width: 991px) {
    .ul-social-providers {
        flex-direction: column;
        gap: 1.6rem;
        background: transparent;
    }

    .social-provider-li {
        background-color: var(--white);
        border-radius: var(--radius-rad-xl);
        min-width: 132px;
        width: 100%;
        height: 4rem;
    }
    .ul-social-providers:hover {
        background-color: transparent;
    }
    .ul-social-providers:hover .social-provider-li {
        background-color: transparent;
    }

    .ul-social-providers .social-provider-li:hover {
        background-color: var(--white);
        color: var(--black);
    }

  .helper-content {
        display: flex;
        justify-content: space-between
    }
}

.social-provider-link {
    display: flex;
    justify-content: center;

    font-style: normal;
    font-weight: 700;
    font-size: 14px;

    color: black;
    text-decoration: inherit;
    align-items: center;
    height: 4rem;
    &.gar-link {
        &.gar-logo {
            background-color: #2f3366;
        }

        &:focus {
            box-shadow: 0 0 0 1px white inset;
        }
    }
}

.social-provider-logo {
    /*background-size: 100% 100%;*/
    background-size: contain;
    background-repeat: no-repeat;
    width: 24px;
    height: 24px;
    display: inline-block;
    margin-right: 10px;
}

.gar-logo-default {
    background-image: url("../img/gar-logo.svg");
}

.gar-logo-tne {
    background-image: url("../img/gar-tne-logo.png");
}

.vidis-logo {
    background-image: url("../img/vidis-logo.svg");
}

.warning-verify-mail{
    display: inline-flex;
    align-items: flex-start;
    justify-content: center;
    font-size: var(--font-size-base-mobile);

    flex-wrap: nowrap;
    margin-top: 0.8rem;

    .icon-svg {
        height: 1.6rem;
        width: 1.6rem;
        filter: brightness(0%);
        margin-top: 0.2rem;
    }
}

.profile-choice {
    display: flex;
    justify-content: space-between;
    width: 100%;
    padding: var(--spacer-pop-tiny) 0;
}

.btn-group {
  background-color: var(--efx-overlay-04);
  display: flex;
  height: 3.2rem;
  border-radius: var(--spacer-pop-small);
}

.button-profile {
  height: 3.2rem;
  width: 16.9rem;
  border-radius: var(--spacer-pop-small);
  background-color: transparent;
  color:black;
  padding: var(--spacer-pop-tiny) var(--spacer-pop-small);
  text-transform: uppercase;
}

.button-profile.active {
  background-color: var(--cyan) !important;
  color:black !important;
  text-transform: uppercase;
}

.enseignement-scolaire {
  display: flex;
  height: 4rem;
  padding: var(--spacer-pop-tiny) 0;
  gap: var(--font-size-small-mobile);
}

.form-input.select .form-input-row{
  border: none;
}
.form-input.select.focus:not(.readonly):not(.error) > .form-input-row {
    -webkit-box-shadow: none;
    box-shadow: none;
}

.form-input-nom-prenom {
    display: flex;
    flex-wrap: wrap;
    column-gap: 0.8rem;
    display: -webkit-box;
      -webkit-box-align: center;
      -ms-flex-align: center;
      align-items: center;
}

@media (max-width: 1024px) {

    .form-input-nom-prenom {
       display: flex;
    flex-wrap: wrap;
    column-gap: 0.8rem;
      -webkit-box-align: center;
      -ms-flex-align: center;
      align-items: center;    }
}