/*
  This CSS file is meant to be customized by deployments
  and is intentionally left empty. Any style that is added
  here should override the default styles in the application.
 */

/*Intégration locale des fonts*/
@font-face {
    font-family: 'DM Sans';
    src: url('/cas/themes/esea-theme/css/fonts/DM_Sans/DMSans-Regular-916f3ae325c2bcd71bec9b469c6a6aa0.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
}

@font-face {
    font-family: 'DM Sans';
    src: url('/cas/themes/esea-theme/css/fonts/DM_Sans/DMSans-Bold-9def97569c21a2e08c818845776c4f21.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
}

:root {
    --mdc-typography-font-family: "DM Sans", "Ubuntu", "Open Sans", Roboto, Arial, sans-serif;
    --brand-primary: #03045E;
    --mdc-theme-primary: var(--brand-primary);
    --cas-theme-primary: var(--brand-primary);
    --bs-blue: var(--brand-primary);
    --red-esea : #C13A51;

    --cas-theme-button-bg-hover : #fff;
    --bs-indigo: #6610f2;
    --bs-purple: #6f42c1;
    --bs-pink: #d63384;
    --bs-red: #dc3545;
    --bs-orange: #fd7e14;
    --bs-yellow: #ffc107;
    --bs-green: #198754;
    --bs-teal: #20c997;
    --bs-cyan: #0dcaf0;
    --bs-black: #000;
    --bs-white: #fff;
    --bs-gray: #6c757d;
    --bs-gray-dark: #343a40;
    --bs-gray-100: #f8f9fa;
    --bs-gray-200: #e9ecef;
    --bs-gray-300: #dee2e6;
    --bs-gray-400: #ced4da;
    --bs-gray-500: #adb5bd;
    --bs-gray-600: #6c757d;
    --bs-gray-700: #495057;
    --bs-gray-800: #343a40;
    --bs-gray-900: #212529;
    --bs-primary: #03045E;
    --bs-secondary: #2AB8B3;
    --bs-danger: var(--red-esea);
    --bs-alert: var(--red-esea);
    --bs-alert-color: var(--red-esea);
    --bs-alert-border-color: var(--red-esea);
    --bs-danger-text-emphasis: var(--red-esea);
    --bs-danger-border-subtle: var(--red-esea);
    --bs-grey: #E9E9EE;
    --bs-disabled: #F1ECEC;

    --bs-success: #2AB8B3;
    --bs-primary-rgb: 3, 4, 94;
    --bs-secondary-rgb: 42, 184, 179;
    --bs-danger-rgb: 193, 58, 81;
    --bs-yellow-rgb: 237, 165, 88;
    --bs-grey-rgb: 233, 233, 238;
    --bs-disabled-rgb: 241, 236, 236;
    --bs-blue-rgb: 3, 4, 94;
    --bs-success-rgb: 42, 184, 179;
    --bs-primary-text-emphasis: rgb(5.2, 44, 101.2);
    --bs-secondary-text-emphasis: rgb(43.2, 46.8, 50);
    --bs-success-text-emphasis: rgb(10, 54, 33.6);
    --bs-info-text-emphasis: rgb(5.2, 80.8, 96);
    --bs-warning-text-emphasis: rgb(102, 77.2, 2.8);
    --bs-light-text-emphasis: #495057;
    --bs-dark-text-emphasis: #495057;
    --bs-primary-bg-subtle: rgb(206.6, 226, 254.6);
    --bs-secondary-bg-subtle: rgb(225.6, 227.4, 229);
    --bs-success-bg-subtle: rgb(209, 231, 220.8);
    --bs-info-bg-subtle: rgb(206.6, 244.4, 252);
    --bs-warning-bg-subtle: rgb(255, 242.6, 205.4);
    --bs-danger-bg-subtle: rgb(248, 214.6, 217.8);
    --bs-light-bg-subtle: rgb(251.5, 252, 252.5);
    --bs-dark-bg-subtle: #ced4da;
    --bs-primary-border-subtle: rgb(158.2, 197, 254.2);
    --bs-secondary-border-subtle: rgb(196.2, 199.8, 203);
    --bs-success-border-subtle: rgb(163, 207, 186.6);
    --bs-info-border-subtle: rgb(158.2, 233.8, 249);
    --bs-warning-border-subtle: rgb(255, 230.2, 155.8);
    --bs-danger-border-subtle: rgb(241, 174.2, 180.6);
    --bs-light-border-subtle: #e9ecef;
    --bs-dark-border-subtle: #adb5bd;
    --bs-white-rgb: 255, 255, 255;
    --bs-black-rgb: 0, 0, 0;
    --bs-font-sans-serif: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --bs-font-monospace: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    --bs-gradient: linear-gradient(180deg, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0));
    --bs-body-font-family: var(--bs-font-sans-serif);
    --bs-body-font-size: 1rem;
    --bs-body-font-weight: 400;
    --bs-body-line-height: 1.5;
    --bs-body-color: #212529;
    --bs-body-color-rgb: 33, 37, 41;
    --bs-body-bg: #fff;
    --bs-body-bg-rgb: 255, 255, 255;
    --bs-emphasis-color: #000;
    --bs-emphasis-color-rgb: 0, 0, 0;
    --bs-secondary-color: rgba(33, 37, 41, 0.75);
    --bs-secondary-color-rgb: 33, 37, 41;
    --bs-secondary-bg: #e9ecef;
    --bs-secondary-bg-rgb: 233, 236, 239;
    --bs-tertiary-color: rgba(33, 37, 41, 0.5);
    --bs-tertiary-color-rgb: 33, 37, 41;
    --bs-tertiary-bg: #f8f9fa;
    --bs-tertiary-bg-rgb: 248, 249, 250;
    --bs-heading-color: inherit;
    --bs-link-color: #03045E;
    --bs-link-color-rgb: 3, 4, 94;
    --bs-link-decoration: underline;
    --bs-link-hover-color: #2AB8B3;
    --bs-link-hover-color-rgb: 42, 184, 179;
    --bs-code-color: #d63384;
    --bs-highlight-color: #212529;
    --bs-highlight-bg: rgb(255, 242.6, 205.4);
    --bs-border-width: 1px;
    --bs-border-style: solid;
    --bs-border-color: #dee2e6;
    --bs-border-color-translucent: rgba(0, 0, 0, 0.175);
    --bs-border-radius: 0.375rem;
    --bs-border-radius-sm: 0.25rem;
    --bs-border-radius-lg: 0.5rem;
    --bs-border-radius-xl: 1rem;
    --bs-border-radius-xxl: 2rem;
    --bs-border-radius-2xl: var(--bs-border-radius-xxl);
    --bs-border-radius-pill: 50rem;
    --bs-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
    --bs-box-shadow-sm: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
    --bs-box-shadow-lg: 0 1rem 3rem rgba(0, 0, 0, 0.175);
    --bs-box-shadow-inset: inset 0 1px 2px rgba(0, 0, 0, 0.075);
    --bs-focus-ring-width: 0.25rem;
    --bs-focus-ring-opacity: 0.25;
    --bs-focus-ring-color: rgba(13, 110, 253, 0.25);
    --bs-form-valid-color: #198754;
    --bs-form-valid-border-color: #198754;
    --bs-form-invalid-color: #dc3545;
    --bs-form-invalid-border-color: #dc3545
}
.mdc-button {
    filter: none !important;
    text-transform: none!important;
}
.mdc-button:hover {
    box-shadow: none !important;
}
button.mdc-button--raised:not(:disabled):hover,
button.mdc-button--raised:not(:disabled):focus-visible {
    transform: none;
}
/*#loginForm + #loginProviders {*/
/*    display: none;*/
/*}*/
div#content {
    box-shadow: none;
}
#main-content {
    margin : 0;


}
.reveal-password {
    border-radius: 0!important;
}
.login-section {
    border-right: 0
}
.mdc-top-app-bar {
    background-color: white;
}

header > nav .cas-brand .cas-logo {
    height: auto;
    width: 175px
}
    *, *::before, *::after {
    box-sizing: border-box
}
.mdc-top-app-bar__row {
    height: 100px;

}
.mdc-top-app-bar {
    position: relative;
}
.banner-danger h2,
.banner-danger {
    color: var(--bs-danger)
}
.banner-danger h1:before, .banner-danger h2:before, .banner-danger h3:before, .banner-danger h4:before, .banner-danger h5:before {
    content: "\F0026";
    margin-right: 0.5rem
}
#securityNotice {
    font-weight: 700;
}
.logo-footer {
    height: 40px;
    width: auto
}
a.btn-outline-primary {
    color: var(--bs-primary)
}
.mb-4 {
    margin-bottom: 1.5rem;
}

