/* =========================================================
   TOKENS / VARIABLES
========================================================= */

:root {
    --mdcf-radius-sm: 0;
    --mdcf-radius-md: 0;
    --mdcf-radius-lg: 0;
    --mdcf-radius-pill: 0;

    --mdcf-space-xs: 8px;
    --mdcf-space-sm: 12px;
    --mdcf-space-md: 16px;
    --mdcf-space-lg: 20px;
    --mdcf-space-xl: 24px;
    --mdcf-space-2xl: 32px;
    --mdcf-space-3xl: 40px;
    --mdcf-space-4xl: 48px;
    --mdcf-space-5xl: 56px;

    /* Couleurs basées sur Astra */
    --mdcf-color-white: #fff;
    --mdcf-color-bg-soft: var(--ast-global-color-5);
    --mdcf-color-badge: var(--ast-global-color-4);
    --mdcf-color-border: var(--ast-border-color);
    --mdcf-color-border-soft: color-mix(in srgb, var(--ast-border-color) 55%, transparent);
    --mdcf-color-border-hover: var(--ast-global-color-0);
    --mdcf-color-text-muted: var(--ast-global-color-3);
    --mdcf-color-pagination: var(--ast-global-color-0);
    --mdcf-color-button-border: var(--ast-border-color);
    --mdcf-color-pagination-border: var(--ast-border-color);
    --mdcf-color-icon-bg: color-mix(in srgb, var(--ast-global-color-0) 10%, transparent);
    --mdcf-color-action-icon: #213745;
    --mdcf-color-action-icon-hover: #168178;
    --mdcf-color-accent: #168178;

    --mdcf-shadow-card: 0 10px 28px rgba(0, 0, 0, 0.08);
    --mdcf-shadow-card-soft: 0 10px 30px rgba(15, 23, 42, 0.05);
    --mdcf-shadow-card-hover: 0 16px 34px rgba(0, 0, 0, 0.12);
    --mdcf-shadow-card-hover-soft: 0 18px 38px rgba(15, 23, 42, 0.10);
    --mdcf-shadow-card-lift: 0 12px 30px rgba(0, 0, 0, 0.08);

    --mdcf-transition-fast: 0.2s ease;

    --mdcf-sidebar-width: 380px;
    --mdcf-content-narrow: 420px;
    --mdcf-content-medium: 320px;
    --mdcf-card-min-height-domain: 220px;
    --mdcf-image-height-cover: 420px;
    --mdcf-image-height-card: 220px;
    --mdcf-image-shadow: none;

}

/* =========================================================
   LIENS GLOBAUX
========================================================= */

a:hover,
a:focus-visible,
a:active {
    color: var(--mdcf-color-accent);
}

/* Override Astra : button:focus { color: #ffffff } */
button:focus {
    color: var(--mdcf-color-action-icon);
}

/* =========================================================
   BASE / LAYOUT GLOBAL
========================================================= */

.mdcf-homepage {
    width: 100%;
}

.mdcf-homepage > .mdcf-hero-search {
    width: 100%;
    max-width: none;
}

.mdcf-article {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.ast-separate-container .mdcf-homepage,
.ast-page-builder-template .mdcf-homepage,
.site-content .mdcf-homepage {
    padding-top: 0;
    padding-left: 0;
    padding-right: 0;
}

.ast-container {
    display: flex;
}
.ast-container,
.mdcf-single-formation__layout,
.mdcf-single-formation__sidebar {
    overflow: visible;
    gap: var(--mdcf-space-lg);
}

@media (min-width: 1024px) {
    .ast-container {
        display: flex;
        flex-direction: column;
        /*padding-left: 0;*/
        /*padding-right: 0;*/
    }
}

/* =========================================================
   RESET BORDER-RADIUS — override Astra (spécificité input[type=x] > .classe)
========================================================= */

input[type=email],
input[type=number],
input[type=password],
input[type=reset],
input[type=search],
input[type=tel],
input[type=text],
input[type=url],
input[type=button],
input[type=submit],
select,
textarea,
button,
.button,
.ast-button,
#ast-scroll-top {
    border-radius: 0 !important;
}

/* =========================================================
   UTILITAIRES
========================================================= */

.mdcf-section {
    margin-top: var(--mdcf-space-3xl);
    border-left: 3px solid var(--ast-global-color-5);
    padding-left: var(--mdcf-space-lg);
}

.mdcf-section--no-border {
    border-left: none;
    padding-left: 0;
}

.mdcf-section-block + .mdcf-section-block {
    margin-top: var(--mdcf-space-xl);
}

