/* Minification failed. Returning unminified contents.
(96,46): run-time error CSS1034: Expected closing parenthesis, found '>'
(157,46): run-time error CSS1034: Expected closing parenthesis, found '>'
(248,13): run-time error CSS1030: Expected identifier, found '>'
(248,22): run-time error CSS1031: Expected selector, found ')'
(248,22): run-time error CSS1025: Expected comma or open brace, found ')'
(255,7): run-time error CSS1030: Expected identifier, found '>'
(255,16): run-time error CSS1031: Expected selector, found ')'
(255,16): run-time error CSS1025: Expected comma or open brace, found ')'
(289,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(290,31): run-time error CSS1046: Expect comma, found '255'
(290,39): run-time error CSS1046: Expect comma, found '/'
(290,41): run-time error CSS1047: Expected number or percentage value in rgb function, found 'var('
(290,45): run-time error CSS1034: Expected closing parenthesis, found '-'
(290,45): run-time error CSS1042: Expected function, found '-'
(290,46): run-time error CSS1039: Token not allowed after unary operator: '-tw-bg-opacity'
(290,60): run-time error CSS1062: Expected semicolon or closing curly-brace, found ')'
(294,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(295,18): run-time error CSS1046: Expect comma, found '0'
(295,22): run-time error CSS1046: Expect comma, found '/'
(295,24): run-time error CSS1047: Expected number or percentage value in rgb function, found 'var('
(295,28): run-time error CSS1034: Expected closing parenthesis, found '-'
(295,28): run-time error CSS1042: Expected function, found '-'
(295,29): run-time error CSS1039: Token not allowed after unary operator: '-tw-text-opacity'
(295,45): run-time error CSS1062: Expected semicolon or closing curly-brace, found ')'
(318,32): run-time error CSS1030: Expected identifier, found '['
(318,37): run-time error CSS1031: Expected selector, found '='
(318,37): run-time error CSS1025: Expected comma or open brace, found '='
(334,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(445,41): run-time error CSS1030: Expected identifier, found '['
(445,47): run-time error CSS1031: Expected selector, found '*='
(445,47): run-time error CSS1025: Expected comma or open brace, found '*='
(457,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
 */
@font-face {
    font-family: Gotham HTF;
    font-weight: 300;
    font-style: normal;
    font-display: swap;
    src: url(../fonts/GothamHTF-Light.woff2) format("woff2"), url(../fonts/GothamHTF-Light.woff) format("woff")
}

@font-face {
    font-family: Gotham HTF;
    font-weight: 300;
    font-style: italic;
    font-display: swap;
    src: url(../fonts/GothamHTF-LightItalic.woff2) format("woff2"), url(../fonts/GothamHTF-LightItalic.woff) format("woff")
}

@font-face {
    font-family: Gotham HTF;
    font-weight: 400;
    font-style: normal;
    font-display: swap;
    src: url(../fonts/GothamHTF-Book.woff2) format("woff2"), url(../fonts/GothamHTF-Book.woff) format("woff")
}

@font-face {
    font-family: Gotham HTF;
    font-weight: 400;
    font-style: italic;
    font-display: swap;
    src: url(../fonts/GothamHTF-BookItalic.woff2) format("woff2"), url(../fonts/GothamHTF-BookItalic.woff) format("woff")
}

@font-face {
    font-family: Gotham HTF;
    font-weight: 600;
    font-style: normal;
    font-display: swap;
    src: url(../fonts/GothamHTF-Bold.woff2) format("woff2"), url(../fonts/GothamHTF-Bold.woff) format("woff")
}

@font-face {
    font-family: Gotham HTF;
    font-weight: 600;
    font-style: italic;
    font-display: swap;
    src: url(../fonts/GothamHTF-BoldItalic.woff2) format("woff2"), url(../fonts/GothamHTF-BoldItalic.woff) format("woff")
}

html, body {
    font-family: Gotham HTF, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", Segoe UI Symbol, "Noto Color Emoji";
    line-height: 1.5;
    font-weight: 300;
    font-size: 16px;
    font-feature-settings: normal;
    font-variation-settings: normal;
}

button, input, optgroup, select, textarea {
    font-family: inherit;
    -webkit-font-feature-settings: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    font-size: 100%;
    font-weight: inherit;
    line-height: inherit;
    letter-spacing: inherit;
    color: inherit;
    margin: 0;
    padding: 0;
}

html, body {
    height: 100%;
}

body {
    margin: 0;
    display: flex;
    flex-direction: column;
    background-color: #7d0d0d;
}