.mdc-data-table > div:nth-child(1) {
    margin: 1rem;
}
.form-group {
    width: 370px
}
.login-providers {
    max-width: 100%
}
#chooseAuthForm .login-provider-item .card,
#loginForm  .login-provider-item .card,
#identityProvidersPanel  .login-provider-item .card {
    width: 255px;
    height: 165px!important;
}

.oidc form {
    width : 235px;
    height: 100%;

    background: url('/cas/themes/esea-theme/images/ProSanteConnect_COULEURS-b14cf5a691f6ff96d1fd5047bf6deede.png') no-repeat center center;
    background-size: contain; /* ou cover selon le besoin */

}
.oidc form button {
    background: none!important;
   top: 0;
    bottom:0;
    left: 0;
    right: 0;
    border: 0;
    box-shadow: none;
    height: 100%

}
.oidc form .mdc-button__label {
  visibility: hidden;
}
.separator-row {
    position: relative;
}

.separator-row::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    width: 1px;
    background: var(--bs-secondary);
    transform: translateX(-50%);
}

.separator-row::after {
    content: "OU";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: #fff;
    padding: 20px 20px;
    border-radius: 100px;
    border: 2px solid var(--bs-secondary);
    font-weight: 700;
}

@media (max-width : 992px) {
    .separator-row {
        display: none;
    }
}

@media (prefers-reduced-motion: no-preference) {
    :root {
        scroll-behavior: smooth
    }
}

.cta-support .card {
max-width: 350px;
}

.forgot {
    text-align: left;
    background-image: none !important;
    background-color: var(--bs-secondary) !important;
    border-radius: 30px!important;
    color: var(--bs-primary) !important;
    margin: 2rem;
    justify-content: start;
    font-size: 24px;
    font-weight: 700;
    min-height: 108px;
    letter-spacing: 0;
    text-transform: lowercase;
}
.forgot div:first-letter {
    text-transform: uppercase;
}
.forgot:hover {
    box-shadow: none;
}
.forgot a {
    font-size: 16px;
    display: flex;
    text-decoration: none;
}
.forgot .mdi:before {
    color: var(--bs-primary) !important;
}

body {
    margin: 0;
    font-family: var(--bs-body-font-family);
    font-size: var(--bs-body-font-size);
    font-weight: var(--bs-body-font-weight);
    line-height: var(--bs-body-line-height);
    color: var(--bs-body-color);
    text-align: var(--bs-body-text-align);
    background-color: var(--bs-body-bg);
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    overflow-y: auto;
}

hr {
    margin: 1rem 0;
    color: inherit;
    border: 0;
    border-top: var(--bs-border-width) solid;
    opacity: .25
}

h3, .h3, h2, .h2, h1, .h1 {
    margin-top: 0;
    margin-bottom: .5rem;
    font-weight: 500;
    line-height: 1.2;
    color: var(--bs-heading-color)
}

h1, .h1 {
    font-size: calc(1.375rem + 1.5vw)
}

@media (min-width: 1200px) {
    h1, .h1 {
        font-size: 2.5rem
    }
}

h2, .h2 {
    font-size: calc(1.325rem + 0.9vw)
}

@media (min-width: 1200px) {
    h2, .h2 {
        font-size: 2rem
    }
}

h3, .h3 {
    font-size: calc(1.3rem + 0.6vw)
}

@media (min-width: 1200px) {
    h3, .h3 {
        font-size: 1.75rem
    }
}

p {
    margin-top: 0;
    margin-bottom: 1rem
}

ol, ul {
    padding-left: 2rem
}

ol, ul {
    margin-top: 0;
    margin-bottom: 1rem
}

ol ol, ul ul, ol ul, ul ol {
    margin-bottom: 0
}

dd {
    margin-bottom: .5rem;
    margin-left: 0
}

b, strong {
    font-weight: bolder
}

small, .small {
    font-size: 0.875em
}

a {
    color: rgba(var(--bs-link-color-rgb), var(--bs-link-opacity, 1));
    text-decoration: underline
}

a:hover {
    --bs-link-color-rgb: var(--bs-link-hover-color-rgb)
}

a:not([href]):not([class]), a:not([href]):not([class]):hover {
    color: inherit;
    text-decoration: none
}

code {
    font-family: var(--bs-font-monospace);
    font-size: 1em
}

code {
    font-size: 0.875em;
    color: var(--bs-code-color);
    word-wrap: break-word
}

a > code {
    color: inherit
}

img, svg {
    vertical-align: middle
}

table {
    caption-side: bottom;
    border-collapse: collapse
}

th {
    text-align: inherit;
    text-align: -webkit-match-parent
}

thead, tbody, tr, td, th {
    border-color: inherit;
    border-style: solid;
    border-width: 0
}

label {
    display: inline-block
}

button {
    border-radius: 0
}

button:focus:not(:focus-visible) {
    outline: 0
}

input, button, select {
    margin: 0;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit
}

button, select {
    text-transform: none
}

[role=button] {
    cursor: pointer
}

select {
    word-wrap: normal
}

select:disabled {
    opacity: 1
}

button, [type=button], [type=submit] {
    -webkit-appearance: button
}

button:not(:disabled), [type=button]:not(:disabled), [type=submit]:not(:disabled) {
    cursor: pointer
}

::-moz-focus-inner {
    padding: 0;
    border-style: none
}

::-webkit-datetime-edit-fields-wrapper, ::-webkit-datetime-edit-text, ::-webkit-datetime-edit-minute, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-year-field {
    padding: 0
}

::-webkit-inner-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-color-swatch-wrapper {
    padding: 0
}

::file-selector-button {
    font: inherit;
    -webkit-appearance: button
}

.img-fluid {
    max-width: 100%;
    height: auto
}

.container {
    --bs-gutter-x: 1.5rem;
    --bs-gutter-y: 0;
    width: 100%;
    padding-right: calc(var(--bs-gutter-x) * .5);
    padding-left: calc(var(--bs-gutter-x) * .5);
    margin-right: auto;
    margin-left: auto
}

@media (min-width: 576px) {
    .container {
        max-width: 540px
    }
}

@media (min-width: 768px) {
    .container {
        max-width: 720px
    }
}

@media (min-width: 992px) {
    .container {
        max-width: 960px
    }
}

@media (min-width: 1200px) {
    .container {
        max-width: 1140px
    }
}

@media (min-width: 1400px) {
    .container {
        max-width: 1320px
    }
}

:root {
    --bs-breakpoint-xs: 0;
    --bs-breakpoint-sm: 576px;
    --bs-breakpoint-md: 768px;
    --bs-breakpoint-lg: 992px;
    --bs-breakpoint-xl: 1200px;
    --bs-breakpoint-xxl: 1400px
}

.row {
    --bs-gutter-x: 1.5rem;
    --bs-gutter-y: 0;
    display: flex;
    flex-wrap: wrap;
    margin-top: calc(-1 * var(--bs-gutter-y));
    margin-right: calc(-0.5 * var(--bs-gutter-x));
    margin-left: calc(-0.5 * var(--bs-gutter-x))
}

.row > * {
    flex-shrink: 0;
    max-width: 100%;
    padding-right: calc(var(--bs-gutter-x) * .5);
    padding-left: calc(var(--bs-gutter-x) * .5);
    margin-top: var(--bs-gutter-y)
}

.col {
    flex: 1 0 0%
}

.row-cols-1 > * {
    flex: 0 0 auto;
    width: 100%
}

.row-cols-2 > * {
    flex: 0 0 auto;
    width: 50%
}

.col-12 {
    flex: 0 0 auto;
    width: 100%
}

.g-2 {
    --bs-gutter-x: 0.5rem
}

.g-2 {
    --bs-gutter-y: 0.5rem
}

.g-3 {
    --bs-gutter-x: 1rem
}

.g-3 {
    --bs-gutter-y: 1rem
}

.g-4 {
    --bs-gutter-x: 1.5rem
}

.g-4, .gy-4 {
    --bs-gutter-y: 1.5rem
}

