/* ============================================================
   SINGLE-SCENARIO — prefix .fr-scn-* isolé pour éviter les
   collisions avec d'autres templates / plugins.
   Palette teal (#4a7fa0) déclinée du hero parent /scenarios/.
============================================================ */
:root {
    --fr-scn-bg:        #f6f8fa;
    --fr-scn-card:      #ffffff;
    --fr-scn-ink:       #0f172a;
    --fr-scn-ink-2:     #475569;
    --fr-scn-ink-3:     #94a3b8;
    --fr-scn-line:      #e5e7eb;
    --fr-scn-accent:    #4a7fa0;
    --fr-scn-accent-d:  #1f3d52;
    --fr-scn-hero-1:    #ecf2f7;
    --fr-scn-hero-2:    #dde7ee;
}

.fr-scn {
    background: var(--fr-scn-bg);
    color: var(--fr-scn-ink);
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    /* 110px en haut = hauteur de la nav fixe (aligné sur single-formation) */
    padding: 110px 0 clamp(3rem, 6vw, 5rem);
    min-height: 100vh;
}
/* Si le thème pose un padding par défaut sur le wrapper main */
.site-main:has(> .fr-scn),
.site-content:has(> .fr-scn) {
    background: var(--fr-scn-bg);
    padding-top: 0;
}

.fr-scn-container {
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 clamp(1rem, 3vw, 2.5rem);
}

/* ===== Hero ============================================== */
.fr-scn-hero {
    padding: clamp(1rem, 2vw, 1.5rem) 0 clamp(2rem, 4vw, 3rem);
}
.fr-scn-hero .fr-scn-container {
    /* Hero un cran plus large que le contenu (DS unifié single-formation) */
    max-width: 1400px;
}
.fr-scn-hero-card {
    background: linear-gradient(120deg, var(--fr-scn-hero-1) 0%, var(--fr-scn-hero-2) 100%);
    border-radius: 24px;
    padding: 2rem 2.5rem;
    overflow: hidden;
    position: relative;
}
.fr-scn-hero-content {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 2rem;
    align-items: stretch;
}
.fr-scn-hero-text {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.875rem;
}
.fr-scn-hero-side {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-end;
    gap: 1rem;
}

.fr-scn-crumbs {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    margin-bottom: 1.25rem;
    font-size: 0.8125rem;
    color: var(--fr-scn-ink-2);
    line-height: 1.2;
}
.fr-scn-crumbs a {
    color: var(--fr-scn-ink-2);
    text-decoration: none;
    transition: color 160ms ease;
}
.fr-scn-crumbs a:hover { color: var(--fr-scn-ink); }
.fr-scn-crumbs span[aria-hidden] { color: var(--fr-scn-ink-3); }
.fr-scn-crumbs [aria-current] {
    color: var(--fr-scn-ink);
    font-weight: 600;
}

.fr-scn-hero-titlerow {
    display: flex;
    align-items: center;
    gap: 1rem;
}
.fr-scn-hero-sign {
    flex-shrink: 0;
    width: 56px;
    height: auto;
    display: block;
}
.fr-scn-hero-title {
    margin: 0;
    font-family: 'DM Sans', 'Inter', sans-serif;
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.02em;
    color: var(--fr-scn-ink);
}
.fr-scn-hero-titlerow + .fr-scn-hero-lead { margin-top: 0.625rem; }
.fr-scn-hero-lead {
    margin: 0;
    font-size: 0.9375rem;
    color: var(--fr-scn-ink-2);
    line-height: 1.5;
    display: flex;
    flex-wrap: wrap;
    gap: 1.25rem;
}
.fr-scn-meta-item {
    display: inline-flex;
    align-items: center;
    gap: 0.4375rem;
}
.fr-scn-meta-item i { color: var(--fr-scn-accent); font-size: 0.8125rem; }
.fr-scn-meta-item a {
    color: inherit;
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color 160ms ease;
}
.fr-scn-meta-item a:hover { border-bottom-color: var(--fr-scn-accent); }

.fr-scn-hero-tags {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.375rem;
}
.fr-scn-hero-pill {
    display: inline-flex;
    align-self: flex-start;
    padding: 0.25rem 0.75rem;
    background: var(--fr-scn-accent);
    color: #fff;
    border-radius: 999px;
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-decoration: none;
    transition: box-shadow 200ms ease, color 200ms ease;
}
.fr-scn-hero-pill--link:hover {
    color: #fff;
    box-shadow: 0 0 0 3px rgba(74, 127, 160, 0.18);
}

.fr-scn-hero-cta {
    display: inline-flex;
    align-items: center;
    gap: 0.625rem;
    padding: 0.625rem 1rem 0.625rem 1.25rem;
    background: transparent;
    color: var(--fr-scn-ink);
    text-decoration: none;
    font-weight: 600;
    font-size: 0.9375rem;
    border: 0;
    border-bottom: 2px solid var(--fr-scn-ink);
    align-self: flex-end;
    cursor: pointer;
    transition: color 160ms ease, border-color 160ms ease, gap 160ms ease;
}
.fr-scn-hero-cta svg {
    width: 18px;
    height: auto;
    transition: transform 160ms ease;
}
.fr-scn-hero-cta:hover {
    color: var(--fr-scn-accent);
    border-bottom-color: var(--fr-scn-accent);
    gap: 0.875rem;
}
.fr-scn-hero-cta:hover svg { transform: translateX(2px); }

