:root,
html[data-theme="sombre"] {
    --bg: #0f1115;
    --panel: #161a1f;
    --panel-rgb: 22, 26, 31;
    --border: #2c333a;
    --text: #d7dadc;
    --text-dim: #8c9197;
    --accent: #4c9aff;
    --row-hover: #1b2026;
    --modal-opacity: 0.9;

    --grp-action: 155, 89, 217;
    --grp-compilation: 230, 126, 34;
    --grp-rec: 76, 154, 255;
    --grp-preprod: 227, 179, 65;
    --grp-prod: 63, 185, 80;
}

html[data-theme="clair"] {
    --bg: #f4f5f7;
    --panel: #ffffff;
    --panel-rgb: 255, 255, 255;
    --border: #dfe1e6;
    --text: #172b4d;
    --text-dim: #5e6c84;
    --accent: #0052cc;
    --row-hover: #f1f2f4;
}

html[data-theme="bleu_nuit"] {
    --bg: #0a1929;
    --panel: #102a43;
    --panel-rgb: 16, 42, 67;
    --border: #1e3a5f;
    --text: #e3eefc;
    --text-dim: #92a9c4;
    --accent: #5eb1ff;
    --row-hover: #16334f;
}

html[data-theme="vert_nuit"] {
    --bg: #0d1912;
    --panel: #142a1e;
    --panel-rgb: 20, 42, 30;
    --border: #234a34;
    --text: #d9f0e3;
    --text-dim: #8fb89f;
    --accent: #4cd97a;
    --row-hover: #1a3526;
}

html[data-theme="violet"] {
    --bg: #160f22;
    --panel: #221934;
    --panel-rgb: 34, 25, 52;
    --border: #3b2a55;
    --text: #e6dffa;
    --text-dim: #a596c2;
    --accent: #b083f0;
    --row-hover: #2a1f42;
}

html[data-theme="contraste"] {
    --bg: #000000;
    --panel: #0d0d0d;
    --panel-rgb: 13, 13, 13;
    --border: #555555;
    --text: #ffffff;
    --text-dim: #cccccc;
    --accent: #ffd60a;
    --row-hover: #1f1f1f;
}

html[data-theme="sable"] {
    --bg: #faf3e8;
    --panel: #fffaf2;
    --panel-rgb: 255, 250, 242;
    --border: #e3d3b8;
    --text: #4a3a25;
    --text-dim: #8a7556;
    --accent: #b5651d;
    --row-hover: #f0e6d2;
}

html[data-theme="charbon"] {
    --bg: #16140f;
    --panel: #221f18;
    --panel-rgb: 34, 31, 24;
    --border: #3d3829;
    --text: #ece6da;
    --text-dim: #a89c84;
    --accent: #e8a33d;
    --row-hover: #2c281e;
}

html[data-theme="bordeaux"] {
    --bg: #1a0e10;
    --panel: #2a161a;
    --panel-rgb: 42, 22, 26;
    --border: #4a2730;
    --text: #f0dde0;
    --text-dim: #b58a92;
    --accent: #e85d75;
    --row-hover: #341c21;
}

html[data-theme="turquoise"] {
    --bg: #07191c;
    --panel: #0f2b2f;
    --panel-rgb: 15, 43, 47;
    --border: #1f4a4f;
    --text: #d9f5f5;
    --text-dim: #87b8ba;
    --accent: #2dd4bf;
    --row-hover: #133539;
}

html[data-theme="graphite"] {
    --bg: #15171a;
    --panel: #1d2024;
    --panel-rgb: 29, 32, 36;
    --border: #33373d;
    --text: #d9dbde;
    --text-dim: #8d9197;
    --accent: #6f9bc4;
    --row-hover: #242830;
}

html[data-theme="glacier"] {
    --bg: #eef5fb;
    --panel: #ffffff;
    --panel-rgb: 255, 255, 255;
    --border: #cfe3f0;
    --text: #1c3a4a;
    --text-dim: #5c7c8c;
    --accent: #1f8fe0;
    --row-hover: #e3f0f9;
}