@media (min-width: 576px) {
    .row-cols-sm-2 > * {
        flex: 0 0 auto;
        width: 50%
    }
}

@media (min-width: 768px) {
    .row-cols-md-1 > * {
        flex: 0 0 auto;
        width: 100%
    }

    .row-cols-md-2 > * {
        flex: 0 0 auto;
        width: 50%
    }

    .row-cols-md-3 > * {
        flex: 0 0 auto;
        width: 33.33333333%
    }

    .row-cols-md-5 > * {
        flex: 0 0 auto;
        width: 20%
    }

    .row-cols-md-6 > * {
        flex: 0 0 auto;
        width: 16.66666667%
    }

    .col-md-4 {
        flex: 0 0 auto;
        width: 33.33333333%
    }

    .col-md-6 {
        flex: 0 0 auto;
        width: 50%
    }

    .col-md-8 {
        flex: 0 0 auto;
        width: 66.66666667%
    }

    .col-md-12 {
        flex: 0 0 auto;
        width: 100%
    }

    .g-md-5 {
        --bs-gutter-x: 3rem
    }

    .g-md-5 {
        --bs-gutter-y: 3rem
    }
}

@media (min-width: 992px) {
    .row-cols-lg-2 > * {
        flex: 0 0 auto;
        width: 50%
    }

    .row-cols-lg-3 > * {
        flex: 0 0 auto;
        width: 33.33333333%
    }

    .row-cols-lg-4 > * {
        flex: 0 0 auto;
        width: 25%
    }

    .col-lg-4 {
        flex: 0 0 auto;
        width: 33.33333333%
    }

}

.table {
    --bs-table-color-type: initial;
    --bs-table-bg-type: initial;
    --bs-table-color-state: initial;
    --bs-table-bg-state: initial;
    --bs-table-color: var(--bs-emphasis-color);
    --bs-table-bg: var(--bs-body-bg);
    --bs-table-border-color: var(--bs-border-color);
    --bs-table-accent-bg: transparent;
    --bs-table-striped-color: var(--bs-emphasis-color);
    --bs-table-striped-bg: rgba(var(--bs-emphasis-color-rgb), 0.05);
    --bs-table-active-color: var(--bs-emphasis-color);
    --bs-table-active-bg: rgba(var(--bs-emphasis-color-rgb), 0.1);
    --bs-table-hover-color: var(--bs-emphasis-color);
    --bs-table-hover-bg: rgba(var(--bs-emphasis-color-rgb), 0.075);
    width: 100%;
    margin-bottom: 1rem;
    vertical-align: top;
    border-color: var(--bs-table-border-color)
}

.table > :not(caption) > * > * {
    padding: .5rem .5rem;
    color: var(--bs-table-color-state, var(--bs-table-color-type, var(--bs-table-color)));
    background-color: var(--bs-table-bg);
    border-bottom-width: var(--bs-border-width);
    box-shadow: inset 0 0 0 9999px var(--bs-table-bg-state, var(--bs-table-bg-type, var(--bs-table-accent-bg)))
}

.table > tbody {
    vertical-align: inherit
}

.table > thead {
    vertical-align: bottom
}

.table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch
}

.form-label {
    margin-bottom: .5rem
}

.form-control {
    display: block;
    width: 100%;
    padding: .375rem .75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: var(--bs-body-color);
    appearance: none;
    background-color: var(--bs-body-bg);
    background-clip: padding-box;
    border: var(--bs-border-width) solid var(--bs-border-color);
    border-radius: var(--bs-border-radius);
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out
}

@media (prefers-reduced-motion: reduce) {
    .form-control {
        transition: none
    }
}

.form-control:focus {
    color: var(--bs-body-color);
    background-color: var(--bs-body-bg);
    border-color: rgb(134, 182.5, 254);
    outline: 0;
    box-shadow: 0 0 0 .25rem rgba(13, 110, 253, .25)
}

.form-control::-webkit-date-and-time-value {
    min-width: 85px;
    height: 1.5em;
    margin: 0
}

.form-control::-webkit-datetime-edit {
    display: block;
    padding: 0
}

.form-control::placeholder {
    color: var(--bs-secondary-color);
    opacity: 1
}

.form-control:disabled {
    background-color: var(--bs-secondary-bg);
    opacity: 1
}

.form-control::file-selector-button {
    padding: .375rem .75rem;
    margin: -0.375rem -0.75rem;
    margin-inline-end: .75rem;
    color: var(--bs-body-color);
    background-color: var(--bs-tertiary-bg);
    pointer-events: none;
    border-color: inherit;
    border-style: solid;
    border-width: 0;
    border-inline-end-width: var(--bs-border-width);
    border-radius: 0;
    transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out
}

@media (prefers-reduced-motion: reduce) {
    .form-control::file-selector-button {
        transition: none
    }
}

.form-control:hover:not(:disabled):not([readonly])::file-selector-button {
    background-color: var(--bs-secondary-bg)
}

.form-select {
    --bs-form-select-bg-img: url("data:image/svg+xml,%3csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 16 16%27%3e%3cpath fill=%27none%27 stroke=%27%23343a40%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27 stroke-width=%272%27 d=%27m2 5 6 6 6-6%27/%3e%3c/svg%3e");
    display: block;
    width: 100%;
    padding: .375rem 2.25rem .375rem .75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: var(--bs-body-color);
    appearance: none;
    background-color: var(--bs-body-bg);
    background-image: var(--bs-form-select-bg-img), var(--bs-form-select-bg-icon, none);
    background-repeat: no-repeat;
    background-position: right .75rem center;
    background-size: 16px 12px;
    border: var(--bs-border-width) solid var(--bs-border-color);
    border-radius: var(--bs-border-radius);
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out
}

@media (prefers-reduced-motion: reduce) {
    .form-select {
        transition: none
    }
}

.form-select:focus {
    border-color: rgb(134, 182.5, 254);
    outline: 0;
    box-shadow: 0 0 0 .25rem rgba(13, 110, 253, .25)
}

.form-select[size]:not([size="1"]) {
    padding-right: .75rem;
    background-image: none
}

.form-select:disabled {
    background-color: var(--bs-secondary-bg)
}

.form-select:-moz-focusring {
    color: rgba(0, 0, 0, 0);
    text-shadow: 0 0 0 var(--bs-body-color)
}

.form-check {
    display: block;
    min-height: 1.5rem;
    padding-left: 1.5em;
    margin-bottom: .125rem
}

.form-check .form-check-input {
    float: left;
    margin-left: -1.5em
}

.form-check-input {
    --bs-form-check-bg: var(--bs-body-bg);
    flex-shrink: 0;
    width: 1em;
    height: 1em;
    margin-top: .25em;
    vertical-align: top;
    appearance: none;
    background-color: var(--bs-form-check-bg);
    background-image: var(--bs-form-check-bg-image);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    border: var(--bs-border-width) solid var(--bs-border-color);
    print-color-adjust: exact
}

.form-check-input[type=checkbox] {
    border-radius: .25em
}

.form-check-input:active {
    filter: brightness(90%)
}

.form-check-input:focus {
    border-color: rgb(134, 182.5, 254);
    outline: 0;
    box-shadow: 0 0 0 .25rem rgba(13, 110, 253, .25)
}

.form-check-input:checked {
    background-color: #0d6efd;
    border-color: #0d6efd
}

.form-check-input:checked[type=checkbox] {
    --bs-form-check-bg-image: url("data:image/svg+xml,%3csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 20 20%27%3e%3cpath fill=%27none%27 stroke=%27%23fff%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27 stroke-width=%273%27 d=%27m6 10 3 3 6-6%27/%3e%3c/svg%3e")
}

.form-check-input[type=checkbox]:indeterminate {
    background-color: #0d6efd;
    border-color: #0d6efd;
    --bs-form-check-bg-image: url("data:image/svg+xml,%3csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 20 20%27%3e%3cpath fill=%27none%27 stroke=%27%23fff%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27 stroke-width=%273%27 d=%27M6 10h8%27/%3e%3c/svg%3e")
}

.form-check-input:disabled {
    pointer-events: none;
    filter: none;
    opacity: .5
}

.form-check-input[disabled] ~ .form-check-label, .form-check-input:disabled ~ .form-check-label {
    cursor: default;
    opacity: .5
}

