/* ==========================================================================
   Layout — structure générale du site
   ========================================================================== */

/* ─── Bandeau image ───────────────────────────────────────────────────────── */

.cdc-bandeau {
    position: relative;
    width: 100%;
    height: var(--cdc-h-bandeau);
    overflow: hidden;
}

.cdc-bandeau-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

/* Voile dégradé en bas du bandeau pour fondre avec la page */
/* Utilise la couleur transparente du fond (pas transparent générique = noir) */
.cdc-bandeau-voile {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 50%;
    background: linear-gradient(to bottom, rgba(245, 234, 208, 0), 90%, var(--cdc-fond-page));
    pointer-events: none;
}

[data-theme="nuit"] .cdc-bandeau-voile {
    background: linear-gradient(to bottom, rgba(29, 22, 16, 0), var(--cdc-fond-page));
}

/* État sans image : motif décoratif */
.cdc-bandeau-vide {
    background:
        repeating-linear-gradient(
            90deg,
            transparent 0,
            transparent 80px,
            rgba(255, 255, 255, 0.06) 80px,
            rgba(255, 255, 255, 0.06) 82px
        ),
        linear-gradient(135deg, var(--cdc-vieil-or-fonce), var(--cdc-or-clair) 50%, var(--cdc-vieil-or-fonce));
}

/* ─── En-tête : titre + baseline ──────────────────────────────────────────── */

.cdc-entete {
    position: relative;
    text-align: center;
    padding: var(--cdc-esp-xl) var(--cdc-esp-md) var(--cdc-esp-lg);
    margin-top: calc(-1 * var(--cdc-esp-xl));
    z-index: 2;
}

.cdc-marque {
    display: inline-block;
    text-decoration: none;
    color: inherit;
    transition: transform var(--cdc-trans);
}

.cdc-marque:hover, .cdc-marque:focus {
    text-decoration: none;
    transform: translateY(-1px);
}

.cdc-marque-titre {
    font-family: var(--cdc-fonte-titre);
    font-size: clamp(2.2rem, 5vw, 3.6rem);
    font-weight: var(--cdc-poids-titre);
    letter-spacing: 0.04em;
    margin: 0;
    color: var(--cdc-texte-titre);
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.3);
}

[data-theme="nuit"] .cdc-marque-titre {
    text-shadow:
        0 0 20px rgba(232, 200, 118, 0.3),
        0 0 40px rgba(232, 200, 118, 0.15);
}

.cdc-marque-baseline {
    font-family: var(--cdc-fonte-corps);
    font-style: italic;
    font-size: clamp(0.95rem, 1.5vw, 1.15rem);
    color: var(--cdc-texte-secondaire);
    margin: var(--cdc-esp-sm) 0 0;
    letter-spacing: 0.02em;
}

/* ─── Navigation principale ───────────────────────────────────────────────── */

.cdc-nav {
    position: sticky;
    top: 0;
    z-index: var(--cdc-z-nav);
    background: var(--cdc-fond-nav);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-top: 1px solid var(--cdc-bordure);
    border-bottom: 1px solid var(--cdc-bordure);
    box-shadow: var(--cdc-ombre-sm);
}

.cdc-nav-inner {
    max-width: var(--cdc-largeur-large);
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: var(--cdc-h-nav);
    padding: 0 var(--cdc-esp-md);
    gap: var(--cdc-esp-md);
}

/* Bouton burger (mobile) */
.cdc-nav-burger {
    display: none;
    align-items: center;
    gap: var(--cdc-esp-xs);
    background: transparent;
    border: 1px solid var(--cdc-bordure);
    color: var(--cdc-texte-secondaire);
    padding: var(--cdc-esp-xs) var(--cdc-esp-sm);
    border-radius: var(--cdc-rayon-sm);
    font-family: var(--cdc-fonte-titre);
    font-size: 0.85rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    transition: all var(--cdc-trans);
}

.cdc-nav-burger:hover {
    border-color: var(--cdc-accent);
    color: var(--cdc-accent);
}

/* Liste des entrées */
.cdc-nav-liste {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    gap: var(--cdc-esp-xs);
    flex: 1;
    justify-content: center;
}

.cdc-nav-item {
    position: relative;
}

.cdc-nav-lien {
    display: flex;
    align-items: center;
    gap: var(--cdc-esp-xs);
    padding: var(--cdc-esp-xs) var(--cdc-esp-md);
    font-family: var(--cdc-fonte-titre);
    font-size: 0.95rem;
    font-weight: var(--cdc-poids-titre);
    letter-spacing: 0.05em;
    color: var(--cdc-texte-secondaire);
    text-decoration: none;
    border-radius: var(--cdc-rayon-sm);
    transition: all var(--cdc-trans);
    position: relative;
}

.cdc-nav-lien::after {
    content: '';
    position: absolute;
    left: 50%;
    bottom: 0;
    width: 0;
    height: 1px;
    background: var(--cdc-accent-vif);
    transition: width var(--cdc-trans), left var(--cdc-trans);
}

.cdc-nav-lien:hover, .cdc-nav-lien:focus {
    color: var(--cdc-accent);
    text-decoration: none;
}

.cdc-nav-lien:hover::after, .cdc-nav-lien:focus::after {
    width: 60%;
    left: 20%;
}

