/*
 * Stylespage-traitement-texte — page Traitement de texte
 *
 * Ordre de la page :
 *  1. Zone fixe — accès rapide, bandeau d'actions
 *  2. Corps éditeur — zoom vertical à gauche, feuilles A4 à droite
 *
 * Bureau : 80 vw par défaut, 90 vw à partir de 1920 px (écrans 27 pouces).
 */

/* Largeur du conteneur — 90 vw sur grands écrans */

.page-traitement-texte.page-contenu {
    --conteneur-largeur: 80vw;
    /* Hauteur sticky (accès rapide + bandeau + marges) — centre le zoom dans la zone éditable */
    --bandeau-hauteur: 16vh;
    --zone-zoom-reserve-haut: calc(4.25vh + var(--bandeau-hauteur));

    width: var(--conteneur-largeur);
    max-width: var(--conteneur-largeur);
}

@media (min-width: 1920px) {
    .page-traitement-texte.page-contenu {
        --conteneur-largeur: 90vw;
    }
}

/* 1. Zone fixe — reste visible en haut au défilement */

.page-traitement-texte .zone-fixe {
    position: sticky;
    top: 0;
    z-index: 10;
    background-color: var(--color-bg);
    padding-bottom: 0.45vh;
    border-bottom: 1px solid var(--color-border);
}

.page-traitement-texte .zone-fixe > * + * {
    margin-top: 1vh;
}

/* Bandeau — hauteur pilotée par --bandeau-hauteur sur .page-contenu */
.page-traitement-texte .bandeau-actions-grilles {
    height: var(--bandeau-hauteur);
    min-height: var(--bandeau-hauteur);
    max-height: var(--bandeau-hauteur);
}

/* Corps éditeur — page A4 centrée, zoom fixe à gauche (hors flux) */

.editeur-corps {
    --zone-zoom-largeur: 9vw;

    display: flex;
    justify-content: center;
    align-items: flex-start;
    width: 100%;
    margin-top: 1.5vh;
    padding-bottom: 2vh;
    box-sizing: border-box;
}

@media (min-width: 1920px) {
    .editeur-corps {
        --zone-zoom-largeur: 10vw;
    }
}

/* Fixe — centré verticalement sous la zone sticky (pas au milieu brut du viewport) */
.zone-zoom {
    position: fixed;
    top: var(--zone-zoom-reserve-haut, 0px);
    bottom: 0;
    left: max(
        1.25vw,
        calc((100vw - var(--conteneur-largeur, 80vw)) / 2 + 1.25vw)
    );
    height: fit-content;
    margin-block: auto;
    z-index: 5;
    width: var(--zone-zoom-largeur);
}

/* 3. Éditeur — zone grise autour des feuilles, centrée */
.editeur {
    flex-shrink: 0;
    padding: 1.5vh;
    background-color: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: 0.35vh;
}

/* Empile les pages verticalement, centrées */
/* Liste des feuilles A4 */
.editeur-pages {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.5vh;
    list-style: none;
    padding: 0;
    margin: 0;
    --page-largeur: 210mm;
    --page-hauteur: 297mm;
    --texte-police: Arial, sans-serif;
    --texte-taille: 12pt;
    --texte-couleur: #1a1a1a;
    --texte-alignement: left;
    --marge-haut: 3cm;
    --marge-bas: 3cm;
    --marge-gauche: 2cm;
    --marge-droite: 2cm;
    --zoom-editeur: 1;
}

@supports (zoom: 1) {
    .editeur-pages {
        zoom: var(--zoom-editeur);
    }
}

@supports not (zoom: 1) {
    .editeur-pages {
        transform: scale(var(--zoom-editeur));
        transform-origin: top center;
    }
}

figure.editeur {
    margin: 0;
    overflow: visible;
}

figure.editeur figcaption {
    margin: 0;
}

.page-a4[data-orientation="paysage"] {
    --page-largeur: 297mm;
    --page-hauteur: 210mm;
}

/* Une feuille A4 (210 × 297 mm) */
.page-a4 {
    position: relative;
    display: flex;
    flex-direction: column;
    width: var(--page-largeur);
    height: var(--page-hauteur);
    max-width: 100%;
    padding: var(--marge-haut) var(--marge-droite) var(--marge-bas)
        var(--marge-gauche);
    background-color: var(--color-surface);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.12);
    box-sizing: border-box;
    list-style: none;
}

/* Zone de saisie : remplit la feuille, sans bordure visible */
.page-ecriture {
    flex: 1;
    width: 100%;
    min-height: 0;
    margin: 0;
    padding: 0;
    border: none;
    outline: none;
    background: transparent;
    color: var(--texte-couleur);
    font-family: var(--texte-police);
    font-size: var(--texte-taille);
    line-height: 1.5;
    text-align: var(--texte-alignement);
    word-break: break-word;
    white-space: pre-wrap;
    overflow: hidden;
    caret-color: var(--curseur-saisie);
    cursor:
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Cpath fill='%23ffffff' stroke='%231a1a1a' stroke-width='2' d='M16 4v24M10 4h12M10 28h12'/%3E%3C/svg%3E")
            16 16,
        text;
}

.page-ecriture strong,
.page-ecriture b {
    font-weight: 700;
}

.page-ecriture em,
.page-ecriture i {
    font-style: italic;
}

.page-ecriture u {
    text-decoration: underline;
}