.single-formation .mdcf-section:not(.mdcf-section--no-border) h2,
.single-prestation .mdcf-section:not(.mdcf-section--no-border) h2,
.single-webinaire .mdcf-section:not(.mdcf-section--no-border) h2 {
    position: relative;
}

.single-formation .mdcf-section:not(.mdcf-section--no-border) h2::before,
.single-prestation .mdcf-section:not(.mdcf-section--no-border) h2::before,
.single-webinaire .mdcf-section:not(.mdcf-section--no-border) h2::before {
    content: '';
    position: absolute;
    left: calc(-1 * var(--mdcf-space-lg) - 1.5px);
    top: 50%;
    transform: translate(-50%, -30%);
    height: 0.975em;
    aspect-ratio: 62.56 / 72.24;
    background: url('../img/icon-triangle.svg') center / contain no-repeat;
}

.mdcf-badge {
    display: inline-block;
    margin: 0 var(--mdcf-space-xs) var(--mdcf-space-xs) 0;
    padding: 6px 10px;
    border-radius: var(--mdcf-radius-pill);
    background: var(--mdcf-color-badge);
    color: var(--ast-global-color-2);
    font-size: 14px;
}

.mdcf-domain-hero,
.mdcf-formation-hero {
    margin-bottom: var(--mdcf-space-2xl);
}

.mdcf-button--download {
    display: inline-block;
    padding: 14px 22px;
    border-radius: var(--mdcf-radius-sm);
    text-decoration: none;
}

/* =========================================================
   MÉDIAS GÉNÉRIQUES
========================================================= */

.mdcf-domain-card__media img,
.mdcf-formation-card__media img,
.mdcf-domain-hero__media img,
.mdcf-related-card__media img,
.mdcf-catalogue-card__media img,
.mdcf-catalogue-single__image,
.mdcf-ressource-card__media img,
.mdcf-ressource-single__image,
.mdcf-single-cover img {
    display: block;
    width: 100%;
    height: auto;
}

.mdcf-formation-hero__image img {
    display: block;
    width: 100%;
    height: auto;
    max-height: 400px;
    object-fit: cover;
}

.mdcf-formation-hero__description {
    margin-top: var(--mdcf-space-xl);
}

/* =========================================================
   GRILLES GLOBALES
========================================================= */

.mdcf-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--mdcf-space-lg);
    align-items: stretch;
    justify-items: stretch;
}

.mdcf-domain-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--mdcf-space-lg);
    align-items: stretch;
}

.mdcf-reglementation-grid,
.mdcf-catalogues-grid,
.mdcf-ressources-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.mdcf-reglementation-grid {
    gap: var(--mdcf-space-xl);
    margin-top: var(--mdcf-space-3xl);
}

.mdcf-catalogues-grid,
.mdcf-ressources-grid {
    gap: var(--mdcf-space-2xl);
}

.mdcf-domaine-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 50px;
}

/* =========================================================
   RESPONSIVE GLOBAL
========================================================= */

@media (max-width: 1024px) {
    .mdcf-domain-grid,
    .mdcf-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 18px;
    }
}

@media (max-width: 767px) {
    .mdcf-domain-grid,
    .mdcf-grid {
        grid-template-columns: 1fr;
        gap: var(--mdcf-space-md);
    }
}

@media (max-width: 544px) {
    .mdcf-catalogues-grid,
    .mdcf-ressources-grid {
        grid-template-columns: 1fr;
    }
}

/* =========================================================
   PAGE HUB DOMAINES DE FORMATION — contenu éditeur isolé
========================================================= */
.mdcf-page-domaines .mdcf-page-intro {
    margin-top: var(--mdcf-space-2xl);
}

/* TOC en float : surcharge le grid du plugin pour cette page uniquement */
.mdcf-page-domaines .mdcf-edito-layout {
    display: block;
}

.mdcf-page-domaines .mdcf-edito-toc {
    float: right;
    width: calc((100% - 2 * var(--mdcf-space-lg)) / 3);
    margin-left: var(--mdcf-space-lg);
    margin-bottom: var(--mdcf-space-lg);
    position: sticky;
    top: var(--mdcf-toc-top-offset, 165px);
}

.mdcf-page-domaines .mdcf-edito-content {
    overflow: hidden; /* BFC — empêche le contenu de passer sous le float */
}

/* Neutralise les alignements Gutenberg dans ce contexte */
.mdcf-page-domaines .mdcf-page-intro .alignfull,
.mdcf-page-domaines .mdcf-page-intro .alignwide {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

@media (max-width: 921px) {
    .mdcf-page-domaines .mdcf-edito-toc {
        float: none;
        width: 100%;
        margin-left: 0;
        position: static;
    }
}