html[data-theme="lavande"] {
    --bg: #f3effa;
    --panel: #fbf9fe;
    --panel-rgb: 251, 249, 254;
    --border: #ddd0ee;
    --text: #3f3357;
    --text-dim: #7c6d96;
    --accent: #8a63d2;
    --row-hover: #ece4f7;
}

html[data-theme="corail"] {
    --bg: #1c1015;
    --panel: #2a181f;
    --panel-rgb: 42, 24, 31;
    --border: #482733;
    --text: #f5dfe3;
    --text-dim: #b98e98;
    --accent: #ff6f61;
    --row-hover: #341e27;
}

html[data-theme="neon"] {
    --bg: #060608;
    --panel: #0d0d12;
    --panel-rgb: 13, 13, 18;
    --border: #2a2a35;
    --text: #e8e8ff;
    --text-dim: #8888aa;
    --accent: #ff2e88;
    --row-hover: #161620;
}

* { box-sizing: border-box; }

body {
    background: var(--bg);
    color: var(--text);
    font-family: -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    font-size: 13px;
    margin: 0;
}

.userbar {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: 8px 20px;
    background: var(--panel);
    border-bottom: 1px solid var(--border);
    font-size: 12px;
    color: var(--text-dim);
}

.userbar > .userbar-gauche, .userbar > .menu-parametrage {
    padding-top: 4px;
}

.userbar a, .link-btn {
    color: var(--text-dim);
    text-decoration: none;
    margin-left: 14px;
    font-size: 12px;
}

.link-btn {
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
}

.userbar a:hover, .link-btn:hover {
    color: var(--accent);
}

.lien-icone {
    display: inline-flex;
    align-items: center;
    vertical-align: middle;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    color: var(--text-dim);
}

.lien-icone:hover {
    color: var(--accent);
}

.lien-icone svg {
    width: 16px;
    height: 16px;
}

.menu-parametrage {
    position: relative;
    flex-shrink: 0;
}

.menu-parametrage-dropdown {
    display: none;
    position: absolute;
    top: calc(100% + 6px);
    right: 0;
    min-width: 220px;
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: 6px;
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.5);
    z-index: 50;
    overflow: hidden;
}

.menu-parametrage-dropdown.open {
    display: block;
}

.menu-parametrage-dropdown a {
    display: block;
    width: 100%;
    margin-left: 0;
    padding: 9px 14px;
    text-align: left;
    box-sizing: border-box;
}

.menu-parametrage-dropdown a:hover {
    background: var(--row-hover);
}

.userbar-gauche {
    display: flex;
    align-items: center;
    gap: 14px;
}

.menu-utilisateur {
    position: relative;
}

.menu-utilisateur-bouton {
    display: flex;
    align-items: center;
    gap: 6px;
    background: none;
    border: none;
    color: var(--text);
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    padding: 4px 2px;
}

.menu-utilisateur-bouton svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

.menu-utilisateur-dropdown {
    display: none;
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    min-width: 160px;
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: 6px;
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.5);
    z-index: 50;
    overflow: hidden;
}

.menu-utilisateur-dropdown.open {
    display: block;
}

.menu-utilisateur-dropdown a,
.menu-utilisateur-dropdown .link-btn {
    display: block;
    width: 100%;
    margin-left: 0;
    padding: 9px 14px;
    text-align: left;
    box-sizing: border-box;
}

.menu-utilisateur-dropdown a:hover,
.menu-utilisateur-dropdown .link-btn:hover {
    background: var(--row-hover);
}

.nav-principale {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    flex: 1;
}

.prefs-parametrage {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
    white-space: nowrap;
}

.nav-principale .btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 10px;
    font-size: 11px;
}

.nav-principale .btn svg {
    width: 13px;
    height: 13px;
    flex-shrink: 0;
}

.badge-extension {
    display: inline-block;
    background: var(--accent);
    color: #0b1220;
    font-size: 10px;
    font-weight: 700;
    border-radius: 3px;
    padding: 2px 5px;
    margin-right: 6px;
    vertical-align: middle;
}

.nav-principale a.actif {
    background: var(--accent);
    color: #0b1220;
    border-color: var(--accent);
}

.menu-nav-dropdown {
    position: relative;
}

.menu-nav-dropdown-panel {
    display: none;
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    min-width: 200px;
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: 6px;
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.5);
    z-index: 50;
    overflow: hidden;
}

