/* BddTech2026 — Styles applicatifs avec thèmes
   ============================================
   Les thèmes sont appliqués via [data-theme="…"] sur <html>.
   Bootstrap 5.3 reçoit data-bs-theme="dark" pour cohérence.
   Thèmes : light (défaut), dark, forest, ocean
*/

/* ===== Thème clair (défaut) ===== */
:root,
[data-theme="light"] {
    --brand:        #3C3489;
    --brand-light:  #EEEDFE;
    --brand-text:   #26215C;
    --warm:         #BA7517;
    --warm-light:   #FAEEDA;
    --teal:         #0F6E56;
    --teal-light:   #E1F5EE;
    --coral:        #993C1D;
    --coral-light:  #FAECE7;

    --page-bg:      #F8F7F2;
    --surface:      #FFFFFF;
    --surface-alt:  #F8F7F2;
    --border:       #E0DED7;
    --text:         #2C2C2A;
    --text-muted:   #6F6E6A;
    --shadow:       0 1px 2px rgba(0,0,0,.05);
    --sidebar-bg:   #FFFFFF;
    --header-bg:    #FFFFFF;

    /* Remappage Bootstrap pour cohérence des composants natifs */
    --bs-body-bg:        var(--page-bg);
    --bs-body-color:     var(--text);
    --bs-border-color:   var(--border);
    --bs-secondary-bg:   var(--surface-alt);
    --bs-tertiary-bg:    var(--surface-alt);
    --bs-emphasis-color: var(--text);
}

/* ===== Mode sombre ===== */
[data-theme="dark"] {
    --brand:        #8780E6;
    --brand-light:  #2A2660;
    --brand-text:   #C7C2FF;
    --warm:         #E5A75D;
    --warm-light:   #4A3920;
    --teal:         #4DBFA0;
    --teal-light:   #1B3D34;
    --coral:        #D87560;
    --coral-light:  #3D241A;

    --page-bg:      #15151A;
    --surface:      #1F1F26;
    --surface-alt:  #2A2A32;
    --border:       #3A3A45;
    --text:         #E5E5E8;
    --text-muted:   #A0A0AA;
    --shadow:       0 1px 2px rgba(0,0,0,.4);
    --sidebar-bg:   #1A1A20;
    --header-bg:    #1F1F26;

    /* Remappage Bootstrap — surcharge le dark mode natif de Bootstrap 5.3 */
    --bs-body-bg:        var(--page-bg);
    --bs-body-color:     var(--text);
    --bs-border-color:   var(--border);
    --bs-secondary-bg:   var(--surface-alt);
    --bs-tertiary-bg:    var(--surface-alt);
    --bs-emphasis-color: var(--text);
}

/* Surcharges spécifiques Bootstrap quand data-bs-theme="dark" est appliqué */
[data-bs-theme="dark"] {
    --bs-body-bg:      var(--page-bg);
    --bs-body-color:   var(--text);
    --bs-border-color: var(--border);
}
[data-theme="dark"] .card,
[data-bs-theme="dark"] .card { background-color: var(--surface); color: var(--text); }
[data-theme="dark"] .table,
[data-bs-theme="dark"] .table {
    --bs-table-bg: var(--surface);
    --bs-table-color: var(--text);
    --bs-table-border-color: var(--border);
    --bs-table-hover-bg: var(--surface-alt);
    --bs-table-hover-color: var(--text);
    color: var(--text);
}
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select,
[data-bs-theme="dark"] .form-control,
[data-bs-theme="dark"] .form-select {
    background-color: var(--surface);
    border-color: var(--border);
    color: var(--text);
}
[data-theme="dark"] .alert-light,
[data-bs-theme="dark"] .alert-light {
    background-color: var(--surface-alt);
    color: var(--text);
    border-color: var(--border);
}
[data-theme="dark"] .btn-close,
[data-bs-theme="dark"] .btn-close {
    filter: invert(1) grayscale(100%) brightness(200%);
}