.btn {
    --bs-btn-padding-x: 0.75rem;
    --bs-btn-padding-y: 0.375rem;
    --bs-btn-font-family: ;
    --bs-btn-font-size: 1rem;
    --bs-btn-font-weight: 400;
    --bs-btn-line-height: 1.5;
    --bs-btn-color: var(--bs-body-color);
    --bs-btn-bg: transparent;
    --bs-btn-border-width: var(--bs-border-width);
    --bs-btn-border-color: transparent;
    --bs-btn-border-radius: var(--bs-border-radius);
    --bs-btn-hover-border-color: transparent;
    --bs-btn-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 1px 1px rgba(0, 0, 0, 0.075);
    --bs-btn-disabled-opacity: 0.65;
    --bs-btn-focus-box-shadow: 0 0 0 0.25rem rgba(var(--bs-btn-focus-shadow-rgb), .5);
    display: inline-block;
    padding: var(--bs-btn-padding-y) var(--bs-btn-padding-x);
    font-family: var(--bs-btn-font-family);
    font-size: var(--bs-btn-font-size);
    font-weight: var(--bs-btn-font-weight);
    line-height: var(--bs-btn-line-height);
    color: var(--bs-btn-color);
    text-align: center;
    text-decoration: none;
    vertical-align: middle;
    cursor: pointer;
    user-select: none;
    border: var(--bs-btn-border-width) solid var(--bs-btn-border-color);
    border-radius: var(--bs-btn-border-radius);
    background-color: var(--bs-btn-bg);
    transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out
}

@media (prefers-reduced-motion: reduce) {
    .btn {
        transition: none
    }
}

.btn:hover {
    color: var(--bs-btn-hover-color);
    background-color: var(--bs-btn-hover-bg);
    border-color: var(--bs-btn-hover-border-color)
}

.btn:focus-visible {
    color: var(--bs-btn-hover-color);
    background-color: var(--bs-btn-hover-bg);
    border-color: var(--bs-btn-hover-border-color);
    outline: 0;
    box-shadow: var(--bs-btn-focus-box-shadow)
}

:not(.btn-check) + .btn:active, .btn:first-child:active, .btn.active {
    color: var(--bs-btn-active-color);
    background-color: var(--bs-btn-active-bg);
    border-color: var(--bs-btn-active-border-color)
}

:not(.btn-check) + .btn:active:focus-visible, .btn:first-child:active:focus-visible, .btn.active:focus-visible {
    box-shadow: var(--bs-btn-focus-box-shadow)
}

.btn:disabled, .btn.disabled {
    color: var(--bs-btn-disabled-color);
    pointer-events: none;
    background-color: var(--bs-btn-disabled-bg);
    border-color: var(--bs-btn-disabled-border-color);
    opacity: var(--bs-btn-disabled-opacity)
}

.btn-primary {
    --bs-btn-color: #fff;
    --bs-btn-bg: #03045E;
    --bs-btn-border-color: #03045E;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: rgb(2.55, 3.4, 79.9);
    --bs-btn-hover-border-color: rgb(2.4, 3.2, 75.2);
    --bs-btn-focus-shadow-rgb: 41, 42, 118;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: rgb(2.4, 3.2, 75.2);
    --bs-btn-active-border-color: rgb(2.25, 3, 70.5);
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: #03045E;
    --bs-btn-disabled-border-color: #03045E
}

.btn-secondary {
    --bs-btn-color: #000;
    --bs-btn-bg: #2AB8B3;
    --bs-btn-border-color: #2AB8B3;
    --bs-btn-hover-color: #000;
    --bs-btn-hover-bg: rgb(73.95, 194.65, 190.4);
    --bs-btn-hover-border-color: rgb(63.3, 191.1, 186.6);
    --bs-btn-focus-shadow-rgb: 36, 156, 152;
    --bs-btn-active-color: #000;
    --bs-btn-active-bg: rgb(84.6, 198.2, 194.2);
    --bs-btn-active-border-color: rgb(63.3, 191.1, 186.6);
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #000;
    --bs-btn-disabled-bg: #2AB8B3;
    --bs-btn-disabled-border-color: #2AB8B3
}

.btn-outline-primary {
    --bs-btn-color: #03045E;
    --bs-btn-border-color: #03045E;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #03045E;
    --bs-btn-hover-border-color: #03045E;
    --bs-btn-focus-shadow-rgb: 3, 4, 94;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #03045E;
    --bs-btn-active-border-color: #03045E;
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #03045E;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #03045E;
    --bs-gradient: none
}

.btn-outline-yellow {
    --bs-btn-color: #EDA558;
    --bs-btn-border-color: #EDA558;
    --bs-btn-hover-color: #000;
    --bs-btn-hover-bg: #EDA558;
    --bs-btn-hover-border-color: #EDA558;
    --bs-btn-focus-shadow-rgb: 237, 165, 88;
    --bs-btn-active-color: #000;
    --bs-btn-active-bg: #EDA558;
    --bs-btn-active-border-color: #EDA558;
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #EDA558;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #EDA558;
    --bs-gradient: none
}

.collapse:not(.show) {
    display: none
}

.dropdown {
    position: relative
}

.dropdown-toggle {
    white-space: nowrap
}

.dropdown-toggle::after {
    display: inline-block;
    margin-left: .255em;
    vertical-align: .255em;
    content: "";
    border-top: .3em solid;
    border-right: .3em solid rgba(0, 0, 0, 0);
    border-bottom: 0;
    border-left: .3em solid rgba(0, 0, 0, 0)
}

.dropdown-toggle:empty::after {
    margin-left: 0
}

.dropdown-menu {
    --bs-dropdown-zindex: 1000;
    --bs-dropdown-min-width: 10rem;
    --bs-dropdown-padding-x: 0;
    --bs-dropdown-padding-y: 0.5rem;
    --bs-dropdown-spacer: 0.125rem;
    --bs-dropdown-font-size: 1rem;
    --bs-dropdown-color: var(--bs-body-color);
    --bs-dropdown-bg: var(--bs-body-bg);
    --bs-dropdown-border-color: var(--bs-border-color-translucent);
    --bs-dropdown-border-radius: var(--bs-border-radius);
    --bs-dropdown-border-width: var(--bs-border-width);
    --bs-dropdown-inner-border-radius: calc(var(--bs-border-radius) - var(--bs-border-width));
    --bs-dropdown-divider-bg: var(--bs-border-color-translucent);
    --bs-dropdown-divider-margin-y: 0.5rem;
    --bs-dropdown-box-shadow: var(--bs-box-shadow);
    --bs-dropdown-link-color: var(--bs-body-color);
    --bs-dropdown-link-hover-color: var(--bs-body-color);
    --bs-dropdown-link-hover-bg: var(--bs-tertiary-bg);
    --bs-dropdown-link-active-color: #fff;
    --bs-dropdown-link-active-bg: #0d6efd;
    --bs-dropdown-link-disabled-color: var(--bs-tertiary-color);
    --bs-dropdown-item-padding-x: 1rem;
    --bs-dropdown-item-padding-y: 0.25rem;
    --bs-dropdown-header-color: #6c757d;
    --bs-dropdown-header-padding-x: 1rem;
    --bs-dropdown-header-padding-y: 0.5rem;
    position: absolute;
    z-index: var(--bs-dropdown-zindex);
    display: none;
    min-width: var(--bs-dropdown-min-width);
    padding: var(--bs-dropdown-padding-y) var(--bs-dropdown-padding-x);
    margin: 0;
    font-size: var(--bs-dropdown-font-size);
    color: var(--bs-dropdown-color);
    text-align: left;
    list-style: none;
    background-color: var(--bs-dropdown-bg);
    background-clip: padding-box;
    border: var(--bs-dropdown-border-width) solid var(--bs-dropdown-border-color);
    border-radius: var(--bs-dropdown-border-radius)
}

.nav {
    --bs-nav-link-padding-x: 1rem;
    --bs-nav-link-padding-y: 0.5rem;
    --bs-nav-link-font-weight: ;
    --bs-nav-link-color: var(--bs-link-color);
    --bs-nav-link-hover-color: var(--bs-link-hover-color);
    --bs-nav-link-disabled-color: var(--bs-secondary-color);
    display: flex;
    flex-wrap: wrap;
    padding-left: 0;
    margin-bottom: 0;
    list-style: none
}