.menu-nav-dropdown-panel.open {
    display: block;
}

.menu-nav-dropdown-panel a {
    display: block;
    width: 100%;
    margin-left: 0;
    padding: 9px 14px;
    text-align: left;
    box-sizing: border-box;
    color: var(--text-dim);
    text-decoration: none;
    font-size: 12px;
}

.menu-nav-dropdown-panel a:hover {
    background: var(--row-hover);
    color: var(--accent);
}

.topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 20px;
    border-bottom: 1px solid var(--border);
}

.topbar .btn + .btn, .topbar a + a {
    margin-left: 8px;
}

.messages {
    margin: 14px 20px 0;
}

.message {
    padding: 10px 14px;
    border-radius: 4px;
    margin-bottom: 8px;
    font-size: 13px;
    transition: opacity 0.5s ease;
}

.message.disparition {
    opacity: 0;
}

.message-error {
    background: #3b1f1f;
    color: #ff8a80;
    border: 1px solid #e2483d;
}

.message-success {
    background: #1f3b27;
    color: #57ab5a;
    border: 1px solid #238636;
}

.erreur-formulaire {
    background: #3b1f1f;
    color: #ff8a80;
    border: 1px solid #e2483d;
    padding: 10px 14px;
    border-radius: 4px;
    margin-bottom: 14px;
    font-size: 13px;
}

.erreur-formulaire .errorlist {
    list-style: none;
    margin: 0;
    padding: 0;
}

.topbar h1 {
    font-size: 16px;
    font-weight: 600;
    margin: 0;
}

.btn {
    display: inline-block;
    background: var(--accent);
    color: #0b1220;
    border: none;
    border-radius: 4px;
    padding: 7px 14px;
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
}

.btn-secondary {
    background: transparent;
    color: var(--text);
    border: 1px solid var(--border);
}

.btn-danger {
    background: #e2483d;
    color: #fff;
}

.table-wrapper {
    overflow-x: auto;
    overflow-y: auto;
    max-height: 72vh;
    margin: 16px 20px;
    border: 1px solid var(--border);
    border-radius: 6px;
}

table.jira-table {
    border-collapse: collapse;
    width: 100%;
    min-width: 3100px;
}

/* Tables a peu de colonnes (ex. Documentation) : n'a pas besoin de la
   largeur minimale pensee pour les grandes grilles (Suivi des entites/
   donnees...), qui forcerait un defilement horizontal inutile. */
table.jira-table.table-compacte {
    min-width: 0;
}

table.jira-table.table-compacte th.col-auteur-document,
table.jira-table.table-compacte td.col-auteur-document {
    width: 130px;
}

table.jira-table.table-compacte th.col-date-document,
table.jira-table.table-compacte td.col-date-document {
    width: 110px;
}

table.jira-table.table-compacte th.col-taille-document,
table.jira-table.table-compacte td.col-taille-document {
    width: 80px;
}

table.jira-table.table-compacte th.col-actions-document,
table.jira-table.table-compacte td.col-actions-document {
    width: 70px;
}

table.jira-table th {
    position: sticky;
    top: 0;
    background: var(--panel);
    color: var(--text-dim);
    text-align: left;
    font-weight: 600;
    font-size: 12px;
    padding: 10px 12px;
    border-bottom: 1px solid var(--border);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    z-index: 3;
}

.poignee-redimensionnement {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 6px;
    cursor: col-resize;
    z-index: 2;
}

.poignee-redimensionnement:hover {
    background: rgba(88, 166, 255, 0.5);
}

.th-tri-date {
    cursor: pointer;
    user-select: none;
}

.icone-tri {
    color: var(--text-dim);
    font-size: 10px;
    margin-left: 4px;
}

.icone-tri.actif {
    color: var(--accent);
}

.bouton-filtre-colonne {
    background: none;
    border: none;
    color: var(--text-dim);
    cursor: pointer;
    font-size: 10px;
    margin-left: 4px;
    padding: 0 2px;
    vertical-align: middle;
}

.bouton-filtre-colonne:hover {
    color: var(--accent);
}