/* ===== Thème Forêt (vert) ===== */
[data-theme="forest"] {
    --brand:        #2D6A4F;
    --brand-light:  #D8F3DC;
    --brand-text:   #1B4332;
    --warm:         #BB7E3F;
    --warm-light:   #F8EBD8;
    --teal:         #1B6E5E;
    --teal-light:   #DBF3EC;
    --coral:        #A0522D;
    --coral-light:  #F5E2D6;

    --page-bg:      #F5F7F3;
    --surface:      #FFFFFF;
    --surface-alt:  #ECF2EA;
    --border:       #D5DDD0;
    --text:         #1B2A24;
    --text-muted:   #6A746E;
    --shadow:       0 1px 2px rgba(45,106,79,.08);
    --sidebar-bg:   #FFFFFF;
    --header-bg:    #FFFFFF;

    --bs-body-bg:      var(--page-bg);
    --bs-body-color:   var(--text);
    --bs-border-color: var(--border);
    --bs-secondary-bg: var(--surface-alt);
    --bs-tertiary-bg:  var(--surface-alt);
}

/* ===== Thème Océan (bleu) ===== */
[data-theme="ocean"] {
    --brand:        #1E5F8E;
    --brand-light:  #E1ECF5;
    --brand-text:   #0E3C5C;
    --warm:         #B07A35;
    --warm-light:   #F8EBD8;
    --teal:         #0E7C7B;
    --teal-light:   #D9F0EF;
    --coral:        #C25B47;
    --coral-light:  #F8E1DC;

    --page-bg:      #F2F6FA;
    --surface:      #FFFFFF;
    --surface-alt:  #E9EFF5;
    --border:       #D2DCE6;
    --text:         #1E2A38;
    --text-muted:   #6B7785;
    --shadow:       0 1px 2px rgba(30,95,142,.08);
    --sidebar-bg:   #FFFFFF;
    --header-bg:    #FFFFFF;

    --bs-body-bg:      var(--page-bg);
    --bs-body-color:   var(--text);
    --bs-border-color: var(--border);
    --bs-secondary-bg: var(--surface-alt);
    --bs-tertiary-bg:  var(--surface-alt);
}

/* ===== Base ===== */
body {
    background: var(--page-bg);
    color: var(--text);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
                 "Helvetica Neue", Arial, sans-serif;
    min-height: 100vh;
    transition: background-color .2s ease, color .2s ease;
}

/* Transitions sur les éléments thématisés pour un changement fluide */
.card, .app-sidebar, .app-header, .table, .form-control,
.form-select, .alert, .btn, .badge {
    transition: background-color .2s ease, border-color .2s ease, color .2s ease;
}

/* ===== Layout principal ===== */
.app-wrapper { display: flex; min-height: 100vh; }

.app-sidebar {
    width: 260px;
    background: var(--sidebar-bg);
    border-right: 1px solid var(--border);
    flex-shrink: 0;
    transition: transform .2s ease, background-color .2s ease;
}

.app-sidebar-header {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: .5rem;
}
.app-sidebar-header .brand {
    font-weight: 600;
    font-size: 1.05rem;
    color: var(--brand);
    text-decoration: none;
}

.app-nav {
    padding: 1rem 0;
    list-style: none;
    margin: 0;
}
.app-nav li { margin: 0; }
.app-nav .nav-link {
    display: flex;
    align-items: center;
    gap: .65rem;
    padding: .55rem 1.25rem;
    color: var(--text);
    text-decoration: none;
    border-left: 3px solid transparent;
    font-size: .94rem;
}
.app-nav .nav-link:hover { background: var(--surface-alt); }
.app-nav .nav-link.active {
    background: var(--brand-light);
    color: var(--brand-text);
    border-left-color: var(--brand);
    font-weight: 500;
}
.app-nav .nav-section-toggle {
    cursor: pointer;
    justify-content: space-between;
}
.app-nav .submenu {
    list-style: none;
    padding-left: 0;
    background: var(--surface-alt);
}
.app-nav .submenu .nav-link {
    padding-left: 2.7rem;
    font-size: .88rem;
}