.nav-link {
    display: block;
    padding: var(--bs-nav-link-padding-y) var(--bs-nav-link-padding-x);
    font-size: var(--bs-nav-link-font-size);
    font-weight: var(--bs-nav-link-font-weight);
    color: var(--bs-nav-link-color);
    text-decoration: none;
    background: none;
    border: 0;
    transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out
}

@media (prefers-reduced-motion: reduce) {
    .nav-link {
        transition: none
    }
}

.nav-link:hover, .nav-link:focus {
    color: var(--bs-nav-link-hover-color)
}

.nav-link:focus-visible {
    outline: 0;
    box-shadow: 0 0 0 .25rem rgba(13, 110, 253, .25)
}

.nav-link.disabled, .nav-link:disabled {
    color: var(--bs-nav-link-disabled-color);
    pointer-events: none;
    cursor: default
}

.navbar {
    --bs-navbar-padding-x: 0;
    --bs-navbar-padding-y: 0.5rem;
    --bs-navbar-color: rgba(var(--bs-emphasis-color-rgb), 0.65);
    --bs-navbar-hover-color: rgba(var(--bs-emphasis-color-rgb), 0.8);
    --bs-navbar-disabled-color: rgba(var(--bs-emphasis-color-rgb), 0.3);
    --bs-navbar-active-color: rgba(var(--bs-emphasis-color-rgb), 1);
    --bs-navbar-brand-padding-y: 0.3125rem;
    --bs-navbar-brand-margin-end: 1rem;
    --bs-navbar-brand-font-size: 1.25rem;
    --bs-navbar-brand-color: rgba(var(--bs-emphasis-color-rgb), 1);
    --bs-navbar-brand-hover-color: rgba(var(--bs-emphasis-color-rgb), 1);
    --bs-navbar-nav-link-padding-x: 0.5rem;
    --bs-navbar-toggler-padding-y: 0.25rem;
    --bs-navbar-toggler-padding-x: 0.75rem;
    --bs-navbar-toggler-font-size: 1.25rem;
    --bs-navbar-toggler-icon-bg: url("data:image/svg+xml,%3csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 30 30%27%3e%3cpath stroke=%27rgba%2833, 37, 41, 0.75%29%27 stroke-linecap=%27round%27 stroke-miterlimit=%2710%27 stroke-width=%272%27 d=%27M4 7h22M4 15h22M4 23h22%27/%3e%3c/svg%3e");
    --bs-navbar-toggler-border-color: rgba(var(--bs-emphasis-color-rgb), 0.15);
    --bs-navbar-toggler-border-radius: var(--bs-border-radius);
    --bs-navbar-toggler-focus-width: 0.25rem;
    --bs-navbar-toggler-transition: box-shadow 0.15s ease-in-out;
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    padding: var(--bs-navbar-padding-y) var(--bs-navbar-padding-x)
}

.navbar > .container {
    display: flex;
    flex-wrap: inherit;
    align-items: center;
    justify-content: space-between
}

.navbar-brand {
    padding-top: var(--bs-navbar-brand-padding-y);
    padding-bottom: var(--bs-navbar-brand-padding-y);
    margin-right: var(--bs-navbar-brand-margin-end);
    font-size: var(--bs-navbar-brand-font-size);
    color: var(--bs-navbar-brand-color);
    text-decoration: none;
    white-space: nowrap
}

.navbar-brand:hover, .navbar-brand:focus {
    color: var(--bs-navbar-brand-hover-color)
}

.navbar-nav {
    --bs-nav-link-padding-x: 0;
    --bs-nav-link-padding-y: 0.5rem;
    --bs-nav-link-font-weight: ;
    --bs-nav-link-color: var(--bs-navbar-color);
    --bs-nav-link-hover-color: var(--bs-navbar-hover-color);
    --bs-nav-link-disabled-color: var(--bs-navbar-disabled-color);
    display: flex;
    flex-direction: column;
    padding-left: 0;
    margin-bottom: 0;
    list-style: none
}

.navbar-nav .nav-link.active {
    color: var(--bs-navbar-active-color)
}

.navbar-nav .dropdown-menu {
    position: static
}

.navbar-collapse {
    flex-basis: 100%;
    flex-grow: 1;
    align-items: center
}

.navbar-toggler {
    padding: var(--bs-navbar-toggler-padding-y) var(--bs-navbar-toggler-padding-x);
    font-size: var(--bs-navbar-toggler-font-size);
    line-height: 1;
    color: var(--bs-navbar-color);
    background-color: rgba(0, 0, 0, 0);
    border: var(--bs-border-width) solid var(--bs-navbar-toggler-border-color);
    border-radius: var(--bs-navbar-toggler-border-radius);
    transition: var(--bs-navbar-toggler-transition)
}

@media (prefers-reduced-motion: reduce) {
    .navbar-toggler {
        transition: none
    }
}

.navbar-toggler:hover {
    text-decoration: none
}

.navbar-toggler:focus {
    text-decoration: none;
    outline: 0;
    box-shadow: 0 0 0 var(--bs-navbar-toggler-focus-width)
}