.panneau-filtre-colonne {
    position: fixed;
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 8px 10px;
    max-height: 240px;
    overflow-y: auto;
    min-width: 170px;
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.5);
    z-index: 1000;
    font-weight: 400;
    font-size: 12px;
    color: var(--text);
    text-transform: none;
}

.panneau-filtre-colonne label {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 3px 0;
    cursor: pointer;
    white-space: nowrap;
}

.panneau-filtre-colonne label:first-child {
    border-bottom: 1px solid var(--border);
    margin-bottom: 4px;
    padding-bottom: 6px;
    font-weight: 600;
}

table.jira-table th.colonne-figee {
    z-index: 4;
}

table.jira-table tbody td.colonne-figee {
    background: var(--bg);
    z-index: 1;
}

table.jira-table tbody tr:hover td.colonne-figee {
    background: var(--row-hover);
}

table.jira-table .colonne-figee-bord {
    box-shadow: 2px 0 6px rgba(0, 0, 0, 0.45);
}

table.jira-table thead tr:nth-child(2) th {
    top: 35px;
}

table.jira-table td {
    padding: 9px 12px;
    border-bottom: 1px solid var(--border);
    white-space: nowrap;
    max-width: 260px;
    overflow: hidden;
    text-overflow: ellipsis;
}

table.jira-table td.cellule-multiligne {
    white-space: pre-line;
    overflow: visible;
    text-overflow: unset;
    max-width: 200px;
}

table.jira-table tbody tr:hover {
    background: var(--row-hover);
}

table.jira-table th.th-groupe-titre {
    text-align: center;
}

table.jira-table th.col-auteur, table.jira-table td.col-auteur {
    width: 48px;
    max-width: 48px;
    text-align: center;
    cursor: help;
}

table.jira-table td.importance-faible {
    color: #4c9aff;
    font-weight: 600;
}

table.jira-table td.importance-moyen {
    color: #e67e22;
    font-weight: 600;
}

table.jira-table td.importance-tres-important {
    color: #e2483d;
    font-weight: 600;
}

.champ-inline {
    width: 100%;
    background: transparent;
    border: 1px solid transparent;
    color: var(--text);
    font-size: 12px;
    padding: 3px 5px;
    border-radius: 4px;
    font-family: inherit;
}

.champ-inline:hover, .champ-inline:focus {
    border-color: var(--border);
    background: var(--panel);
}

select.select-statut-inline {
    display: inline-block;
    width: auto;
    max-width: 100%;
    padding: 3px 8px;
    border-radius: 3px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
}

select.select-statut-inline:hover, select.select-statut-inline:focus {
    border-color: var(--border);
}

table.jira-table th.grp-action, table.jira-table td.grp-action { background: rgba(var(--grp-action), 0.12); }
table.jira-table th.grp-compilation, table.jira-table td.grp-compilation { background: rgba(var(--grp-compilation), 0.12); }
table.jira-table th.grp-rec, table.jira-table td.grp-rec { background: rgba(var(--grp-rec), 0.12); }
table.jira-table th.grp-preprod, table.jira-table td.grp-preprod { background: rgba(var(--grp-preprod), 0.12); }
table.jira-table th.grp-prod, table.jira-table td.grp-prod { background: rgba(var(--grp-prod), 0.12); }

.barre-recherche {
    margin: 14px 20px 0;
}

.filtres-journal {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 14px 20px 0;
}

.filtres-journal select {
    max-width: 220px;
}

.pagination {
    display: flex;
    align-items: center;
    gap: 14px;
    margin: 16px 20px;
    color: var(--text-dim);
    font-size: 12px;
}

.barre-recherche input {
    max-width: 360px;
}

.barre-actions .barre-recherche {
    margin: 0;
}

.barre-actions .barre-recherche input {
    max-width: 220px;
}

.barre-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 14px 20px 0;
    flex-wrap: wrap;
    gap: 12px;
}

.actions-selection {
    display: flex;
    gap: 8px;
}

.affichage-couleur {
    display: flex;
    align-items: center;
    gap: 16px;
    font-size: 12px;
    color: var(--text-dim);
}

.affichage-couleur label {
    display: flex;
    align-items: center;
    gap: 5px;
    cursor: pointer;
}