/* Listes — ul / ol : alignement à gauche (évite chiffres au-dessus du texte avec justify) */
.page-ecriture ul,
.page-ecriture ol {
    margin: 0.2em 0;
    padding-left: 2em;
    text-align: left;
    white-space: normal;
    word-break: normal;
    list-style-position: outside;
}

.page-ecriture ul {
    list-style-type: disc;
}

.page-ecriture ol {
    list-style-type: decimal;
}

.page-ecriture li {
    display: list-item;
    margin: 0.15em 0;
    padding: 0;
    text-align: left;
    white-space: normal;
    word-break: normal;
}

.page-ecriture:empty::before {
    content: attr(data-placeholder);
    color: var(--color-text-muted);
    pointer-events: none;
}

.page-ecriture img.page-medias__element--image,
.page-ecriture video.page-medias__element--video {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
    margin: 0;
}

.page-ecriture video.page-medias__element--video {
    max-height: 22vh;
}

/* Bloc image ou vidéo — position gauche, centre ou droite via data-alignement */
.page-medias__bloc {
    position: relative;
    display: block;
    width: fit-content;
    max-width: 100%;
    margin: 0.5vh 0;
    line-height: 0;
}

.page-medias__bloc[data-alignement="gauche"],
.page-medias__bloc:not([data-alignement]) {
    margin-right: auto;
    margin-left: 0;
}

.page-medias__bloc[data-alignement="centre"] {
    margin-left: auto;
    margin-right: auto;
}

.page-medias__bloc[data-alignement="droite"] {
    margin-left: auto;
    margin-right: 0;
}

.page-medias__bloc--selectionne .page-medias__element {
    box-shadow: 0 0 0 2px var(--color-accent);
}

.page-medias__supprimer {
    position: absolute;
    top: 0.35vh;
    right: 0.35vh;
    z-index: 2;
    display: none;
    align-items: center;
    justify-content: center;
    width: 2.75vh;
    height: 2.75vh;
    padding: 0;
    font-family: inherit;
    font-size: 1.35rem;
    font-weight: 700;
    line-height: 1;
    cursor: pointer;
    border: none;
    border-radius: 50%;
    background-color: #c62828;
    color: #ffffff;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.25);
}

.page-medias__bloc--selectionne .page-medias__supprimer {
    display: flex;
}

.page-medias__poignee {
    position: absolute;
    right: 0;
    bottom: 0;
    z-index: 2;
    display: none;
    width: 2.5vh;
    height: 2.5vh;
    cursor: nwse-resize;
    touch-action: none;
    border: 3px solid #ffffff;
    border-radius: 0.35vh 0 0 0;
    background-color: var(--color-accent);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.28);
}

.page-medias__bloc--selectionne .page-medias__poignee {
    display: block;
}

/* Numérotation en pied de page — bas droite, ex. 1/3 */
.page-pied-numero {
    position: absolute;
    right: var(--marge-droite);
    bottom: calc(var(--marge-bas) * 0.25);
    z-index: 1;
    display: flex;
    align-items: baseline;
    gap: 0.1vh;
    margin: 0;
    padding: 0;
    pointer-events: none;
    user-select: none;
    font-family: var(--texte-police);
    line-height: 1;
}

.editeur-pages[data-numeros-pages="false"] .page-pied-numero {
    display: none;
}

.page-pied-numero__actuelle,
.page-pied-numero__total {
    font-size: 0.85rem;
    font-weight: 400;
    color: var(--texte-couleur);
}

.page-pied-numero__sep {
    font-size: 0.75rem;
    font-weight: 400;
    color: var(--color-text-muted);
}

/* Curseur plus visible — souris et saisie */
.page-traitement-texte {
    cursor:
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Cpath fill='%23ffffff' stroke='%231a1a1a' stroke-width='2' stroke-linejoin='round' d='M6 4l4 18 4-7 7-1z'/%3E%3C/svg%3E")
            6 4,
        auto;
}

.page-traitement-texte button,
.page-traitement-texte select,
.page-traitement-texte input[type="color"],
.page-traitement-texte .bouton-aide {
    cursor:
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Cpath fill='%23ffffff' stroke='%231a1a1a' stroke-width='2' stroke-linejoin='round' d='M10 4c0 4-3 6-3 10a6 6 0 1 0 12 0c0-2-1-3-2-4l-2-8z'/%3E%3Cline x1='10' y1='24' x2='10' y2='28' stroke='%231a1a1a' stroke-width='2'/%3E%3C/svg%3E")
            10 4,
        pointer;
}

.page-ecriture:focus {
    outline: none;
}

.page-ecriture:focus-visible {
    box-shadow: inset 0 0 0 2px
        color-mix(in srgb, var(--curseur-saisie) 35%, transparent);
}

/* Impression : une feuille A4 par page */
@media print {
    .site-header,
    .site-footer,
    .zone-fixe,
    .zone-zoom {
        display: none;
    }

    .page-contenu {
        padding: 0;
        max-width: none;
    }

    .editeur {
        padding: 0;
        background: transparent;
        border: none;
    }

    .editeur-pages {
        gap: 0;
        zoom: 1 !important;
        transform: none !important;
    }

    .page-a4 {
        width: auto;
        height: auto;
        max-width: none;
        padding: 0;
        box-shadow: none;
        page-break-after: always;
    }

    .page-a4:last-child {
        page-break-after: auto;
    }

    .page-ecriture {
        overflow: visible;
        height: auto;
        min-height: 0;
    }

    .page-medias__supprimer,
    .page-medias__poignee {
        display: none !important;
    }
}