.cdc-nav-item.est-actif > .cdc-nav-lien {
    color: var(--cdc-accent);
}

.cdc-nav-item.est-actif > .cdc-nav-lien::after {
    width: 60%;
    left: 20%;
}

.cdc-nav-icone {
    display: flex;
    align-items: center;
    color: inherit;
}

.cdc-nav-chevron {
    margin-left: 2px;
    opacity: 0.6;
    transition: transform var(--cdc-trans);
}

.cdc-nav-item.a-sous:hover .cdc-nav-chevron {
    transform: rotate(180deg);
}

/* Sous-menu */
.cdc-sous-menu {
    list-style: none;
    margin: 0;
    padding: var(--cdc-esp-xs) 0;
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(-4px);
    min-width: 360px;
    max-width: 540px;
    background: var(--cdc-fond-cartouche);
    border: 1px solid var(--cdc-bordure-forte);
    border-radius: var(--cdc-rayon-md);
    box-shadow: var(--cdc-ombre-lg);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: all var(--cdc-trans);
    z-index: 10;
}

.cdc-nav-item.a-sous:hover .cdc-sous-menu,
.cdc-nav-item.a-sous:focus-within .cdc-sous-menu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
}

.cdc-sous-menu li {
    margin: 0;
}

.cdc-sous-menu a {
    display: block;
    padding: var(--cdc-esp-xs) var(--cdc-esp-md);
    font-family: var(--cdc-fonte-corps);
    font-size: 0.9rem;
    color: var(--cdc-texte-secondaire);
    text-decoration: none;
    border-radius: 0;
    transition: all var(--cdc-trans);
}

.cdc-sous-menu a:hover, .cdc-sous-menu a:focus {
    background: var(--cdc-fond-creux);
    color: var(--cdc-accent);
    text-decoration: none;
}

/* Bascule jour / nuit */
.cdc-theme-toggle {
    background: transparent;
    border: 1px solid var(--cdc-bordure);
    color: var(--cdc-texte-secondaire);
    width: 38px;
    height: 38px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--cdc-trans);
    flex-shrink: 0;
}

.cdc-theme-toggle:hover {
    border-color: var(--cdc-accent);
    color: var(--cdc-accent);
    transform: rotate(15deg);
}

.cdc-theme-jour { display: none; }
.cdc-theme-nuit { display: flex; align-items: center; }

[data-theme="nuit"] .cdc-theme-jour { display: flex; align-items: center; }
[data-theme="nuit"] .cdc-theme-nuit { display: none; }

/* ─── Main ────────────────────────────────────────────────────────────────── */

.cdc-main {
    min-height: 50vh;
    padding: var(--cdc-esp-xl) 0 var(--cdc-esp-2xl);
}

.cdc-section {
    max-width: var(--cdc-largeur-contenu);
    margin: 0 auto var(--cdc-esp-2xl);
    padding: 0 var(--cdc-esp-lg);
}

.cdc-section:last-child {
    margin-bottom: 0;
}

.cdc-section-titre {
    font-family: var(--cdc-fonte-titre);
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    text-align: center;
    margin-bottom: var(--cdc-esp-xs);
}

.cdc-section-sous {
    text-align: center;
    color: var(--cdc-texte-secondaire);
    font-style: italic;
    margin-bottom: var(--cdc-esp-xl);
}

.cdc-section-action {
    text-align: center;
    margin-top: var(--cdc-esp-xl);
}

.cdc-page-entete {
    text-align: center;
    margin-bottom: var(--cdc-esp-2xl);
}

.cdc-page-titre {
    font-family: var(--cdc-fonte-titre);
    font-size: clamp(2rem, 4vw, 3rem);
    margin-bottom: var(--cdc-esp-xs);
}

.cdc-page-sous {
    color: var(--cdc-texte-secondaire);
    font-style: italic;
    font-size: 1.1rem;
    margin-bottom: var(--cdc-esp-lg);
}

/* ─── Pied de page ────────────────────────────────────────────────────────── */

.cdc-pied {
    margin-top: var(--cdc-esp-3xl);
    padding: var(--cdc-esp-xl) var(--cdc-esp-md);
    background: var(--cdc-fond-creux);
    border-top: 1px solid var(--cdc-bordure);
    color: var(--cdc-texte-secondaire);
    text-align: center;
}

.cdc-pied-inner {
    max-width: var(--cdc-largeur-contenu);
    margin: 0 auto;
}

.cdc-pied-titre {
    font-family: var(--cdc-fonte-titre);
    font-size: 1.2rem;
    color: var(--cdc-texte-titre);
    letter-spacing: 0.05em;
    margin: var(--cdc-esp-md) 0 var(--cdc-esp-xs);
}

.cdc-pied-mention {
    font-size: 0.85rem;
    color: var(--cdc-texte-discret);
    margin: 0 0 var(--cdc-esp-md);
}

.cdc-pied-liens {
    font-size: 0.9rem;
}

.cdc-pied-liens a {
    color: var(--cdc-texte-secondaire);
    margin: 0 var(--cdc-esp-xs);
}

.cdc-pied-liens span {
    color: var(--cdc-texte-discret);
    margin: 0 var(--cdc-esp-2xs);
}