.affichage-grille {
    display: flex;
    align-items: center;
    gap: 16px;
    font-size: 12px;
    color: var(--text-dim);
}

.affichage-grille label {
    display: flex;
    align-items: center;
    gap: 5px;
    cursor: pointer;
}

.table-wrapper.avec-grille table.jira-table th,
.table-wrapper.avec-grille table.jira-table td {
    border-right: 1px solid var(--border);
}

.table-wrapper.avec-grille table.jira-table th:last-child,
.table-wrapper.avec-grille table.jira-table td:last-child {
    border-right: none;
}

.table-wrapper.sans-couleur th.grp-action,
.table-wrapper.sans-couleur th.grp-compilation,
.table-wrapper.sans-couleur th.grp-rec,
.table-wrapper.sans-couleur th.grp-preprod,
.table-wrapper.sans-couleur th.grp-prod {
    background: var(--panel);
}

.table-wrapper.sans-couleur td.grp-action,
.table-wrapper.sans-couleur td.grp-compilation,
.table-wrapper.sans-couleur td.grp-rec,
.table-wrapper.sans-couleur td.grp-preprod,
.table-wrapper.sans-couleur td.grp-prod {
    background: transparent;
}

.groupe-champs {
    margin: 14px 0;
    padding: 12px 14px;
    border-radius: 6px;
    border: 1px solid var(--border);
}

.groupe-champs.grp-action { border-left: 3px solid rgb(var(--grp-action)); background: rgba(var(--grp-action), 0.06); }
.groupe-champs.grp-compilation { border-left: 3px solid rgb(var(--grp-compilation)); background: rgba(var(--grp-compilation), 0.06); }
.groupe-champs.grp-rec { border-left: 3px solid rgb(var(--grp-rec)); background: rgba(var(--grp-rec), 0.06); }
.groupe-champs.grp-preprod { border-left: 3px solid rgb(var(--grp-preprod)); background: rgba(var(--grp-preprod), 0.06); }
.groupe-champs.grp-prod { border-left: 3px solid rgb(var(--grp-prod)); background: rgba(var(--grp-prod), 0.06); }

.groupe-titre {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--text-dim);
    margin-bottom: 10px;
}

.groupe-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 14px;
}

.groupe-grid .form-group.full {
    grid-column: 1 / -1;
}

.badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 3px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    margin-right: 4px;
    white-space: nowrap;
}