.app-main { flex: 1 1 auto; min-width: 0; }

.app-header {
    background: var(--header-bg);
    border-bottom: 1px solid var(--border);
    padding: .65rem 1.25rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.app-header .toggle-sidebar {
    background: none; border: none;
    font-size: 1.3rem;
    cursor: pointer;
    color: var(--text);
    display: none;
}
.app-content { padding: 1.5rem; max-width: 1400px; }

.page-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.25rem;
    gap: 1rem;
    flex-wrap: wrap;
}
.page-header h1 {
    font-size: 1.5rem;
    margin: 0;
    color: var(--text);
}

/* ===== Cards ===== */
.card {
    border: 1px solid var(--border);
    background: var(--surface);
    color: var(--text);
}
.card-header {
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    font-weight: 500;
    color: var(--text);
}
.card-header.bg-light {
    background: var(--surface-alt) !important;
}

/* ===== Tables ===== */
.table {
    --bs-table-bg: var(--surface);
    --bs-table-color: var(--text);
    --bs-table-border-color: var(--border);
    color: var(--text);
}
.table thead th {
    background: var(--surface-alt);
    border-bottom: 1px solid var(--border);
    font-weight: 500;
    font-size: .88rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: .03em;
}
.table-hover > tbody > tr:hover > * {
    background: var(--surface-alt);
    color: var(--text);
}
.table-row-link { cursor: pointer; }

/* ===== Boutons ===== */
.btn-primary {
    background: var(--brand);
    border-color: var(--brand);
    color: #fff;
}
.btn-primary:hover, .btn-primary:focus {
    background: var(--brand-text);
    border-color: var(--brand-text);
    color: #fff;
}
.btn-outline-primary {
    color: var(--brand);
    border-color: var(--brand);
}
.btn-outline-primary:hover {
    background: var(--brand);
    border-color: var(--brand);
    color: #fff;
}
.btn-outline-secondary {
    color: var(--text);
    border-color: var(--border);
}
.btn-outline-secondary:hover {
    background: var(--surface-alt);
    color: var(--text);
    border-color: var(--border);
}

/* ===== Formulaires ===== */
.form-control, .form-select {
    background-color: var(--surface);
    border-color: var(--border);
    color: var(--text);
}
.form-control:focus, .form-select:focus {
    background-color: var(--surface);
    border-color: var(--brand);
    color: var(--text);
    box-shadow: 0 0 0 .2rem var(--brand-light);
}
.form-label {
    font-weight: 500;
    font-size: .9rem;
    color: var(--text);
}
.form-text {
    color: var(--text-muted);
}
.required-mark { color: #c0392b; }

/* ===== Badges d'état ===== */
.status-badge {
    display: inline-block;
    padding: .25em .6em;
    border-radius: 4px;
    font-size: .8rem;
    font-weight: 500;
}
.status-active     { background: var(--teal-light);  color: var(--teal); }
.status-archived   { background: var(--surface-alt); color: var(--text-muted); }
.status-test       { background: var(--warm-light);  color: var(--warm); }
.status-in-progress{ background: var(--brand-light); color: var(--brand-text); }

/* ===== Drag & drop ===== */
.sortable-handle {
    cursor: grab;
    color: var(--text-muted);
    padding: 0 .5rem;
}
.sortable-handle:active { cursor: grabbing; }

.sortable-ghost {
    opacity: .4;
    background: var(--brand-light) !important;
}
.sortable-chosen {
    background: var(--surface);
}

.menu-tree, .menu-tree ul {
    list-style: none;
    padding-left: 0;
}
.menu-tree ul { padding-left: 2rem; }
.menu-tree-item {
    display: flex;
    align-items: center;
    padding: .5rem .75rem;
    margin: .25rem 0;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 4px;
    gap: .5rem;
}
.menu-tree-item .label { flex: 1 1 auto; }
.menu-tree-item .actions { display: flex; gap: .25rem; }

/* ===== Sélecteur de thème (topbar) — vanilla dropdown ===== */
.theme-switcher {
    position: relative;
}
.theme-toggle {
    cursor: pointer;
}
.theme-menu {
    position: absolute;
    top: calc(100% + 6px);
    right: 0;
    min-width: 220px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 6px;
    box-shadow: 0 4px 12px rgba(0,0,0,.15);
    padding: .35rem 0;
    display: none !important;
    z-index: 1050;
}
.theme-menu.show { display: block !important; }
.theme-menu-header {
    padding: .35rem .85rem;
    font-size: .75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--text-muted);
}
.theme-option {
    display: flex;
    align-items: center;
    gap: .65rem;
    padding: .5rem .85rem;
    width: 100%;
    background: none;
    border: 0;
    text-align: left;
    color: var(--text);
    font-size: .9rem;
    cursor: pointer;
    transition: background-color .15s ease;
}
.theme-option:hover { background: var(--surface-alt); }
.theme-option.is-active {
    background: var(--brand-light);
    color: var(--brand-text);
    font-weight: 500;
}
.theme-check {
    visibility: hidden;
    margin-left: auto;
}
.theme-option.is-active .theme-check { visibility: visible; }