.navbar-toggler-icon {
    display: inline-block;
    width: 1.5em;
    height: 1.5em;
    vertical-align: middle;
    background-image: var(--bs-navbar-toggler-icon-bg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 100%
}

@media (min-width: 992px) {
    .navbar-expand-lg {
        flex-wrap: nowrap;
        justify-content: flex-start
    }

    .navbar-expand-lg .navbar-nav {
        flex-direction: row
    }

    .navbar-expand-lg .navbar-nav .dropdown-menu {
        position: absolute
    }

    .navbar-expand-lg .navbar-nav .nav-link {
        padding-right: var(--bs-navbar-nav-link-padding-x);
        padding-left: var(--bs-navbar-nav-link-padding-x)
    }

    .navbar-expand-lg .navbar-collapse {
        display: flex !important;
        flex-basis: auto
    }

    .navbar-expand-lg .navbar-toggler {
        display: none
    }
}

.card {
    --bs-card-spacer-y: 1rem;
    --bs-card-spacer-x: 1rem;
    --bs-card-title-spacer-y: 0.5rem;
    --bs-card-title-color: ;
    --bs-card-subtitle-color: ;
    --bs-card-border-width: var(--bs-border-width);
    --bs-card-border-color: var(--bs-border-color-translucent);
    --bs-card-border-radius: var(--bs-border-radius);
    --bs-card-box-shadow: ;
    --bs-card-inner-border-radius: calc(var(--bs-border-radius) - (var(--bs-border-width)));
    --bs-card-cap-padding-y: 0.5rem;
    --bs-card-cap-padding-x: 1rem;
    --bs-card-cap-bg: rgba(var(--bs-body-color-rgb), 0.03);
    --bs-card-cap-color: ;
    --bs-card-height: ;
    --bs-card-color: ;
    --bs-card-bg: var(--bs-body-bg);
    --bs-card-img-overlay-padding: 1rem;
    --bs-card-group-margin: 0.75rem;
    position: relative;
    display: flex;
    flex-direction: column;
    min-width: 0;
    height: var(--bs-card-height);
    color: var(--bs-body-color);
    word-wrap: break-word;
    background-color: var(--bs-card-bg);
    background-clip: border-box;
    border: var(--bs-card-border-width) solid var(--bs-card-border-color);
    border-radius: var(--bs-card-border-radius)
}

.card > hr {
    margin-right: 0;
    margin-left: 0
}

.card-body {
    flex: 1 1 auto;
    padding: var(--bs-card-spacer-y) var(--bs-card-spacer-x);
    color: var(--bs-card-color)
}

.card-title {
    margin-bottom: var(--bs-card-title-spacer-y);
    color: var(--bs-card-title-color)
}

.card-subtitle {
    margin-top: calc(-0.5 * var(--bs-card-title-spacer-y));
    margin-bottom: 0;
    color: var(--bs-card-subtitle-color)
}

.card-text:last-child {
    margin-bottom: 0
}

.card-header {
    padding: var(--bs-card-cap-padding-y) var(--bs-card-cap-padding-x);
    margin-bottom: 0;
    color: var(--bs-card-cap-color);
    background-color: var(--bs-card-cap-bg);
    border-bottom: var(--bs-card-border-width) solid var(--bs-card-border-color)
}

.card-header:first-child {
    border-radius: var(--bs-card-inner-border-radius) var(--bs-card-inner-border-radius) 0 0
}

.card-img-top {
    width: 100%
}

.card-img-top {
    border-top-left-radius: var(--bs-card-inner-border-radius);
    border-top-right-radius: var(--bs-card-inner-border-radius)
}

.badge {
    --bs-badge-padding-x: 0.65em;
    --bs-badge-padding-y: 0.35em;
    --bs-badge-font-size: 0.75em;
    --bs-badge-font-weight: 700;
    --bs-badge-color: #fff;
    --bs-badge-border-radius: var(--bs-border-radius);
    display: inline-block;
    padding: var(--bs-badge-padding-y) var(--bs-badge-padding-x);
    font-size: var(--bs-badge-font-size);
    font-weight: var(--bs-badge-font-weight);
    line-height: 1;
    color: var(--bs-badge-color);
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    border-radius: var(--bs-badge-border-radius)
}

.badge:empty {
    display: none
}

.btn .badge {
    position: relative;
    top: -1px
}

.alert {
    --bs-alert-bg: transparent;
    --bs-alert-padding-x: 1rem;
    --bs-alert-padding-y: 1rem;
    --bs-alert-margin-bottom: 1rem;
    --bs-alert-color: inherit;
    --bs-alert-border-color: transparent;
    --bs-alert-border: var(--bs-border-width) solid var(--bs-alert-border-color);
    --bs-alert-border-radius: var(--bs-border-radius);
    --bs-alert-link-color: inherit;
    position: relative;
    padding: var(--bs-alert-padding-y) var(--bs-alert-padding-x);
    margin-bottom: var(--bs-alert-margin-bottom);
    color: var(--bs-alert-color);
    background-color: var(--bs-alert-bg);
    border: var(--bs-alert-border);
    border-radius: var(--bs-alert-border-radius)
}

.alert-primary {
    --bs-alert-color: var(--bs-primary-text-emphasis);
    --bs-alert-bg: var(--bs-primary-bg-subtle);
    --bs-alert-border-color: var(--bs-primary-border-subtle);
    --bs-alert-link-color: var(--bs-primary-text-emphasis)
}

.alert-danger {
    --bs-alert-color: var(--bs-danger-text-emphasis);
    --bs-alert-bg: var(--bs-danger-bg-subtle);
    --bs-alert-border-color: var(--bs-danger-border-subtle);
    --bs-alert-link-color: var(--bs-danger-text-emphasis)
}

.alert-success {
    --bs-alert-color: var(--bs-success-text-emphasis);
    --bs-alert-bg: var(--bs-success-bg-subtle);
    --bs-alert-border-color: var(--bs-success-border-subtle);
    --bs-alert-link-color: var(--bs-success-text-emphasis)
}

@keyframes progress-bar-stripes {
    0% {
        background-position-x: 1rem
    }
}

@keyframes spinner-border {
    to {
        transform: rotate(360deg) /* rtl:ignore */
    }
}

@keyframes spinner-grow {
    0% {
        transform: scale(0)
    }
    50% {
        opacity: 1;
        transform: none
    }
}

.placeholder {
    display: inline-block;
    min-height: 1em;
    vertical-align: middle;
    cursor: wait;
    background-color: currentcolor;
    opacity: .5
}

.placeholder.btn::before {
    display: inline-block;
    content: ""
}

@keyframes placeholder-glow {
    50% {
        opacity: .2
    }
}

@keyframes placeholder-wave {
    100% {
        mask-position: -200% 0%
    }
}

.visually-hidden {
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important
}

.visually-hidden:not(caption) {
    position: absolute !important
}

.stretched-link::after {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1;
    content: ""
}

.d-block {
    display: block !important
}

.d-flex {
    display: flex !important
}

.d-none {
    display: none !important
}

.border-start {
    border-left: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important
}

.border-secondary {
    --bs-border-opacity: 1;
    border-color: rgba(var(--bs-secondary-rgb), var(--bs-border-opacity)) !important
}

.border-1 {
    border-width: 1px !important
}

.border-2 {
    border-width: 2px !important
}

.border-opacity-100 {
    --bs-border-opacity: 1
}

.w-50 {
    width: 50% !important
}

.h-100 {
    height: 100% !important
}

.flex-column {
    flex-direction: column !important
}

.flex-row-reverse {
    flex-direction: row-reverse !important
}

.flex-grow-1 {
    flex-grow: 1 !important
}

.flex-wrap {
    flex-wrap: wrap !important
}

.justify-content-start {
    justify-content: flex-start !important
}

.justify-content-end {
    justify-content: flex-end !important
}

.justify-content-center {
    justify-content: center !important
}

.justify-content-between {
    justify-content: space-between !important
}

.justify-content-around {
    justify-content: space-around !important
}

.align-items-end {
    align-items: flex-end !important
}

.align-items-center {
    align-items: center !important
}

.align-self-center {
    align-self: center !important
}

.m-0 {
    margin: 0 !important
}

.m-1 {
    margin: .25rem !important
}

.m-5 {
    margin: 3rem !important
}

.mx-auto {
    margin-right: auto !important;
    margin-left: auto !important
}

.my-1 {
    margin-top: .25rem !important;
    margin-bottom: .25rem !important
}

.my-2 {
    margin-top: .5rem !important;
    margin-bottom: .5rem !important
}

.my-3 {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important
}

.my-5 {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important
}

.mt-2 {
    margin-top: .5rem !important
}

.mt-3 {
    margin-top: 1rem !important
}

.mt-4 {
    margin-top: 1.5rem !important
}

.mt-5 {
    margin-top: 3rem !important
}

.me-2 {
    margin-right: .5rem !important
}

.me-3 {
    margin-right: 1rem !important
}

.me-4 {
    margin-right: 1.5rem !important
}

.me-auto {
    margin-right: auto !important
}

.mb-0 {
    margin-bottom: 0 !important
}

.mb-2 {
    margin-bottom: .5rem !important
}

.mb-3 {
    margin-bottom: 1rem !important
}

.mb-5 {
    margin-bottom: 3rem !important
}

.mb-auto {
    margin-bottom: auto !important
}

.ms-1 {
    margin-left: .25rem !important
}

.ms-2 {
    margin-left: .5rem !important
}

.ms-auto {
    margin-left: auto !important
}

.p-0 {
    padding: 0 !important
}

.p-3 {
    padding: 1rem !important
}

.p-5 {
    padding: 3rem !important
}

.px-5 {
    padding-right: 3rem !important;
    padding-left: 3rem !important
}

.py-2 {
    padding-top: .5rem !important;
    padding-bottom: .5rem !important
}

.py-3 {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important
}

.py-4 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important
}

.py-5 {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important
}

.pt-3 {
    padding-top: 1rem !important
}

.pb-3 {
    padding-bottom: 1rem !important
}

.gap-1 {
    gap: .25rem !important
}

.gap-2 {
    gap: .5rem !important
}

.gap-3 {
    gap: 1rem !important
}

.gap-4 {
    gap: 1.5rem !important
}

.gap-5 {
    gap: 3rem !important
}

.fw-bold {
    font-weight: 700 !important
}

.text-start {
    text-align: left !important
}

.text-center {
    text-align: center !important
}

.text-primary {
    --bs-text-opacity: 1;
    color: rgba(var(--bs-primary-rgb), var(--bs-text-opacity)) !important
}

.text-secondary {
    --bs-text-opacity: 1;
    color: rgba(var(--bs-secondary-rgb), var(--bs-text-opacity)) !important
}

.text-danger {
    --bs-text-opacity: 1;
    color: rgba(var(--bs-danger-rgb), var(--bs-text-opacity)) !important
}

.text-white {
    --bs-text-opacity: 1;
    color: rgba(var(--bs-white-rgb), var(--bs-text-opacity)) !important
}

.text-muted {
    --bs-text-opacity: 1;
    color: var(--bs-secondary-color) !important
}

.link-underline-opacity-0 {
    --bs-link-underline-opacity: 0
}

.bg-primary {
    --bs-bg-opacity: 1;
    background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important
}

.bg-white {
    --bs-bg-opacity: 1;
    background-color: rgba(var(--bs-white-rgb), var(--bs-bg-opacity)) !important
}

.rounded-circle {
    border-radius: 50% !important
}

.rounded-pill {
    border-radius: var(--bs-border-radius-pill) !important
}