main {
    flex: 1 1 auto;
    background: linear-gradient(180deg, #9f1212 0%, #7d0d0d 100%);
}

main * {
    color: #ffffff;
}

main a:hover, main a:active {
    color: inherit;
}

@media (min-width: 1024px) and (aspect-ratio > 3 / 4) {
    body {
        background-image: url("./images/connexion-espace-client.png");
        background-repeat: no-repeat;
        background-position: top left;
        background-size: cover;
    }

    main {
        width: 50%;
        position: relative;
        left: 50%;
    }
}

@media not all and (min-width: 1280px) {
    #lien-site-public-texte, #lien-contact-texte, #lien-site-epargne-texte {
        display: none;
    }
}

header, .conteneur-authentification-pied, .conteneur-authentification-tete, .conteneur-main-pied {
    flex: 0 1 auto;
    background-color: #ffffff;
}

.conteneur-authentification-pied *, .conteneur-authentification-tete *, .conteneur-main-pied * {
    color: #000000;
}

::selection {
    color: #fff;
    background-color: #ce1717;
}

* {
    outline-color: #ce1717;
}

*, :before, :after {
    box-sizing: border-box;
    border-width: 0;
    border-style: solid;
    border-color: #e5e7eb;
}

.conteneur-entete, .conteneur-main {
    width: 100%;
    margin-right: auto;
    margin-left: auto;
    padding-right: 1.5rem;
    padding-left: 1.5rem;
}

@media (min-width: 768px) {
    .container-main {
        padding-top: 3rem;
        padding-bottom: 3rem;
    }
}

@media (min-width: 1024px) and (aspect-ratio > 3 / 4) {
    .conteneur-main {
        padding-top: 2.5rem;
    }
}