.statut-livre { background: #23863333; color: #3fb950; border: 1px solid #238633; }
.statut-livre-manuel { background: #23863333; color: #3fb950; border: 1px solid #238633; }
.statut-a-livrer { background: #1f6feb33; color: #58a6ff; border: 1px solid #1f6feb; }
.statut-a-supprimer { background: #e2483d33; color: #ff7b72; border: 1px solid #e2483d; }
.statut-supprime { background: #3b4252; color: #8b949e; border: 1px solid #484f58; }
.statut-ne-pas-livrer { background: #9e6a0333; color: #e3b341; border: 1px solid #9e6a03; }
.statut-en-attente { background: #e67e2233; color: #f0a868; border: 1px solid #e67e22; }

.pill-bool-oui { color: #e3b341; font-weight: 600; }
.pill-bool-non { color: var(--text-dim); }

.actions-cell a, .actions-cell button {
    color: var(--text-dim);
    text-decoration: none;
    margin-right: 8px;
    font-size: 12px;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
}

.actions-cell a:hover, .actions-cell button:hover { color: var(--accent); }

.form-wrapper {
    max-width: 760px;
    margin: 24px auto;
    padding: 0 20px;
}

.form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}

.form-grid .full { grid-column: 1 / -1; }

.form-group label {
    display: block;
    margin-bottom: 4px;
    color: var(--text-dim);
    font-size: 12px;
}

.champ-obligatoire {
    color: #e2483d;
}

.form-control, select.form-control, textarea.form-control {
    width: 100%;
    background: var(--panel);
    border: 1px solid var(--border);
    color: var(--text);
    border-radius: 4px;
    padding: 7px 10px;
    font-size: 13px;
}

.form-check-input {
    margin-right: 6px;
}

.form-actions {
    margin-top: 20px;
    display: flex;
    gap: 10px;
}

.empty-state {
    padding: 40px;
    text-align: center;
    color: var(--text-dim);
}

.confirm-box {
    max-width: 480px;
    margin: 40px auto;
    padding: 20px;
    border: 1px solid var(--border);
    border-radius: 6px;
    background: var(--panel);
}

.modal-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.35);
    align-items: center;
    justify-content: center;
    z-index: 1000;
    padding: 20px;
}

.modal-overlay.open {
    display: flex;
}

.modal-box {
    position: relative;
    background: rgba(var(--panel-rgb), var(--modal-opacity));
    border: 1px solid var(--border);
    border-radius: 8px;
    max-width: 760px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    padding: 24px;
}

.modal-box h2 {
    margin: 0 0 16px;
    font-size: 16px;
}

.rbn-textarea {
    width: 100%;
    font-family: 'Consolas', 'Courier New', monospace;
    font-size: 12px;
    resize: vertical;
    box-sizing: border-box;
}

.modal-close {
    position: absolute;
    top: 14px;
    right: 16px;
    background: none;
    border: none;
    color: var(--text-dim);
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
}

.modal-close:hover {
    color: var(--accent);
}

.boite-dialogue-box {
    max-width: 380px;
    text-align: center;
}

.boite-dialogue-box p {
    margin: 4px 0 22px;
    color: var(--text);
    font-size: 14px;
    line-height: 1.4;
}

.boite-dialogue-box .form-actions {
    justify-content: center;
    margin-top: 0;
}

.modal-opacite {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 12px;
    color: var(--text-dim);
    margin-bottom: 18px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--border);
}

.modal-opacite input[type="range"] {
    flex: 1;
    max-width: 180px;
}

.parametrage-wrapper {
    max-width: 760px;
}

.parametrage-section {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 18px 20px;
    margin-bottom: 18px;
}

.parametrage-section h2 {
    margin: 0 0 8px;
    font-size: 15px;
}

.parametrage-aide {
    color: var(--text-dim);
    font-size: 12px;
    margin: 0 0 14px;
    line-height: 1.4;
}

.separateur-ou {
    display: flex;
    align-items: center;
    text-align: center;
    color: var(--text-dim);
    font-size: 11px;
    margin: 16px 0;
}

.separateur-ou::before, .separateur-ou::after {
    content: '';
    flex: 1;
    border-bottom: 1px solid var(--border);
}

.separateur-ou span {
    padding: 0 10px;
}

#indicateurChargement {
    color: var(--text-dim);
    font-size: 12px;
}

.parametrage-cases {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
}

.case-environnement {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}

.parametrage-liens {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

/* Tableau de bord */

.dashboard-wrapper {
    margin: 4px 20px 24px;
}

.dashboard-kpis {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
    margin-bottom: 20px;
}

.kpi-carte {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 18px 20px;
    display: flex;
    align-items: center;
    gap: 16px;
    transition: transform 0.15s ease, border-color 0.15s ease;
}

.kpi-carte:hover {
    transform: translateY(-2px);
    border-color: var(--accent);
}

.kpi-icone {
    flex: none;
    width: 44px;
    height: 44px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(var(--panel-rgb), 0.6);
    color: var(--accent);
}

.kpi-icone svg {
    width: 22px;
    height: 22px;
}

.kpi-valeur {
    font-size: 28px;
    font-weight: 700;
    line-height: 1.1;
    color: var(--text);
}

.kpi-label {
    font-size: 12px;
    color: var(--text-dim);
    margin-top: 2px;
}

.kpi-sous-label {
    font-size: 11px;
    color: var(--text-dim);
    opacity: 0.7;
    margin-top: 2px;
}

.dashboard-grille {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

.dashboard-panneau {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 20px 22px;
}

.dashboard-panneau-large {
    grid-column: 1 / -1;
}

.dashboard-panneau {
    display: flex;
    flex-direction: column;
}

.dashboard-panneau h2 {
    margin: 0 0 16px;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-dim);
}

.dashboard-panneau > .dashboard-env-grille,
.dashboard-panneau > .dashboard-infos-liste {
    margin-top: auto;
    margin-bottom: auto;
}

.dashboard-env-grille {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 12px;
}

.dashboard-env-carte {
    border-radius: 8px;
    padding: 12px 14px;
    border-left: 3px solid var(--border);
}

.dashboard-env-rec { border-left-color: rgb(var(--grp-rec)); background: rgba(var(--grp-rec), 0.07); }
.dashboard-env-preprod { border-left-color: rgb(var(--grp-preprod)); background: rgba(var(--grp-preprod), 0.07); }
.dashboard-env-prod { border-left-color: rgb(var(--grp-prod)); background: rgba(var(--grp-prod), 0.07); }

.dashboard-env-titre {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--text-dim);
    margin-bottom: 10px;
}

.dashboard-env-chiffres {
    display: flex;
    gap: 18px;
}

.dashboard-env-chiffre {
    display: flex;
    flex-direction: column;
}

.dashboard-env-chiffre strong {
    font-size: 22px;
    line-height: 1.1;
    color: var(--text);
}

.dashboard-env-chiffre span {
    font-size: 11px;
    color: var(--text-dim);
}

.dashboard-infos-liste {
    list-style: none;
    margin: 0;
    padding: 0;
}

.dashboard-infos-liste li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 9px 0;
    border-bottom: 1px solid var(--border);
    font-size: 13px;
}

.dashboard-infos-liste li:last-child {
    border-bottom: none;
}

.dashboard-infos-liste li span {
    color: var(--text-dim);
}

.dashboard-infos-liste li strong {
    color: var(--text);
    font-weight: 700;
}

.dashboard-valeur-attention {
    color: #e3b341 !important;
}

.dashboard-infos-separateur {
    border-bottom: none !important;
    padding: 2px 0 !important;
}

.dashboard-activite-liste {
    list-style: none;
    margin: 0 0 14px;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
    max-height: 420px;
    overflow-y: auto;
}

.dashboard-activite-liste li {
    display: grid;
    grid-template-columns: 92px 1fr auto;
    align-items: center;
    gap: 14px;
    padding: 10px 4px;
    border-bottom: 1px solid var(--border);
}

.dashboard-activite-liste li:last-child {
    border-bottom: none;
}

.dashboard-activite-liste .badge {
    justify-self: start;
}

.dashboard-activite-texte {
    display: flex;
    flex-direction: column;
    gap: 1px;
    min-width: 0;
}

.dashboard-activite-texte strong {
    font-size: 13px;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dashboard-activite-page {
    font-size: 11px;
    color: var(--accent);
}

.dashboard-activite-description {
    font-size: 11px;
    color: var(--text-dim);
}

.dashboard-activite-meta {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 1px;
    font-size: 11px;
    color: var(--text-dim);
    white-space: nowrap;
}

.dashboard-activite-vide {
    color: var(--text-dim);
    font-size: 13px;
    padding: 10px 4px;
}

.dashboard-voir-tout {
    font-size: 12px;
    color: var(--accent);
    text-decoration: none;
}

.dashboard-voir-tout:hover {
    text-decoration: underline;
}

.dashboard-livraisons-liste {
    display: flex;
    flex-direction: column;
    gap: 14px;
    max-height: 420px;
    overflow-y: auto;
}

.dashboard-livraison-groupe {
    border-radius: 8px;
    padding: 10px 14px;
    border-left: 3px solid var(--border);
}

.dashboard-livraison-titre {
    font-size: 12px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 8px;
}

.dashboard-livraison-refs {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.dashboard-livraison-ref {
    display: inline-block;
    background: rgba(var(--panel-rgb), 0.7);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 3px 9px;
    font-size: 11px;
    color: var(--text-dim);
}

@media (max-width: 900px) {
    .dashboard-grille {
        grid-template-columns: 1fr;
    }

    .dashboard-activite-liste li {
        grid-template-columns: 1fr;
        row-gap: 4px;
    }

    .dashboard-activite-meta {
        align-items: flex-start;
    }
}

/* Marque (logo + nom de l'application) dans la barre du haut */

.marque-app {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-left: 0;
    text-decoration: none;
    color: var(--text);
    font-weight: 600;
    font-size: 13px;
    letter-spacing: 0.01em;
}

.userbar-gauche .marque-app {
    margin-left: 0;
}

.marque-app:hover,
.marque-app.actif {
    color: var(--accent);
}

.marque-logo {
    width: 22px;
    height: 22px;
    border-radius: 6px;
    display: block;
    flex-shrink: 0;
}

.marque-separateur {
    width: 1px;
    height: 18px;
    background: var(--border);
}

/* Page de connexion */

.page-connexion {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    padding: 24px;
    box-sizing: border-box;
}

.connexion-fond {
    position: fixed;
    inset: 0;
    z-index: 0;
    overflow: hidden;
    background: var(--bg);
}

.connexion-blob {
    position: absolute;
    width: 440px;
    height: 440px;
    border-radius: 50%;
    filter: blur(100px);
    opacity: 0.25;
}

.connexion-blob.blob-rec { background: rgb(var(--grp-rec)); top: -140px; left: -120px; }
.connexion-blob.blob-preprod { background: rgb(var(--grp-preprod)); bottom: -160px; left: 30%; }
.connexion-blob.blob-prod { background: rgb(var(--grp-prod)); top: 10%; right: -140px; }

.connexion-carte {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 380px;
    background: rgba(var(--panel-rgb), 0.78);
    backdrop-filter: blur(18px);
    border: 1px solid var(--border);
    border-radius: 18px;
    padding: 44px 38px 36px;
    box-shadow: 0 25px 70px rgba(0, 0, 0, 0.45);
    text-align: center;
    box-sizing: border-box;
}

.connexion-logo {
    display: flex;
    justify-content: center;
}

.connexion-logo img {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
}

.connexion-titre {
    margin: 18px 0 4px;
    font-size: 19px;
    color: var(--text);
}

.connexion-soustitre {
    margin: 0 0 28px;
    font-size: 13px;
    color: var(--text-dim);
}

.connexion-form {
    text-align: left;
}

.connexion-form .form-group {
    margin-bottom: 16px;
}

.connexion-form .form-group:last-of-type {
    margin-bottom: 22px;
}

.connexion-bouton {
    width: 100%;
    padding: 11px;
    font-size: 14px;
    font-weight: 600;
    border-radius: 10px;
}

@media (max-width: 480px) {
    .connexion-carte {
        padding: 32px 22px;
    }
}

/* Consultation d'un document */

.document-detail-mise-en-page {
    display: grid;
    grid-template-columns: 1.6fr 1fr;
    gap: 20px;
    align-items: start;
    margin-top: 16px;
}

.document-detail-panneau {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 20px;
}

.document-detail-apercu {
    min-height: 420px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px;
}

.document-apercu-image {
    max-width: 100%;
    max-height: 560px;
    border-radius: 6px;
    object-fit: contain;
}

.document-apercu-pdf {
    width: 100%;
    height: 560px;
    border: none;
    border-radius: 6px;
}

.document-apercu-indisponible {
    text-align: center;
    color: var(--text-dim);
    padding: 40px 20px;
}

.document-apercu-icone {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 72px;
    height: 72px;
    border-radius: 14px;
    background: rgba(var(--panel-rgb), 0.6);
    border: 1px solid var(--border);
    color: var(--accent);
    font-weight: 700;
    font-size: 14px;
    margin-bottom: 16px;
}

.document-apercu-indisponible p {
    margin: 0 0 18px;
}

.document-detail-badge {
    font-size: 12px;
}

.document-detail-description {
    margin: 14px 0 20px;
    color: var(--text);
    line-height: 1.5;
}

.document-detail-description-vide {
    color: var(--text-dim);
    font-style: italic;
}

.document-detail-meta {
    margin: 0;
}

.document-detail-meta dt {
    color: var(--text-dim);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-top: 14px;
}

.document-detail-meta dt:first-child {
    margin-top: 0;
}

.document-detail-meta dd {
    margin: 4px 0 0;
    color: var(--text);
    font-size: 13px;
}

.document-detail-nom-fichier {
    word-break: break-all;
}

.document-actions-cellule {
    display: flex;
    align-items: center;
    gap: 14px;
}

@media (max-width: 800px) {
    .document-detail-mise-en-page {
        grid-template-columns: 1fr;
    }
}