@media (min-width: 768px) {
    .d-md-block {
        display: block !important
    }

    .justify-content-md-end {
        justify-content: flex-end !important
    }

    .my-md-4 {
        margin-top: 1.5rem !important;
        margin-bottom: 1.5rem !important
    }

    .my-md-5 {
        margin-top: 3rem !important;
        margin-bottom: 3rem !important
    }

    .mb-md-5 {
        margin-bottom: 3rem !important
    }

    .py-md-5 {
        padding-top: 3rem !important;
        padding-bottom: 3rem !important
    }
}

@media (min-width: 992px) {
    .justify-content-lg-end {
        justify-content: flex-end !important
    }
    .justify-content-lg-start {
        justify-content: flex-start !important

    }

    .mx-lg-0 {
        margin-right: 0 !important;
        margin-left: 0 !important
    }

    .my-lg-0 {
        margin-top: 0 !important;
        margin-bottom: 0 !important
    }

    .mb-lg-0 {
        margin-bottom: 0 !important
    }

    .mb-lg-auto {
        margin-bottom: auto !important
    }

    .ms-lg-5 {
        margin-left: 3rem !important
    }

    .pe-lg-5 {
        padding-right: 3rem !important
    }

    .pb-lg-0 {
        padding-bottom: 0 !important
    }

    .text-lg-start {
        text-align: left !important
    }
}

:root {
    --body-font-size: 1rem;
    --body-font-weight: 400;
    --body-color: #000;
    --h1-font-size: 2rem;
    --h1-font-weight: 900;
    --h2-font-size: 1.5rem;
    --h2-font-weight: 800;
    --h3-font-size: 1.25rem;
    --h3-font-weight: 600;
    --key-number-font-size: 3rem;
    --key-number-font-weight: 700;
    --card-border-radius: 0.625rem
}

section {
    position: relative
}

section.hero-main {
    min-height: 29rem
}

section.hero-main::after {
    background-image: url(ffb74b0870421d26b6cc.png);
    top: 0
}

section.antagonist-main::after {
    background-image: url(0bcc4d463dc28d04a782.png);
    bottom: 0
}

section.antagonist-tertiary::after {
    background-image: url(7e6e269001e1cbcd7336.png);
    bottom: 0
}

section::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 100%;
    width: 100%;
    background-repeat: no-repeat;
    background-position: top;
    background-size: cover;
    z-index: -1
}

html, body {
    height: 100%;
    margin: 0
}

body {
    font-family: "DM Sans", sans-serif;
    font-size: var(--body-font-size);
    font-weight: var(--body-font-weight);
    color: var(--body-color);
    font-style: normal;
    font-optical-sizing: auto;
    display: flex;
    flex-direction: column
}

main {
    flex: 1 0 auto
}

h1, .h1 {
    font-size: var(--h1-font-size);
    font-weight: var(--h1-font-weight);
    color: var(--bs-primary)
}

h1.w-70, .w-70.h1 {
    max-width: 70%
}

h2, .h2 {
    font-size: var(--h2-font-size);
    font-weight: var(--h2-font-weight);
    color: var(--bs-primary)
}

h3, .h3 {
    font-size: var(--h3-font-size);
    font-weight: var(--h3-font-weight);
    color: var(--bs-primary)
}

.card {
    border-radius: var(--card-border-radius);
    box-shadow: 1px 1px 8px 1px rgba(0, 0, 0, .15);
    transition: box-shadow .3s ease;
    overflow: hidden
}

.card:hover {
    box-shadow: 2px 2px 16px 8px rgba(0, 0, 0, .25)
}

.card .card-body {
    padding: 1.875rem
}

.card .card-body .card-text {
    line-height: 1.301875rem
}

.rounded-pill {
    border: 1px solid var(--bs-secondary);
    color: var(--bs-primary);
    background-color: unset;
    font-size: .875rem;
    font-weight: 500;
    border-radius: 4rem
}

.actualites-card .card-subtitle {
    font-size: var(--h3-font-size);
    font-weight: 700
}

.actualites-card .card-img-top {
    border-top-left-radius: var(--card-border-radius);
    border-top-right-radius: var(--card-border-radius)
}

.service-card .card-body {
    display: flex;
    flex-direction: column;
    align-items: center
}

.service-card .card-body .card-title {
    color: var(--bs-primary)
}

.service-card .card-body img {
    border: 2px solid var(--bs-primary)
}

.job-card .card-body .card-title {
    color: var(--bs-primary)
}

.service-benefits-card {
    border: 3px solid var(--bs-yellow);
    position: relative;
    width: 100%;
    padding-top: 100%
}

.service-benefits-card:hover {
    cursor: default;
    box-shadow: 1px 1px 8px 1px rgba(0, 0, 0, .15)
}

.service-benefits-card .card-body {
    display: flex;
    flex-direction: column;
    align-items: center;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0
}

.service-benefits-card .card-body .card-title {
    color: var(--bs-primary)
}

.service-benefits-card .card-body img {
    border: 2px solid var(--bs-primary)
}

.job-card:has(.card-body.text-muted):hover {
    box-shadow: none
}

.job-card .card-body.text-muted {
    background-color: var(--bs-disabled)
}

.job-card .card-body.text-muted .card-subtitle {
    margin-bottom: 5rem
}

.job-card .card-body:not(.text-muted) .card-title {
    margin-bottom: 5rem
}

.services-card {
    text-align: start
}

.services-card:hover {
    box-shadow: 1px 1px 8px 1px rgba(0, 0, 0, .15)
}

.services-card .services-grid {
    display: flex;
    flex-wrap: wrap;
    gap: .7rem
}

.number-item {
    position: relative
}

.key-number {
    font-size: var(--key-number-font-size);
    font-weight: var(--key-number-font-weight);
    color: var(--bs-primary)
}

.number-item:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    height: 100%;
    width: 3px;
    background-color: var(--bs-secondary)
}

@media (max-width: 767px) {
    .number-item::after {
        display: none
    }
}

.block-text-underlined {
    background-color: var(--bs-secondary);
    border-radius: 1.875rem;
    display: flex;
    align-items: center;
    text-align: center
}

.btn {
    box-shadow: 1px 1px 8px 1px rgba(0, 0, 0, .15);
    display: inline-flex;
    align-items: center;
    gap: .5rem
}

.btn svg {
    flex-shrink: 0
}

.btn-primary {
    border-radius: .625rem
}

.btn-primary:hover {
    background-color: var(--bs-white);
    color: var(--bs-primary);
    border-color: var(--bs-primary)
}

.btn-secondary {
    color: var(--bs-primary);
    border-radius: .3125rem
}

.btn-secondary:hover {
    background-color: var(--bs-primary);
    color: var(--bs-white);
    border-color: var(--bs-primary)
}

.btn-light {
    background-color: var(--bs-white);
    box-shadow: 1px 1px 8px 1px rgba(0, 0, 0, .15);
    border-radius: .625rem
}

.btn-light:hover {
    background-color: var(--bs-primary);
    color: var(--bs-white)
}

.btn-outline-yellow {
    color: var(--bs-primary);
    border-radius: .3125rem
}

.btn-outline-yellow:hover {
    background-color: var(--bs-yellow)
}

.form-control {
    border-radius: .9375rem
}

.form-control:focus {
    box-shadow: unset;
    border-color: var(--bs-primary)
}

form:not(.form-sso) .form-select {
    border: unset;
    border-bottom: 3px solid var(--bs-yellow);
    border-radius: unset
}

form:not(.form-sso) .form-select:focus {
    box-shadow: unset;
    border-color: var(--bs-yellow)
}

form:not(.form-sso) .form-select option {
    background-color: var(--bs-grey)
}

form:not(.form-sso) .form-select option:hover, form:not(.form-sso) .form-select option:focus, form:not(.form-sso) .form-select option:active {
    background-color: var(--bs-primary) !important
}

.rounded-image {
    border-radius: .625rem
}

.text-list ol {
    list-style: none;
    counter-reset: list-counter;
    padding-left: 0
}

.text-list {
    width: 95%;
    margin-left: auto;
    margin-right: auto
}

.text-list ol > li {
    position: relative;
    margin-left: 3.9rem;
    margin-bottom: 2.125rem
}