.conteneur-main {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.conteneur-entete {
    padding-top: .5rem;
    padding-bottom: .5rem;
}

@media (min-width: 1024px) {
    .conteneur-entete {
        padding-top: 1rem;
        padding-bottom: 1rem;
    }
}

@media (min-width: 1280px) {
    .conteneur-entete {
        padding-top: 1.5rem;
        padding-bottom: 1.5rem;
    }
}

.entete-contenu, .conteneur-authentification-pied-contenu, .conteneur-main-pied-contenu {
    display: flex;
    column-gap: 2rem;
    justify-content: space-between;
    align-items: center;
}

@media (max-width: 768px) {
    .entete-contenu {
        column-gap: inherit;
    }
}

.entete-section {
    flex-shrink: 0;
}

.lien-logo {
    padding: .5rem;
    margin-top: -.5rem;
    margin-bottom: -.5rem;
}

.logo-cfcal {
    display: block;
    width: auto;
    height: 2.25rem;
}
@media (min-width: 1024px) {
    .logo-cfcal {
        height: 3rem;
    }
}

mark {
    font-weight: 700;
    background-color: inherit;
}

label {
    font-weight: 600;
}

.input-libelle-masque {
    height: 0;
    display: block;
    padding-right: 1rem;
    padding-left: 1rem;
    font-weight: inherit;
    visibility: hidden;
}

a, .bouton {
    font-weight: 700;
}

a, a:hover, a:active {
    text-decoration: underline;
}

.bouton:has(>img.icon), a:has(>img.icon) {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    column-gap: .75rem;
}

a:has(>img.icon):not(:has(>span)):not(.info-bulle) {
    margin-right: .75rem;
}

header a, .conteneur-authentification-pied a, .conteneur-authentification-pied a > span, .conteneur-main-pied a, .conteneur-main-pied a > span, .bouton {
    transition: color .3s cubic-bezier(.25,.46,.45,.94);
}

header a, .conteneur-authentification-pied a, .conteneur-authentification-pied a > span, .conteneur-main-pied a, .conteneur-main-pied a > span, .bouton, header a:hover, .conteneur-authentification-pied a:hover, header a:active, .conteneur-authentification-pied a:active, .conteneur-main-pied a:hover, header a:active, .conteneur-main-pied a:active {
    color: #ce1717;
}

header a:not(.bouton), .bouton {
    display: inline-block;
}

.bouton {
    transition: background-color .3s cubic-bezier(.25,.46,.45,.94),color .3s cubic-bezier(.25,.46,.45,.94);
    background-color: #ce1717;
    cursor: pointer;
    padding: 1rem 1.5rem;
}
.bouton, .bouton:hover {
    color: #fff;
    text-decoration: none;
}

.bouton, input {
    border-radius: .375rem;
}

input {
    min-height: 3rem;
    border-width: 1px;
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
    font-size: 1rem;
    line-height: 1.5rem;
    font-weight: 400;
    --tw-text-opacity: 1;
    color: rgb(0 0 0 / var(--tw-text-opacity));
    padding: .5rem 1rem;
    border-color: #ccc;
}

input[type=text], input[type=password], input[type=email] {
    width: 100%;
}

input[type=text], input[type=password], input[type=email], input[type=checkbox], input[type=radio] {
    font-size: 15px;
    margin-bottom: 0;
    margin-top: 0;
}

input[type=checkbox], input[type=radio], label + input[type=checkbox], label + input[type=radio] {
    vertical-align: middle;
}

input[type=checkbox], input[type=radio] {
    accent-color: rgb(206, 23, 23);
}

input[type="radio"]:has(+ input[type="radio"]) {
    margin-right: 12px;
}
label:not(.input-libelle-masque):has(+input) {
    margin-right: 6px;
}

input[type=submit].bouton {
    border: none;
}

.ui-tooltip {
    font-family: Gotham HTF, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", Segoe UI Symbol, "Noto Color Emoji" !important;
}

.titre-page {
    --tw-text-opacity: 1;
    font-weight: 700;
    font-size: 27px;
    line-height: 1.75rem;
    margin-bottom: 1.25rem;
}

.conteneur-authentification, .conteneur-authentification-pied, .conteneur-authentification-tete, .conteneur-main-pied {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.conteneur-authentification {
    width: 100%;
}

.conteneur-authentification-formulaire {
    padding-left: 5rem;
    padding-right: 5rem;
}


@media (max-width: 1024px) {
    .conteneur-authentification-formulaire {
        padding-right: 3.5rem;
        padding-left: 3.5rem;
    }
}

@media (max-width : 760px) {
    .conteneur-authentification-formulaire {
        padding-right: 1.5rem;
        padding-left: 1.5rem;
    }
}

.conteneur-authentification-conteneur-ajax, .conteneur-authentification > form, .conteneur-authentification-formulaire {
    width: 100%;
}

.conteneur-authentification-pied, .conteneur-authentification-tete, .conteneur-main-pied {
    border-radius: .375rem;
}
.conteneur-authentification-pied, .conteneur-authentification-tete, .conteneur-main-pied, .conteneur-authentification-notes {
    margin-top: 2rem;
    padding-top: .5rem;
    padding-bottom: .5rem;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

@media (max-width: 768px) {
    .conteneur-authentification-pied, .conteneur-authentification-tete, .conteneur-main-pied, .conteneur-authentification-notes {
        padding-right: .5rem;
        padding-left: .5rem;
    }
}

.formulaire {
    display: grid;
    grid-template-columns: auto 1fr;
    column-gap: 8px;
    align-items: center;
}

.formulaire-groupe-actions, .confirmation-action-lien {
    margin: 6px 0 0;
    padding: 16px 0;
}

.formulaire-groupe-actions {
    display: flex;
    justify-content: center;
}

.formulaire-groupe-2-cols {
    grid-column: 1 / span 2;
}

.formulaire-groupe-resume-erreurs {
    background: #fff9f9;
    border: 1.5px solid #c02b0a;
    border-radius: 5px;
    box-shadow: 0 1px 4px rgba(0,0,0,.11), 0 0 4px rgba(18,25,97,.041);
    margin-block-end: 8px;
    margin-block-start: 8px;
    padding-block: 16px;
    padding-inline-end: 16px;
    padding-inline-start: 36px;
    position: relative;
    width: 100%;
    background-image: url(./images/icon-error.png);
    background-repeat: no-repeat;
    background-position: 8px center;
}

.formulaire-groupe-resume-erreurs>ul {
    margin-block-end: 0;
    margin-block-start: 0;
    margin-inline: 0;
    padding-inline-start: 18px;
}

.formulaire-groupe-resume-erreurs, .formulaire-groupe-resume-erreurs * {
    color: #c02b0a;
    font-size: 13.2px;
    font-weight: 500;
    line-height: 17.6px;
}

.formulaire-groupe-resume-erreurs:has(li[style*="display:none"]), .formulaire-groupe-resume-erreurs:has(li[style*="display: none"]) {
    display: none;
}

.formulaire-groupe-erreur-champ {
    clear: both;
    width: 100%;
    background: #fff9f9;
    border: 1px solid #c02b0a;
    margin-block-start: 8px;
    padding: 12.992px 24px;
    border-radius: .375rem;
    --tw-bg-opacity: 1;
}

.formulaire-groupe-erreur-champ, .formulaire-groupe-erreur-champ * {
    color: #c02b0a;
    font-size: 15px;
    font-weight: 600;
}

.formulaire-groupe:not(.field-validation-error):not(.field-validation-valid):not(.formulaire-groupe-liens) {
    margin-top: 16px;
}

.conteneur-main-contenu-texte {
    padding-top: 16px;
}

.formulaire-groupe.field-validation-valid {
    display: none !important;
}

.formulaire-groupe-col2 {
    grid-column: 2;
}

.formulaire-groupe-liens {
    margin-top: 1.5rem;
    text-align: center;
}

.info-bulle {
    cursor: help;
}

.confirmation-action {
    text-align: center;
}

.no-wrap {
    text-wrap: nowrap;
}

body {
    max-height: 100dvh;
    overflow: hidden;
}

main {
    overflow: auto;
}

.alert {
    padding: 15px;
    margin-bottom: 20px;
    border: 1px solid transparent;
    border-radius: 4px;
    font-weight: 500;
    text-align: center;
}

.alert h4 {
    margin-top: 0;
    color: inherit;
}

.alert .alert-link {
    font-weight: bold;
}

.alert > p,
.alert > ul {
    margin-bottom: 0;
}

.alert > p + p {
    margin-top: 5px;
}

.alert-dismissable,
.alert-dismissible {
    padding-right: 35px;
}

.alert-dismissable .close,
.alert-dismissible .close {
    position: relative;
    top: -2px;
    right: -21px;
    color: inherit;
}

.alert-success {
    color: #3c763d;
    background-color: #dff0d8;
    border-color: #d6e9c6;
}

.alert-success hr {
    border-top-color: #c9e2b3;
}

.alert-success .alert-link {
    color: #2b542c;
}

.alert-info {
    color: #31708f;
    background-color: #d9edf7;
    border-color: #bce8f1;
}

.alert-info hr {
    border-top-color: #a6e1ec;
}

.alert-info .alert-link {
    color: #245269;
}

.alert-warning {
    color: #8a6d3b;
    background-color: #fcf8e3;
    border-color: #faebcc;
}

.alert-warning hr {
    border-top-color: #f7e1b5;
}

.alert-warning .alert-link {
    color: #66512c;
}

.alert-danger {
    color: #a94442;
    background-color: #f2dede;
    border-color: #ebccd1;
}

.alert-danger hr {
    border-top-color: #e4b9c0;
}

.alert-danger .alert-link {
    color: #843534;
}

input::-ms-reveal {
    display: none;
}

.togglePasswordVisibility {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-left: -3rem;
    width: 3rem;
    height: 3rem;
    padding: 1%;
}

.togglePasswordVisibility :hover {
    background-color: #F1F1F1;
}

.togglePasswordVisibility :active {
    background-color: #E5E5E5;
}

.imgContainer {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 90%;
    aspect-ratio: 1/1;
    padding: 20%;
    margin: 10%;
    border-radius: 100%;
}

.imgContainer > img {
    width: 100%;
    height: 100%;
    user-select: none;
}

.passwordField {
    width: 100%;
    display: inline-flex;
    align-items: center;
}
/* Style et animation du voile de chargement pour les requêtes AJAX */
@font-face {
    font-family: 'Cfcal.Ajax.Chargement';
    src: url('../fonts/glyphicons-halflings-regular.woff') format('woff'), url('../fonts/glyphicons-halflings-regular.ttf') format('truetype');
}

@keyframes apparitionVoile {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

.voile-chargement-global {
    position: fixed;
    top: 0;
    height: 100%;
    left: 0;
    width: 100%;
    -webkit-animation: apparitionVoile 3s 300ms linear 1 both;
    -moz-animation: apparitionVoile 3s 300ms linear 1 both;
    -o-animation: apparitionVoile 3s 300ms linear 1 both;
    animation: apparitionVoile 3s 300ms linear 1 both;
    background: rgba(255, 255, 255, 0.5);
    text-align: center;
    z-index: 9999999;
}

.voile-chargement-partiel {
    position: fixed;
    height: inherit;
    width: inherit;
    -webkit-animation: apparitionVoile 3s 300ms linear 1 both;
    -moz-animation: apparitionVoile 3s 300ms linear 1 both;
    -o-animation: apparitionVoile 3s 300ms linear 1 both;
    animation: apparitionVoile 3s 300ms linear 1 both;
    background: rgba(255, 255, 255, 0.5);
    text-align: center;
    z-index: 9999999;
}

.chargement-contenu {
    position: absolute;
    top: 50%;
    bottom: 0;
    left: 0;
    right: 0;
    margin: -3.9375rem auto 0;
    color: #1a1d1d;
    text-align: center;
}

.chargement-texte {
    font-size: 0.875rem;
    line-height: 1.3125rem;
    text-shadow: white 0 0 1em, white 0 0 0.5em, white 0 0 0.25em;
    position: relative;
    display: block;
    text-transform: uppercase;
    font-weight: bold;
    font-family: 'Cfcal.Ajax.Chargement';
}

    .chargement-texte:after {
        content: "...";
        font-family: 'Cfcal.Ajax.Chargement';
    }

.chargement-icone {
    display: block;
    margin: auto;
    height: 80px;
    width: 80px;
}

.chargement-icone:before {
    vertical-align: middle;
    content: "\e000";
    font-family: 'Cfcal.Ajax.Chargement';
}