@media (max-width: 720px) {
    .fr-scn-hero-content { grid-template-columns: 1fr; }
    .fr-scn-hero-side { align-items: flex-start; gap: 0.875rem; }
    .fr-scn-hero-cta { align-self: flex-start; }
    .fr-scn-hero-sign { width: 44px; }
    .fr-scn-hero-titlerow { gap: 0.75rem; }
}

/* ===== Eyebrow / callouts ================================ */
.fr-scn-eyebrow {
    display: inline-block;
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--fr-scn-accent);
    margin-bottom: 0.5rem;
}

/* ===== Notice (consignes) ================================ */
.fr-scn-notice {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1.25rem;
    background: var(--fr-scn-card);
    border: 1px solid var(--fr-scn-line);
    border-left: 4px solid var(--fr-scn-accent);
    border-radius: 18px;
    padding: 1.5rem 1.75rem;
    margin-bottom: clamp(1.5rem, 3vw, 2.25rem);
}
.fr-scn-notice-icon {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: rgba(74, 127, 160, 0.10);
    color: var(--fr-scn-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.125rem;
}
.fr-scn-notice-body { min-width: 0; }
.fr-scn-notice-title {
    margin: 0 0 0.5rem;
    font-family: 'DM Sans', 'Inter', sans-serif;
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--fr-scn-ink);
}

/* ===== Visualiseur ======================================= */
.fr-scn-viewer {
    margin-bottom: clamp(2rem, 4vw, 3rem);
}
.fr-scn-viewer-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 1rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}
.fr-scn-viewer-title {
    margin: 0;
    font-family: 'DM Sans', 'Inter', sans-serif;
    font-size: clamp(1.25rem, 2vw, 1.5rem);
    font-weight: 700;
    color: var(--fr-scn-ink);
    letter-spacing: -0.01em;
}
.fr-scn-viewer-controls {
    display: inline-flex;
    gap: 0.5rem;
}
.fr-scn-icon-btn {
    width: 40px;
    height: 40px;
    border-radius: 12px;
    background: var(--fr-scn-card);
    border: 1px solid var(--fr-scn-line);
    color: var(--fr-scn-ink-2);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: color 160ms ease, border-color 160ms ease, background 160ms ease;
}
.fr-scn-icon-btn:hover {
    color: var(--fr-scn-accent);
    border-color: var(--fr-scn-accent);
    background: rgba(74, 127, 160, 0.06);
}
.fr-scn-viewer-frame {
    background: var(--fr-scn-card);
    border: 1px solid var(--fr-scn-line);
    border-radius: 22px;
    padding: 0.5rem;
    overflow: hidden;
}
.fr-scn-canvas {
    position: relative;
    width: 100%;
    border-radius: 16px;
    overflow: hidden;
    background: #0f172a;
}
.fr-scn-canvas .scenario-background-img {
    display: block;
    width: 100%;
    height: auto;
}
.fr-scn-canvas .scenario-element {
    pointer-events: none;
}

/* Fullscreen — branchement existant via .scenario-viewer.fullscreen
   On supporte aussi notre nouvelle classe pour ne pas casser le JS. */
.fr-scn-viewer.fullscreen,
.scenario-viewer.fullscreen {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: #000;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.fr-scn-viewer.fullscreen .fr-scn-viewer-frame {
    width: 100vw;
    height: 100vh;
    border-radius: 0;
    background: #000;
    border: 0;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.fr-scn-viewer.fullscreen .fr-scn-canvas {
    max-width: 100%;
    max-height: 100%;
    border-radius: 0;
}
.fr-scn-viewer.fullscreen .fr-scn-viewer-head { display: none; }

/* ===== Section générique (description) =================== */
.fr-scn-section {
    background: var(--fr-scn-card);
    border: 1px solid var(--fr-scn-line);
    border-radius: 22px;
    padding: clamp(1.5rem, 3vw, 2.25rem);
    margin-bottom: clamp(1.5rem, 3vw, 2.25rem);
}
.fr-scn-section-head { margin-bottom: 1.25rem; }
.fr-scn-section-title {
    margin: 0;
    font-family: 'DM Sans', 'Inter', sans-serif;
    font-size: clamp(1.25rem, 2vw, 1.5rem);
    font-weight: 700;
    letter-spacing: -0.01em;
    color: var(--fr-scn-ink);
}
.fr-scn-prose {
    color: var(--fr-scn-ink-2);
    font-size: 0.9375rem;
    line-height: 1.65;
}
.fr-scn-prose > * + * { margin-top: 0.875rem; }
.fr-scn-prose h2, .fr-scn-prose h3 { color: var(--fr-scn-ink); }
.fr-scn-prose a { color: var(--fr-scn-accent); }

/* ===== Scénarios liés ==================================== */
.fr-scn-related {
    margin-top: clamp(2.5rem, 5vw, 4rem);
    background: transparent;
}
/* La grille .fm-grid + cards .fm-card sont déjà gérées dans style.css ;
   on hérite de la palette --fm-page-accent via .fm-page--scenarios. */