.text-list ol > li::before {
    content: counter(list-counter);
    counter-increment: list-counter;
    position: absolute;
    left: -4.5rem;
    background-color: var(--bs-secondary);
    color: var(--bs-primary);
    border-radius: 50%;
    width: 3.3125rem;
    height: 3.3125rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    border: 1px solid var(--bs-primary);
    box-shadow: 0 0 0 5px var(--bs-white), 0 0 0 7px var(--bs-grey)
}

.text-list ol li ul {
    list-style: none;
    padding-left: 0;
    color: #575756
}

.text-list ol li ul li {
    margin-left: 0;
    position: relative;
    padding-left: 0
}

.text-list ol li ul li::before {
    content: ""
}

.text-list strong {
    font-size: var(--h3-font-size);
    color: var(--bs-primary);
    display: block
}

.event-meta {
    border: 3px solid var(--bs-secondary);
    border-radius: 1.875rem
}

.event-meta .meta-item {
    position: relative
}

.event-meta .key-number {
    font-size: var(--key-number-font-size);
    font-weight: var(--key-number-font-weight);
    color: var(--bs-primary)
}

.event-meta .meta-item:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    height: 100%;
    width: 3px;
    background-color: var(--bs-primary)
}

@media (max-width: 1200px) {
    .event-meta .meta-item::after {
        display: none
    }
}

.map-container {
    position: relative;
    width: 100%;
    margin: 0 auto
}

.map-container .map-image {
    width: 100%;
    height: auto;
    display: block
}

.map-container .address-label {
    position: absolute;
    bottom: 0;
    left: 0;
    max-width: 300px;
    color: #fff;
    padding: 10px 15px;
    border-radius: 0 4px 0 0;
    box-shadow: 0 2px 4px rgba(0, 0, 0, .2)
}

.map-container .address-label p {
    margin: 0;
    font-size: 14px;
    line-height: 1.4;
    font-weight: bold;
    text-shadow: 1px 1px 1px rgba(0, 0, 0, .1)
}

.footer {
    background-color: var(--bs-primary);
    color: #fff
}

.footer a {
    color: #fff;
    text-decoration: none
}

.footer .logo {
    width: 200px;
    height: auto
}

.footer .item {
    position: relative
}

.footer .item:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    height: 100%;
    width: 1px;
    background-color: var(--bs-white)
}

@media (max-width: 767px) {
    .footer .item::after {
        display: none
    }
}

@media (max-width: 1366px) {
    .footer .item {
        font-size: .875rem
    }
}

.search-results li {
    list-style: none
}

.sponsor {
    width: 100px;
    height: auto
}

.navbar {
    border-bottom: 1px solid var(--bs-grey)
}

.navbar .navbar-brand img {
    width: 175px;
    height: auto
}

.navbar .nav-link {
    color: var(--bs-primary);
    font-weight: 500
}

.navbar .nav-link.dropdown-toggle::after {
    content: none
}

.navbar .nav-link.active {
    border-bottom: 2px solid var(--bs-secondary)
}

.navbar .dropdown-menu {
    min-width: 18.75rem;
    border-radius: unset;
    border: none;
    background-color: var(--bs-white);
    font-size: 1rem
}

.navbar .dropdown-menu a {
    text-decoration: none
}

.navbar .dropdown-menu li {
    margin-top: .5rem;
    background-color: var(--bs-grey);
    padding: .625rem
}

.navbar .dropdown-menu li:hover, .navbar .dropdown-menu li:focus, .navbar .dropdown-menu li:active {
    background-color: var(--bs-primary) !important;
    color: var(--bs-white)
}

.navbar .dropdown-menu li:hover a, .navbar .dropdown-menu li:focus a, .navbar .dropdown-menu li:active a {
    color: var(--bs-white) !important
}

.timeline {
    position: relative;
    padding: 0;
    list-style: none
}

.timeline::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 26%;
    width: 2px
}

@media (min-width: 576px) {
    .timeline::before {
        left: 50%
    }
}

.antagonist-main .timeline::before, .hero-main .timeline::before {
    background-color: #03045e
}

.bg-primary h1, .bg-primary .h1, .bg-primary h2, .bg-primary .h2, .bg-primary h3, .bg-primary .h3, .bg-primary p {
    color: #fff
}

.bg-primary .timeline-item {
    color: #fff
}

.bg-primary .swiper-slide p {
    color: unset
}

.bg-primary .btn-primary {
    background-color: #fff;
    color: #03045e
}

.bg-primary .card-body .btn-primary {
    background-color: #03045e;
    color: #fff
}

.bg-primary .card-body .btn-primary:hover {
    background-color: #fff;
    color: #03045e
}

.bg-primary .timeline::before {
    background-color: #fff
}

.timeline-item {
    position: relative;
    margin-bottom: 50px;
    display: flex;
    justify-content: space-between;
    align-items: center
}

.timeline-item:nth-child(even) {
    flex-direction: row-reverse
}

.timeline-dot {
    position: absolute;
    width: 50px;
    height: 50px;
    line-height: 50px;
    border-radius: 50%;
    text-align: center;
    background-color: #fff;
    color: navy;
    font-weight: bold;
    left: 26%;
    margin-left: -25px;
    z-index: 1;
    box-shadow: 0 0 0 5px var(--bs-primary), 0 0 0 7px var(--bs-yellow)
}

@media (min-width: 576px) {
    .timeline-dot {
        left: 50%
    }
}

.timeline-content {
    width: 45%;
    padding: 1.25rem
}

@media (max-width: 576px) {
    .timeline-content {
        flex-grow: .55
    }
}

.timeline-date {
    width: fit-content;
    text-align: right;
    padding: 1.25rem;
    font-weight: bold;
    font-size: 1.2em
}

@media (min-width: 576px) {
    .timeline-date {
        width: 45%
    }
}

.timeline-item:nth-child(even) {
    flex-direction: row-reverse
}

.timeline-item:nth-child(even) .timeline-date {
    text-align: left
}

@media (max-width: 576px) {
    .timeline-item:nth-child(even) {
        flex-direction: row
    }

    .timeline-item:nth-child(even) .timeline-date {
        text-align: right
    }
}

.swiper {
    border-radius: 1.875rem;
    box-shadow: 1px 1px 8px 1px rgba(0, 0, 0, .15);
    transition: box-shadow .3s ease;
    background-color: var(--bs-white)
}

.swiper .swiper-slide {
    display: flex !important;
    justify-content: center
}

.swiper .swiper-slide .swiper-content {
    width: 90%;
    padding: 3.125rem
}

@media (max-width: 768px) {
    .swiper .swiper-slide .swiper-content {
        padding: 2rem 2rem 1rem 2rem
    }
}

.swiper .swiper-button-prev:after, .swiper .swiper-button-next:after {
    color: var(--bs-primary)
}

@media (max-width: 768px) {
    .swiper .swiper-button-prev, .swiper .swiper-button-next {
        position: static;
        margin-bottom: 1rem
    }
}

.card-padding-fix .card-body {
    padding: 1rem
}

.card {
    height: auto !important
}

.card .stretched-link {
    text-decoration: none
}

.card .stretched-link:hover, .card .stretched-link:focus, .card .stretched-link:visited {
    color: #03045e
}

.card-id {
    height: 100% !important
}

@media (max-width: 991.98px) {
    .border-md-none {
        border: none !important
    }
}

.form-sso {
    border-radius: var(--card-border-radius);
    border: 1px solid var(--bs-grey)
}

 .disabled p a:after {
    background: rgba(204, 204, 204, 0.5);;
}

.text-small {
    font-size: 0.8rem;

}
.text-small a {
    text-decoration: none;
}

/**
******************************************************
* Surcharge jbi
******************************************************
*/
.disabled p a {
    cursor: not-allowed;
}

.text-light {
    font-weight: normal;
}

.alert-warning {
    --bs-alert-color: var(--bs-warning-text-emphasis);
    --bs-alert-bg: var(--bs-warning-bg-subtle);
    --bs-alert-border-color: var(--bs-warning-bg-subtle);
    --bs-alert-link-color: var(--bs-warning-text-emphasis)
}

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

.oidc form.disabled {
    filter: grayscale(100%);
    -webkit-filter: grayscale(100%);
    background-color: white;
    opacity: 0.4;
}

.shadow-none {
    box-shadow: none;
}

/**
******************************************************
* Surcharge cas.css
******************************************************
*/
main:has(.d-flex > section:only-of-type) {
    max-width: none;
}