.theme-swatch {
    width: 20px; height: 20px;
    border-radius: 50%;
    border: 2px solid rgba(0,0,0,.06);
    flex-shrink: 0;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.4);
}
.theme-swatch--light  { background: linear-gradient(135deg, #3C3489 50%, #F8F7F2 50%); }
.theme-swatch--dark   { background: linear-gradient(135deg, #8780E6 50%, #1F1F26 50%); }
.theme-swatch--forest { background: linear-gradient(135deg, #2D6A4F 50%, #F5F7F3 50%); }
.theme-swatch--ocean  { background: linear-gradient(135deg, #1E5F8E 50%, #F2F6FA 50%); }

/* ===== Responsive ===== */
@media (max-width: 768px) {
    .app-sidebar {
        position: fixed;
        top: 0;
        left: 0;
        height: 100vh;
        z-index: 1050;
        transform: translateX(-100%);
        box-shadow: 0 0 1rem rgba(0,0,0,.15);
    }
    .app-sidebar.open { transform: translateX(0); }
    .app-header .toggle-sidebar { display: inline-flex; }
    .app-content { padding: 1rem; }
    .sidebar-backdrop {
        position: fixed; inset: 0;
        background: rgba(0,0,0,.45);
        z-index: 1040;
        display: none;
    }
    .sidebar-backdrop.show { display: block; }
}

/* ===== Utilitaires ===== */
.text-muted-sm { color: var(--text-muted); font-size: .85rem; }
.text-muted { color: var(--text-muted) !important; }
.empty-state {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--text-muted);
}
.empty-state i { font-size: 3rem; opacity: .3; margin-bottom: 1rem; }

.code-inline {
    font-family: ui-monospace, "SF Mono", Menlo, monospace;
    background: var(--surface-alt);
    padding: .1em .35em;
    border-radius: 3px;
    font-size: .88em;
    color: var(--text);
}

/* Modal / dropdown — fond cohérent avec le thème */
.dropdown-menu {
    background: var(--surface);
    border-color: var(--border);
    color: var(--text);
}
.dropdown-item { color: var(--text); }
.dropdown-item:hover, .dropdown-item:focus {
    background: var(--surface-alt);
    color: var(--text);
}

/* Caret rotation */
.caret { transition: transform .15s ease; }
.caret.rotate-180 { transform: rotate(180deg); }

/* Alerts en mode sombre */
[data-theme="dark"] .alert-light {
    background: var(--surface-alt);
    color: var(--text);
    border-color: var(--border);
}

/* Page de connexion / setup — fond cohérent */
.auth-bg {
    background: var(--page-bg);
}
.auth-card {
    background: var(--surface);
    border: 1px solid var(--border);
}

/* TinyMCE — bordure pour cohérence */
.tox-tinymce { border-color: var(--border) !important; }
