.public-breadcrumb {
    font-size: .98rem;
    line-height: 1.2;
    color: #1f2937;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    background-color: #ffffff;
    border-radius: 0;
    border-bottom: 1px solid #e9eef5;
    padding: .72rem 1rem;
}
.public-breadcrumb-trail {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .1rem;
    min-width: 0;
}
.public-breadcrumb a {
    color: #1e7fe6 !important;
    text-decoration: none;
    font-weight: normal;
}
.public-breadcrumb a:hover {
    color: #1568c6 !important;
    text-decoration: underline;
}
.public-breadcrumb-sep {
    color: #111827;
    margin: 0 .35rem;
    font-weight: normal;
}
.public-breadcrumb-current {
    color: #111827;
    font-weight: 700;
    white-space: nowrap;
}
.public-breadcrumb-return {
    color: #1e7fe6 !important;
    font-weight: normal;
    text-decoration: none;
    white-space: nowrap;
}
.public-breadcrumb-return:hover {
    text-decoration: underline;
}
main .container > .container-fluid {
    margin-top: 1rem !important;
}
@media (min-width: 992px) {
    .public-flow-shell {
        align-items: stretch;
    }
    .public-flow-shell > .public-flow-hero-col,
    .public-flow-shell > .public-hero-card {
        align-self: stretch !important;
    }
}
@media (max-width: 991.98px) {
    ol.jc-parcours-timeline {
        display: none !important;
    }
    .public-breadcrumb > .flex-grow-1:has(.jc-parcours-timeline) {
        display: none !important;
    }
    .mb-4:has(.jc-parcours-timeline) {
        display: none !important;
    }
    .public-breadcrumb:not(:has(.public-breadcrumb-trail)) {
        flex-direction: row;
        justify-content: flex-end;
        align-items: center;
        gap: .5rem;
    }
    .public-breadcrumb:not(:has(.public-breadcrumb-trail)) .public-breadcrumb-return {
        align-self: auto;
    }
    .public-breadcrumb:has(.public-breadcrumb-trail) {
        flex-direction: column;
        align-items: stretch;
        gap: .5rem;
    }
    .public-breadcrumb:has(.public-breadcrumb-trail) > .flex-grow-1 {
        width: 100%;
        max-width: 100%;
        padding-right: 0 !important;
    }
    .public-breadcrumb:has(.public-breadcrumb-trail) .public-breadcrumb-return {
        align-self: flex-end;
    }
    .public-breadcrumb > .flex-grow-1 {
        width: 100%;
        max-width: 100%;
        padding-right: 0 !important;
    }
    .public-flow-shell {
        min-height: 0;
    }
}
.public-flow-hero-col,
.public-hero-card {
    --public-hero-color: #173a64;
    --public-hero-image-opacity: 0.3;
    position: relative;
    background-color: var(--public-hero-color);
}
.public-flow-hero-col::before,
.public-hero-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: url('/_public/Images/background_hero_neutre.png');
    background-size: cover;
    background-position: right center;
    background-repeat: no-repeat;
    opacity: var(--public-hero-image-opacity);
    pointer-events: none;
    border-radius: inherit;
    z-index: 0;
}
.public-flow-hero-col > *,
.public-hero-card > * {
    position: relative;
    z-index: 1;
}
.public-flow-hero-col {
    border-radius: 1rem;
    overflow: hidden;
}
.public-flow-hero-col,
.public-hero-card,
.public-flow-hero-wrap,
.public-hero-content-wrap {
    color: #fff;
}
.public-flow-hero-col :is(h1, h2, h3, h4, h5, h6, p, li, ol, ul, small, .small),
.public-hero-card :is(h1, h2, h3, h4, h5, h6, p, li, ol, ul, small, .small),
.public-flow-hero-wrap :is(h1, h2, h3, h4, h5, h6, p, li, ol, ul, small, .small),
.public-hero-content-wrap :is(h1, h2, h3, h4, h5, h6, p, li, ol, ul, small, .small) {
    color: #fff !important;
}
.public-flow-hero-col .text-white-50,
.public-hero-card .text-white-50,
.public-flow-hero-wrap .text-white-50,
.public-hero-content-wrap .text-white-50 {
    color: #fff !important;
}
.public-flow-hero-wrap .public-flow-checklist-item,
.public-flow-hero-wrap .public-flow-checklist-item.active,
.public-flow-hero-wrap .public-flow-checklist-item.done {
    color: #fff !important;
}
.public-flow-hero-wrap {
    color: #fff;
    padding: 20px;
}
@media (max-width: 991.98px) {
    .public-flow-hero-wrap {
        padding: 14px 16px 18px;
    }
}
.public-flow-hero-return {
    color: rgba(255, 255, 255, .85);
    border-color: rgba(255, 255, 255, .45);
}
.public-flow-hero-return:hover {
    color: #fff;
    background-color: rgba(255, 255, 255, .08);
    border-color: rgba(255, 255, 255, .65);
}
.public-flow-hero-badge {
    background-color: rgba(105, 203, 238, 0.2);
    color: #69cbee;
}
.public-flow-checklist-item {
    color: rgba(255, 255, 255, .55);
    margin-bottom: .5rem;
    display: flex;
    align-items: center;
    gap: .55rem;
}
.public-flow-checklist-item.active {
    color: #fff;
    font-weight: 600;
}
.public-flow-checklist-item.done {
    color: #8ee7b8;
}
.public-flow-main-col {
    background: #f8f9fa;
}
.public-flow-main-col-inner {
    width: 100%;
    padding: 14px 16px 18px;
}
@media (min-width: 992px) {
    .public-flow-main-col-inner {
        padding: 20px;
    }
}
@media (min-width: 1200px) {
    .public-flow-main-col-inner {
        padding: 20px 3rem 3rem;
    }
}
.public-flow-check-index {
    width: 1.25rem;
    height: 1.25rem;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .72rem;
    font-weight: 700;
    background: rgba(255, 255, 255, .18);
    color: rgba(255, 255, 255, .85);
    flex: 0 0 1.25rem;
}
.public-flow-checklist-item.active .public-flow-check-index {
    background: #fff;
    color: #0d6efd;
}
.public-flow-checklist-item.done .public-flow-check-index {
    background: #8ee7b8;
    color: #0f5132;
}
.public-flow-maxw {
    max-width: 580px;
}
.public-flow-step {
    display: none;
}
.public-flow-step.active {
    display: block;
}
.public-flow-option-card {
    border: 1px solid #cfe2ff;
    border-radius: .85rem;
    background: #fff;
    padding: .85rem 1rem;
    cursor: pointer;
    width: 100%;
    text-align: left;
}
.public-flow-option-card.active {
    border-color: #0d6efd;
    box-shadow: 0 0 0 .15rem rgba(13, 110, 253, .12);
}
.public-flow-duration-pill.active {
    background-color: #0d6efd;
    border-color: #0d6efd;
    color: #fff;
}
.public-flow-duration-pill.priority {
    border-color: #8bb9ea;
    color: #2f5f98;
    font-weight: 600;
}
/* Ligne de sélection type carte (parcours public : type de stage, secteur, service civil) */
.public-flow-pick-card {
    --pick-bd: #cfe2ff;
    --pick-bd-on: #8bb9ea;
    --pick-sh: rgba(139, 185, 234, .2);
    --pick-ic: #5f8fcb;
    --pick-ti: #133d72;
    --pick-sub: #7ca8d7;
    border: 2px solid var(--pick-bd);
    border-radius: 1.2rem;
    background: #fff;
    cursor: pointer;
    width: 100%;
    text-align: left;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.public-flow-pick-card.public-flow-pick-card--padded {
    padding: 1.1rem 1.2rem;
}
.public-flow-pick-card.public-flow-pick-card--padded-slim {
    padding: .95rem 1.2rem;
}
.public-flow-pick-main {
    display: flex;
    align-items: center;
    gap: .9rem;
    min-width: 0;
}
.public-flow-pick-icon {
    font-size: 1.3rem;
    width: 2.2rem;
    text-align: center;
    color: var(--pick-ic);
    flex-shrink: 0;
}
.public-flow-pick-icon.public-flow-pick-icon--lg {
    font-size: 1.5rem;
}
.public-flow-pick-title {
    font-weight: 700;
    font-size: 1.05rem;
    color: var(--pick-ti);
    line-height: 1.2;
}
.public-flow-pick-sub {
    color: var(--pick-sub);
    font-size: .95rem;
    line-height: 1.2;
    margin-top: .15rem;
}
.public-flow-pick-radio {
    width: 2.1rem;
    height: 2.1rem;
    border-radius: 50%;
    border: 2px solid var(--pick-bd);
    background: #fff;
    flex: 0 0 2.1rem;
}
.public-flow-pick-card.active {
    border-color: var(--pick-bd-on);
    box-shadow: 0 0 0 .2rem var(--pick-sh);
}
.public-flow-pick-card.active .public-flow-pick-radio {
    border-color: var(--pick-bd-on);
    background: radial-gradient(circle, var(--pick-bd-on) 0 45%, #fff 46% 100%);
}
.public-flow-footer {
    border-top: 1px solid #e9ecef;
    padding-top: 1rem;
    margin-top: 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
}
.public-flow-footer-right {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: .6rem;
}
@media (max-width: 991.98px) {
    .public-flow-footer.public-flow-footer--mobile-sticky {
        position: sticky;
        bottom: 0;
        z-index: 1050;
        margin-top: 0;
        padding: .75rem .25rem calc(.75rem + env(safe-area-inset-bottom));
        background: #f8f9fa;
        border-top: 1px solid #dfe5ee;
        box-shadow: 0 -6px 18px rgba(17, 24, 39, .08);
    }
    .public-flow-main-col {
        padding-bottom: .5rem;
    }
}
.public-flow-step-pill {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .2rem .62rem;
    border-radius: 999px;
    background-color: #edf6ff;
    color: #2d8ce8;
    font-size: .92rem;
    font-weight: 600;
    line-height: 1;
}
.public-flow-step-pill::before {
    content: "•";
    font-size: 1rem;
    line-height: 1;
}
.public-hero-content-wrap {
    padding: 20px;
}
.public-hero-logo-wrap {
    width: 45%;
    min-width: 45%;
    max-width: 100%;
}
.public-hero-logo-wrap a,
.public-hero-logo-wrap img {
    display: block;
    width: 100%;
}
.public-hero-logo-wrap img {
    height: auto !important;
    max-width: 100%;
}
.public-hero-step-badge {
    white-space: nowrap;
}
@media (max-width: 991.98px) {
    .public-hero-step-badge {
        font-size: .72rem;
        padding: .3rem .55rem;
    }
}
/* Timeline de parcours candidat (UserControl ParcoursTimeline) */
.jc-parcours-timeline {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    width: 100%;
    border-left: 2px solid #d4dbe5;
    padding-left: 1rem;
    margin-left: .45rem;
}
.jc-parcours-timeline-item {
    flex: 0 0 auto;
    position: relative;
    padding-bottom: .65rem;
    min-width: 0;
}
.jc-parcours-timeline-item:last-child {
    padding-bottom: 0;
}
.jc-parcours-timeline-item + .jc-parcours-timeline-item::before {
    display: none;
    content: none;
}
.jc-parcours-timeline-node {
    border: 1px solid #d8dee8;
    border-radius: .5rem;
    padding: .5rem .65rem;
    background: #fff;
    display: flex;
    align-items: center;
    gap: .45rem;
}
.jc-parcours-timeline-index {
    width: 1.3rem;
    height: 1.3rem;
    border-radius: 50%;
    border: 1px solid #c5cfdb;
    font-size: .75rem;
    line-height: 1.2rem;
    text-align: center;
    flex: 0 0 1.3rem;
    background: #f7f9fc;
    color: #6c7a8b;
    font-weight: 600;
}
.jc-parcours-timeline-label {
    font-size: .85rem;
    line-height: 1.25;
    color: #5d6c7f;
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
}
.jc-parcours-timeline-node.is-done {
    background: #eef8f2;
    border-color: #a8d5ba;
}
.jc-parcours-timeline-node.is-done .jc-parcours-timeline-index {
    background: #2f8f56;
    border-color: #2f8f56;
    color: #fff;
}
.jc-parcours-timeline-node.is-done .jc-parcours-timeline-label {
    color: #2d6f49;
}
.jc-parcours-timeline-node.is-current {
    background: #edf4ff;
    border-color: #8fb6ef;
}
.jc-parcours-timeline-node.is-current .jc-parcours-timeline-index {
    background: #2f6fcb;
    border-color: #2f6fcb;
    color: #fff;
}
.jc-parcours-timeline-node.is-current .jc-parcours-timeline-label {
    color: #224f91;
    font-weight: 600;
}
@media (min-width: 992px) {
    .jc-parcours-timeline {
        flex-direction: row;
        align-items: center;
        flex-wrap: nowrap;
        gap: .45rem;
        border-left: none;
        padding-left: 0;
        margin-left: 0;
    }
    .jc-parcours-timeline-item {
        display: flex;
        flex: 1 1 0;
        align-items: center;
        padding-bottom: 0;
    }
    .jc-parcours-timeline-item + .jc-parcours-timeline-item::before {
        display: block;
        content: "";
        width: 1.2rem;
        height: 1px;
        background: #d4dbe5;
        margin-right: .45rem;
        flex: 0 0 auto;
    }
    .jc-parcours-timeline-label {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
}
.public-flow-hero-steps-mobile {
    margin-top: .25rem;
}
.public-flow-hero-steps-mobile summary {
    cursor: pointer;
    color: rgba(255, 255, 255, .78);
    font-size: .9rem;
    user-select: none;
    list-style-position: outside;
}
.public-flow-hero-steps-mobile summary:hover {
    color: #fff;
}
.public-flow-hero-steps-mobile > ol {
    margin-top: .5rem;
    margin-bottom: 0;
}
@media (min-width: 992px) {
    .stage-hero-checklist-details > summary {
        display: none;
    }
    .stage-hero-checklist-details > ol {
        margin-top: 0;
    }
}
@media (max-width: 991.98px) {
    .public-page-connexion .public-flow-hero-wrap {
        padding: 10px 12px 14px !important;
    }
    .public-page-connexion .public-flow-hero-wrap .public-flow-checklist-item {
        margin-bottom: 0.35rem;
    }
    .public-page-connexion .public-flow-hero-wrap h1.h2 {
        font-size: 1.25rem;
        line-height: 1.3;
    }
    .public-page-connexion .public-flow-main-col .public-breadcrumb {
        padding: 0.45rem 0.75rem;
    }
    .public-page-connexion .card-body h1.h4,
    .public-page-connexion .card-body h2.h4 {
        font-size: 1.15rem;
    }
}

/* FAQ publique (_public/faq.aspx) */
.public-faq .public-faq-footer-link {
    color: #1e7fe6;
    text-decoration: none;
    font-weight: 500;
}
.public-faq .public-faq-footer-link:hover {
    color: #1568c6;
    text-decoration: underline;
}
.public-faq-sommaire-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.public-faq-sommaire-scroll .btn {
    border-color: #c5cfdb;
}
.public-faq-backtop {
    position: fixed;
    right: 1rem;
    bottom: 1rem;
    z-index: 1030;
    box-shadow: 0 2px 8px rgba(23, 58, 100, 0.12);
}
.public-faq .faq-accordion .accordion-header .accordion-button {
    font-weight: 600;
}
.public-faq .faq-answer {
    text-wrap: pretty;
    font-weight: 400;
    color: #5a6570;
    line-height: 1.55;
}
.public-faq .faq-answer p {
    margin-bottom: 0.65rem;
}
.public-faq .faq-answer p:last-child {
    margin-bottom: 0;
}
.public-faq .faq-answer ul,
.public-faq .faq-answer ol {
    margin-bottom: 0.65rem;
    padding-left: 1.25rem;
}
.public-faq .faq-answer li {
    margin-bottom: 0.35rem;
}
.public-faq .faq-answer a {
    word-break: break-word;
    color: #1e7fe6;
    font-weight: 500;
}
.public-faq .faq-answer a:hover {
    color: #1568c6;
}
.public-faq .faq-answer h1,
.public-faq .faq-answer h2,
.public-faq .faq-answer h3,
.public-faq .faq-answer h4,
.public-faq .faq-answer h5,
.public-faq .faq-answer h6 {
    font-size: 1rem;
    margin-top: 0.75rem;
    margin-bottom: 0.5rem;
}
