/* ════════════════════════════════════════════════════════════════════
   LogBook - Salott-IT — Thème (Light + Dark)
   Couleurs Salott-IT Engineering : navy primary + warm orange accent.
   ════════════════════════════════════════════════════════════════════ */

/* ─── Variables CSS — Theme Light ─────────────────────────────────── */
:root {
    /* Salott-IT brand: navy primary + warm orange accent
       Variables historiquement nommées --hki-* — valeurs adaptées Salott-IT. */
    --hki-purple:    #0B2559;
    --hki-purple-dk: #06183d;
    --hki-purple-lt: #e6ecf5;
    --hki-coral:     #FF6B35;
    --hki-teal:      #4db748;
    --hki-yellow:    #F59E0B;
    --hki-gray:      #6b7a99;
    --radius:        0.5rem;

    --purple: #0B2559;
    --green:  #4db748;
    --ks-purple-horizon: #0B2559;
    --ks-coral-sunshine: #FF6B35;
    --lb-gold:        #c8a84b;
    --lb-gold-dim:    rgba(200,168,75,0.18);
    --lb-gold-border: rgba(200,168,75,0.30);
    --lb-cream:       #f0ead6;
    --ks-bg-card:     #ffffff;
    --ks-bg-body:     #f8f9fa;
    --ks-text-main:   #212529;
    --ks-text-muted:  #6c757d;
    --ks-border-soft: rgba(0,0,0,0.08);
}

body {
    font-family: 'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;
    font-size: 0.875rem;
}

/* ─── Topbar ──────────────────────────────────────────────────────── */
.lb-topbar {
    background-color: #ffffff;
    border-bottom: 1px solid rgba(0,0,0,0.06);
    padding: 0.35rem 1rem;
    font-size: 0.78rem;
}
.lb-topbar .topbar-institution {
    font-weight: 800;
    font-size: 0.9rem;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: var(--hki-purple);
}
.lb-topbar .topbar-logo {
    height: 51px;
    width: auto;
    max-width: 360px;
    object-fit: contain;
    display: block;
}
.lb-topbar .topbar-theme-btns,
.lb-topbar .topbar-lang-btns {
    display: inline-flex;
    background: #f8f9fa;
    border: 1px solid rgba(0,0,0,0.08);
    border-radius: 6px;
    overflow: hidden;
}
.lb-topbar .topbar-icon-btn,
.lb-topbar .topbar-lang-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 28px;
    padding: 0 8px;
    border: none;
    background: transparent;
    color: #6c757d;
    text-decoration: none;
    font-size: 0.8rem;
    font-weight: 600;
    transition: background 0.15s;
}
.lb-topbar .topbar-icon-btn.active,
.lb-topbar .topbar-icon-btn:hover,
.lb-topbar .topbar-lang-btn.active,
.lb-topbar .topbar-lang-btn:hover {
    background: var(--hki-purple-lt);
    color: var(--hki-purple);
}
.lb-topbar .topbar-sep {
    width: 1px;
    height: 20px;
    background: rgba(0,0,0,0.1);
}
.lb-topbar .topbar-entity-select {
    appearance: none;
    background: #f8f9fa;
    border: 1px solid rgba(0,0,0,0.08);
    border-radius: 6px;
    color: #212529;
    font-size: 0.75rem;
    font-weight: 700;
    padding: 3px 22px 3px 8px;
    height: 28px;
    cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%235B6770'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 6px center;
    max-width: 180px;
}
.lb-topbar .topbar-entity-select:hover {
    border-color: var(--hki-purple);
}

/* ─── Navbar (HKI Purple) ─────────────────────────────────────────── */
.navbar-custom {
    background-color: var(--hki-purple) !important;
    border-bottom: 3px solid var(--hki-coral);
    padding-top: 0.3rem;
    padding-bottom: 0.3rem;
}
.navbar-custom,
.navbar-custom .navbar-brand,
.navbar-custom .nav-link,
.navbar-custom .nav-link.dropdown-toggle,
.navbar-custom .dropdown-toggle {
    color: rgba(255, 255, 255, 0.9) !important;
}
.navbar-custom .navbar-brand:hover,
.navbar-custom .nav-link:hover,
.navbar-custom .nav-link:focus {
    color: #ffffff !important;
}
.navbar-custom .nav-link.active {
    color: #ffffff !important;
    background-color: rgba(255, 255, 255, 0.15) !important;
    box-shadow: inset 0 -2px 0 var(--hki-coral);
}
.navbar-custom .nav-link {
    font-size: 0.82rem;
    font-weight: 500;
    padding: 0.3rem 0.6rem !important;
    border-radius: 0.375rem;
    transition: background-color 0.15s;
    white-space: nowrap;
}
.navbar-custom .nav-link:hover {
    background-color: rgba(255, 255, 255, 0.12) !important;
}
.navbar-custom .navbar-toggler {
    border-color: rgba(255, 255, 255, 0.35);
}
.navbar-custom .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255,255,255,0.85%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* Dropdown menus — always light */
.navbar-custom .dropdown-menu {
    background-color: #ffffff !important;
    border: 1px solid rgba(0,0,0,0.08) !important;
    box-shadow: 0 6px 20px rgba(0,0,0,0.14);
    border-top: 3px solid var(--hki-purple) !important;
}
.navbar-custom .dropdown-item { color: #212529 !important; font-size: 0.85rem; }
.navbar-custom .dropdown-item:hover { background-color: var(--hki-purple-lt) !important; color: var(--hki-purple) !important; }
.navbar-custom .dropdown-header { color: var(--hki-gray) !important; font-size: 0.75rem; text-transform: uppercase; }
.navbar-custom .dropdown-divider { border-color: rgba(11,37,89,0.15) !important; }
.navbar-custom .dropdown-item.text-primary { color: var(--hki-purple) !important; }
.navbar-custom .dropdown-item.text-danger { color: #dc3545 !important; }
.navbar-custom .dropdown-item.text-muted { color: var(--hki-gray) !important; }

.navbar-brand { font-size: 0.95rem; font-weight: 700; }

.badge-alert {
    background-color: var(--hki-coral) !important;
    color: #fff;
    font-size: 0.65rem;
    border-radius: 10px;
    padding: 2px 6px;
    position: relative;
    top: -6px;
}

/* ─── Boutons utilitaires ─────────────────────────────────────────── */
.btn-hki-primary {
    background-color: var(--hki-purple);
    border-color: var(--hki-purple);
    color: #fff;
    border-radius: 50px;
}
.btn-hki-primary:hover {
    background-color: var(--hki-purple-dk);
    border-color: var(--hki-purple-dk);
    color: #fff;
}

/* ─── Toasts globaux ──────────────────────────────────────────────── */
#appToastStack .toast { border-radius: 12px; min-width: 300px; }
#appToastStack .toast.toast-success { background: linear-gradient(135deg, #198754, #20c997); color: #fff; }
#appToastStack .toast.toast-danger  { background: linear-gradient(135deg, #dc3545, #e74c3c); color: #fff; }
#appToastStack .toast.toast-warning { background: linear-gradient(135deg, #fd7e14, #ffc107); color: #212529; }
#appToastStack .toast.toast-warning .btn-close { filter: none; }
#appToastStack .toast.toast-info    { background: linear-gradient(135deg, #0d6efd, #6f42c1); color: #fff; }


/* ════════════════════════════════════════════════════════════════════
   DARK THEME — Inspired by deep navy-purple UI
   ════════════════════════════════════════════════════════════════════ */

[data-bs-theme="dark"] {
    --ks-bg-card:     #1a1a30;
    --ks-bg-body:     #0f0f1e;
    --ks-text-main:   #dde0f0;
    --ks-text-muted:  #7878a0;
    --ks-border-soft: rgba(255,255,255,0.07);
    --hki-purple-lt:  rgba(192,57,43,0.15);
}

[data-bs-theme="dark"] body { background-color: #0f0f1e; color: #dde0f0; }

[data-bs-theme="dark"] .lb-topbar {
    background-color: #0d0d1c;
    border-bottom: 1px solid rgba(255,255,255,0.05);
}
[data-bs-theme="dark"] .lb-topbar .topbar-institution { color: #c084fc; }
[data-bs-theme="dark"] .lb-topbar .topbar-logo {
    background: #ffffff;
    border-radius: 6px;
    padding: 2px 6px;
}
[data-bs-theme="dark"] .lb-topbar .topbar-theme-btns,
[data-bs-theme="dark"] .lb-topbar .topbar-lang-btns {
    background: rgba(255,255,255,0.05);
    border-color: rgba(255,255,255,0.10);
}
[data-bs-theme="dark"] .lb-topbar .topbar-icon-btn,
[data-bs-theme="dark"] .lb-topbar .topbar-lang-btn { color: rgba(255,255,255,0.45); }
[data-bs-theme="dark"] .lb-topbar .topbar-icon-btn.active,
[data-bs-theme="dark"] .lb-topbar .topbar-lang-btn.active {
    background: rgba(192,57,43,0.30);
    color: #ff8a80;
}
[data-bs-theme="dark"] .lb-topbar .topbar-icon-btn:hover,
[data-bs-theme="dark"] .lb-topbar .topbar-lang-btn:hover {
    background: rgba(255,255,255,0.08);
    color: #dde0f0;
}
[data-bs-theme="dark"] .lb-topbar .topbar-entity-select {
    background-color: rgba(255,255,255,0.05);
    border-color: rgba(255,255,255,0.10);
    color: #dde0f0;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23aaaacc'/%3E%3C/svg%3E");
}

[data-bs-theme="dark"] .navbar-custom {
    background-color: #13132a !important;
    border-bottom-color: #c0392b;
}
[data-bs-theme="dark"] .navbar-custom .nav-link.active {
    background-color: rgba(192,57,43,0.22) !important;
    box-shadow: inset 0 -2px 0 #c0392b;
    color: #fff !important;
}
[data-bs-theme="dark"] .navbar-custom .nav-link:hover {
    background-color: rgba(192,57,43,0.12) !important;
}
[data-bs-theme="dark"] .navbar-custom .dropdown-menu {
    background-color: #1e1e38 !important;
    border-color: rgba(255,255,255,0.07) !important;
    border-top: 3px solid #c0392b !important;
    box-shadow: 0 8px 24px rgba(0,0,0,0.5);
}
[data-bs-theme="dark"] .navbar-custom .dropdown-item { color: #c8cce8 !important; }
[data-bs-theme="dark"] .navbar-custom .dropdown-item:hover {
    background-color: rgba(192,57,43,0.15) !important;
    color: #ff8a80 !important;
}
[data-bs-theme="dark"] .navbar-custom .dropdown-header { color: #7878a0 !important; }
[data-bs-theme="dark"] .navbar-custom .dropdown-divider { border-color: rgba(255,255,255,0.08) !important; }
[data-bs-theme="dark"] .navbar-custom .dropdown-item.text-danger { color: #ff6b6b !important; }

[data-bs-theme="dark"] .card {
    background-color: #1a1a30;
    border-color: rgba(255,255,255,0.07);
}
[data-bs-theme="dark"] .card-header {
    background-color: #16162a;
    border-bottom-color: rgba(255,255,255,0.07);
}
[data-bs-theme="dark"] .card-footer {
    background-color: #16162a;
    border-top-color: rgba(255,255,255,0.07);
}

[data-bs-theme="dark"] .table {
    --bs-table-color:       #dde0f0;
    --bs-table-bg:          transparent;
    --bs-table-striped-bg:  rgba(255,255,255,0.03);
    --bs-table-hover-bg:    rgba(255,255,255,0.05);
    --bs-table-border-color: rgba(255,255,255,0.07);
}
[data-bs-theme="dark"] .keller-table thead th {
    background: linear-gradient(135deg, #1f0a35, #2d0d45) !important;
    color: #e8c8f8 !important;
    border-bottom-color: rgba(192,57,43,0.4) !important;
}
[data-bs-theme="dark"] .table-light { --bs-table-bg: rgba(255,255,255,0.04); }

[data-bs-theme="dark"] .form-control,
[data-bs-theme="dark"] .form-select {
    background-color: #13132a;
    border-color: rgba(255,255,255,0.12);
    color: #dde0f0;
}
[data-bs-theme="dark"] .form-control::placeholder { color: #555570; }
[data-bs-theme="dark"] .form-control:focus,
[data-bs-theme="dark"] .form-select:focus {
    background-color: #1a1a38;
    border-color: #c0392b;
    color: #dde0f0;
    box-shadow: 0 0 0 0.2rem rgba(192,57,43,0.20);
}
[data-bs-theme="dark"] .input-group-text {
    background-color: #1e1e38;
    border-color: rgba(255,255,255,0.12);
    color: #7878a0;
}
[data-bs-theme="dark"] .form-check-input {
    background-color: #1a1a38;
    border-color: rgba(255,255,255,0.20);
}
[data-bs-theme="dark"] .form-check-input:checked { background-color: #c0392b; border-color: #c0392b; }

[data-bs-theme="dark"] .btn-outline-secondary {
    border-color: rgba(255,255,255,0.20);
    color: #aaaacc;
}
[data-bs-theme="dark"] .btn-outline-secondary:hover {
    background-color: rgba(255,255,255,0.08);
    border-color: rgba(255,255,255,0.30);
    color: #dde0f0;
}
[data-bs-theme="dark"] .btn-light {
    background-color: rgba(255,255,255,0.08);
    border-color: rgba(255,255,255,0.12);
    color: #dde0f0;
}

[data-bs-theme="dark"] .list-group-item {
    background-color: #1a1a30;
    border-color: rgba(255,255,255,0.07);
    color: #dde0f0;
}
[data-bs-theme="dark"] .list-group-item:hover { background-color: #1e1e38; }
[data-bs-theme="dark"] .list-group-item.active {
    background-color: #c0392b;
    border-color: #c0392b;
}

[data-bs-theme="dark"] .nav-tabs { border-bottom-color: rgba(255,255,255,0.10); }
[data-bs-theme="dark"] .nav-tabs .nav-link { color: #7878a0; border-color: transparent; }
[data-bs-theme="dark"] .nav-tabs .nav-link:hover { color: #c8cce8; border-color: rgba(255,255,255,0.08); }
[data-bs-theme="dark"] .nav-tabs .nav-link.active {
    background-color: #1a1a30;
    border-color: rgba(255,255,255,0.10) rgba(255,255,255,0.10) #1a1a30;
    color: #dde0f0;
}

/* Sous-menus modules */
[data-bs-theme="dark"] .dash-nav,
[data-bs-theme="dark"] .loc-nav,
[data-bs-theme="dark"] .gen-nav,
[data-bs-theme="dark"] .mnt-nav,
[data-bs-theme="dark"] .tcv-nav,
[data-bs-theme="dark"] .rep-nav,
[data-bs-theme="dark"] .adm-nav,
[data-bs-theme="dark"] .dep-nav {
    background: #13132a !important;
    border-bottom-color: rgba(255,255,255,0.08) !important;
}
[data-bs-theme="dark"] .dash-nav .nav-link,
[data-bs-theme="dark"] .loc-nav .nav-link,
[data-bs-theme="dark"] .gen-nav .nav-link,
[data-bs-theme="dark"] .mnt-nav .nav-link,
[data-bs-theme="dark"] .tcv-nav .nav-link,
[data-bs-theme="dark"] .rep-nav .nav-link,
[data-bs-theme="dark"] .adm-nav .nav-link,
[data-bs-theme="dark"] .dep-nav .nav-link {
    color: #7878a0 !important;
    border-bottom-color: transparent !important;
}
[data-bs-theme="dark"] .dash-nav .nav-link:hover,
[data-bs-theme="dark"] .loc-nav .nav-link:hover,
[data-bs-theme="dark"] .gen-nav .nav-link:hover,
[data-bs-theme="dark"] .mnt-nav .nav-link:hover,
[data-bs-theme="dark"] .tcv-nav .nav-link:hover,
[data-bs-theme="dark"] .rep-nav .nav-link:hover,
[data-bs-theme="dark"] .adm-nav .nav-link:hover,
[data-bs-theme="dark"] .dep-nav .nav-link:hover {
    color: #c8cce8 !important;
    background: rgba(255,255,255,0.05) !important;
    border-bottom-color: rgba(192,57,43,0.35) !important;
}
[data-bs-theme="dark"] .dash-nav .nav-link.active,
[data-bs-theme="dark"] .loc-nav .nav-link.active,
[data-bs-theme="dark"] .gen-nav .nav-link.active,
[data-bs-theme="dark"] .mnt-nav .nav-link.active,
[data-bs-theme="dark"] .tcv-nav .nav-link.active,
[data-bs-theme="dark"] .rep-nav .nav-link.active,
[data-bs-theme="dark"] .adm-nav .nav-link.active,
[data-bs-theme="dark"] .dep-nav .nav-link.active {
    color: #ff8a80 !important;
    background: transparent !important;
    border-bottom-color: #c0392b !important;
}
[data-bs-theme="dark"] .dash-nav .nav-link.active i,
[data-bs-theme="dark"] .loc-nav .nav-link.active i,
[data-bs-theme="dark"] .gen-nav .nav-link.active i,
[data-bs-theme="dark"] .mnt-nav .nav-link.active i,
[data-bs-theme="dark"] .tcv-nav .nav-link.active i,
[data-bs-theme="dark"] .rep-nav .nav-link.active i,
[data-bs-theme="dark"] .adm-nav .nav-link.active i,
[data-bs-theme="dark"] .dep-nav .nav-link.active i,
[data-bs-theme="dark"] .dash-nav .nav-link.active i { color: #ff8a80 !important; }

[data-bs-theme="dark"] .badge.bg-light {
    background-color: rgba(255,255,255,0.10) !important;
    color: #c0c8e0 !important;
}
[data-bs-theme="dark"] .badge.bg-secondary {
    background-color: #2a2a48 !important;
    color: #9090b8 !important;
}

[data-bs-theme="dark"] .alert-info    { background-color: rgba(52,152,219,0.12); border-color: rgba(52,152,219,0.30); color: #89c4f4; }
[data-bs-theme="dark"] .alert-warning { background-color: rgba(229,160,32,0.12); border-color: rgba(229,160,32,0.30); color: #f5c842; }
[data-bs-theme="dark"] .alert-danger  { background-color: rgba(192,57,43,0.12);  border-color: rgba(192,57,43,0.30);  color: #ff8a80; }
[data-bs-theme="dark"] .alert-success { background-color: rgba(26,188,156,0.12); border-color: rgba(26,188,156,0.30); color: #1abc9c; }

[data-bs-theme="dark"] .modal-content {
    background-color: #1a1a30;
    border-color: rgba(255,255,255,0.10);
}
[data-bs-theme="dark"] .modal-header { border-bottom-color: rgba(255,255,255,0.08); }
[data-bs-theme="dark"] .modal-footer { border-top-color: rgba(255,255,255,0.08); }

[data-bs-theme="dark"] .dropdown-menu {
    background-color: #1e1e38;
    border-color: rgba(255,255,255,0.08);
}
[data-bs-theme="dark"] .dropdown-item { color: #c8cce8; }
[data-bs-theme="dark"] .dropdown-item:hover { background-color: rgba(192,57,43,0.15); color: #ff8a80; }
[data-bs-theme="dark"] .dropdown-divider { border-color: rgba(255,255,255,0.07); }

[data-bs-theme="dark"] .text-muted   { color: #7878a0 !important; }
[data-bs-theme="dark"] .border       { border-color: rgba(255,255,255,0.07) !important; }
[data-bs-theme="dark"] .border-top,
[data-bs-theme="dark"] .border-bottom { border-color: rgba(255,255,255,0.07) !important; }
[data-bs-theme="dark"] footer        { border-top-color: rgba(255,255,255,0.07) !important; color: #555570; }
[data-bs-theme="dark"] hr            { border-color: rgba(255,255,255,0.08); }
[data-bs-theme="dark"] .bg-white     { background-color: #1a1a30 !important; }
[data-bs-theme="dark"] .bg-light     { background-color: #16162a !important; }
[data-bs-theme="dark"] .shadow-sm    { box-shadow: 0 2px 8px rgba(0,0,0,0.40) !important; }
[data-bs-theme="dark"] .shadow       { box-shadow: 0 4px 16px rgba(0,0,0,0.50) !important; }
[data-bs-theme="dark"] code          { background-color: rgba(255,255,255,0.07); color: #ff8a80; padding: 1px 5px; border-radius: 4px; }


/* ════════════════════════════════════════════════════════════════════
   PWA — Banners install / update / sync (v1.0.07.3a)
   Couleurs HKI : purple #0B2559, coral #F87C56
   ════════════════════════════════════════════════════════════════════ */

/* ── Install banner ── */
.lb-pwa-install-banner {
    position: fixed;
    left: 16px;
    right: 16px;
    bottom: 16px;
    margin: 0 auto;
    max-width: 460px;
    background: #fff;
    border: 1px solid var(--ks-border-soft);
    border-top: 3px solid var(--hki-coral);
    border-radius: 14px;
    box-shadow: 0 12px 36px rgba(122, 65, 131, 0.22);
    padding: 14px 16px;
    display: flex;
    align-items: center;
    gap: 12px;
    z-index: 1080;
    animation: lbPwaSlideUp 0.3s ease-out;
}
@keyframes lbPwaSlideUp {
    from { transform: translateY(110%); opacity: 0; }
    to   { transform: translateY(0);    opacity: 1; }
}
.lb-pwa-install-banner .lb-pwa-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: var(--hki-purple-lt);
    color: var(--hki-purple);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    flex-shrink: 0;
}
.lb-pwa-install-banner .lb-pwa-text {
    flex: 1;
    min-width: 0;
}
.lb-pwa-install-banner .lb-pwa-title {
    font-size: 0.9rem;
    font-weight: 700;
    color: #212529;
    line-height: 1.2;
}
.lb-pwa-install-banner .lb-pwa-sub {
    font-size: 0.78rem;
    color: var(--hki-gray);
    margin-top: 2px;
    line-height: 1.35;
}
.lb-pwa-install-banner .lb-pwa-actions {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
}
.lb-pwa-btn {
    border: none;
    border-radius: 50px;
    padding: 6px 14px;
    font-size: 0.8rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.15s;
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.lb-pwa-btn-primary {
    background: var(--hki-purple);
    color: #fff;
}
.lb-pwa-btn-primary:hover { background: var(--hki-purple-dk); }
.lb-pwa-btn-ghost {
    background: transparent;
    color: var(--hki-gray);
}
.lb-pwa-btn-ghost:hover { background: rgba(0, 0, 0, 0.04); color: var(--hki-purple); }

/* ── Update banner (top-fixed) ── */
.lb-pwa-update-banner {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background: linear-gradient(135deg, var(--hki-purple), var(--hki-purple-dk));
    color: #fff;
    padding: 10px 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    z-index: 1090;
    box-shadow: 0 4px 18px rgba(0,0,0,0.18);
    font-size: 0.88rem;
    animation: lbPwaSlideDown 0.3s ease-out;
}
@keyframes lbPwaSlideDown {
    from { transform: translateY(-100%); }
    to   { transform: translateY(0); }
}
.lb-pwa-update-banner .lb-pwa-update-text { display: flex; align-items: center; }
.lb-pwa-update-banner .lb-pwa-btn {
    background: #fff;
    color: var(--hki-purple);
}
.lb-pwa-update-banner .lb-pwa-btn:hover { background: var(--hki-purple-lt); }

/* ── Sync banner persistant (rappel saisies en attente) ── */
.lb-sync-banner {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background: linear-gradient(135deg, var(--hki-coral), #d96b48);
    color: #fff;
    padding: 10px 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    z-index: 1085;
    box-shadow: 0 3px 14px rgba(248, 124, 86, 0.35);
    font-size: 0.88rem;
    animation: lbPwaSlideDown 0.25s ease-out;
}
.lb-sync-banner .lb-sync-text {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
    min-width: 0;
}
.lb-sync-banner .lb-sync-icon {
    font-size: 1.1rem;
    animation: lbSyncPulse 2s ease-in-out infinite;
}
@keyframes lbSyncPulse {
    0%, 100% { opacity: 1; }
    50%      { opacity: 0.5; }
}
.lb-sync-banner .lb-sync-count {
    background: rgba(255, 255, 255, 0.22);
    border: 1px solid rgba(255, 255, 255, 0.35);
    padding: 1px 8px;
    border-radius: 50px;
    font-weight: 700;
    font-size: 0.78rem;
}
.lb-sync-banner .lb-sync-actions {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
}
.lb-sync-banner .lb-sync-btn {
    background: #fff;
    color: var(--hki-coral);
    border: none;
    border-radius: 50px;
    padding: 5px 12px;
    font-weight: 600;
    font-size: 0.82rem;
    cursor: pointer;
    transition: all 0.15s;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.lb-sync-banner .lb-sync-btn:hover {
    background: #fff7f3;
    transform: translateY(-1px);
}
.lb-sync-banner .lb-sync-btn[disabled] {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}
.lb-sync-banner .lb-sync-btn-ghost {
    background: transparent;
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.5);
}
.lb-sync-banner .lb-sync-btn-ghost:hover {
    background: rgba(255, 255, 255, 0.12);
}

/* ── Network status pill (badge mode hors-ligne) ── */
.lb-net-pill {
    position: fixed;
    bottom: 18px;
    left: 18px;
    background: #fff;
    border: 1px solid var(--ks-border-soft);
    border-radius: 50px;
    padding: 6px 12px 6px 10px;
    box-shadow: 0 4px 14px rgba(0,0,0,0.10);
    display: none;
    align-items: center;
    gap: 6px;
    font-size: 0.78rem;
    font-weight: 600;
    z-index: 1075;
}
.lb-net-pill.is-offline {
    display: inline-flex;
    background: #fff5f4;
    border-color: rgba(220, 53, 69, 0.25);
    color: #b02a37;
}
.lb-net-pill.is-offline .lb-net-dot {
    background: #dc3545;
    animation: lbSyncPulse 1.5s ease-in-out infinite;
}
.lb-net-pill .lb-net-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #198754;
}

/* ── Décalage du contenu quand un banner top est affiché ── */
body.lb-has-top-banner { padding-top: 44px; }

/* ── Dark theme ajustements ── */
[data-bs-theme="dark"] .lb-pwa-install-banner {
    background: #1a1a30;
    border-color: rgba(255,255,255,0.10);
    box-shadow: 0 12px 36px rgba(0,0,0,0.55);
}
[data-bs-theme="dark"] .lb-pwa-install-banner .lb-pwa-title { color: #dde0f0; }
[data-bs-theme="dark"] .lb-pwa-install-banner .lb-pwa-icon {
    background: rgba(192, 132, 252, 0.18);
    color: #c084fc;
}
[data-bs-theme="dark"] .lb-net-pill {
    background: #1a1a30;
    border-color: rgba(255,255,255,0.10);
    color: #dde0f0;
}

/* ── Responsive mobile ── */
@media (max-width: 480px) {
    .lb-pwa-install-banner {
        flex-wrap: wrap;
        padding: 12px;
    }
    .lb-pwa-install-banner .lb-pwa-text { width: 100%; order: 1; }
    .lb-pwa-install-banner .lb-pwa-icon { order: 0; }
    .lb-pwa-install-banner .lb-pwa-actions {
        width: 100%;
        order: 2;
        justify-content: flex-end;
    }
    .lb-sync-banner {
        flex-wrap: wrap;
        gap: 8px;
    }
    .lb-sync-banner .lb-sync-text { width: 100%; }
    .lb-sync-banner .lb-sync-actions {
        width: 100%;
        justify-content: flex-end;
    }
}


/* ════════════════════════════════════════════════════════════════════
   Tables responsive — Cards mobiles (v1.0.07.3b)
   Active sur les tables avec class .lb-table-cards (opt-in non destructif).
   Sur écran < 768px, chaque <tr> devient une card avec libellés inline.
   Pour activer : ajouter class="table lb-table-cards" + data-label="X" sur chaque <td>.
   ════════════════════════════════════════════════════════════════════ */
@media (max-width: 767.98px) {
    .lb-table-cards thead {
        display: none;
    }
    .lb-table-cards,
    .lb-table-cards tbody,
    .lb-table-cards tr,
    .lb-table-cards td {
        display: block;
        width: 100%;
    }
    .lb-table-cards tr {
        background: var(--ks-bg-card, #fff);
        border: 1px solid var(--ks-border-soft, rgba(0,0,0,0.08));
        border-left: 3px solid var(--hki-purple);
        border-radius: 10px;
        margin-bottom: 0.85rem;
        padding: 0.6rem 0.8rem;
        box-shadow: 0 1px 3px rgba(0,0,0,0.04);
    }
    .lb-table-cards td {
        border: none !important;
        padding: 0.4rem 0;
        display: flex;
        justify-content: space-between;
        align-items: center;
        gap: 0.75rem;
        font-size: 0.85rem;
        text-align: right;
    }
    .lb-table-cards td::before {
        content: attr(data-label);
        font-weight: 600;
        color: var(--hki-gray);
        text-transform: uppercase;
        font-size: 0.7rem;
        letter-spacing: 0.04em;
        text-align: left;
        flex-shrink: 0;
    }
    .lb-table-cards td:not([data-label])::before {
        content: '';
    }
    .lb-table-cards td.lb-card-actions {
        justify-content: flex-end;
        border-top: 1px dashed var(--ks-border-soft, rgba(0,0,0,0.08));
        padding-top: 0.5rem;
        margin-top: 0.3rem;
    }
    .lb-table-cards td.lb-card-actions::before {
        display: none;
    }
    /* Pas de hover-row sur mobile cards */
    .lb-table-cards tr:hover {
        background: var(--ks-bg-card, #fff) !important;
    }
}

/* Dark theme cards mobile */
@media (max-width: 767.98px) {
    [data-bs-theme="dark"] .lb-table-cards tr {
        background: #1a1a30;
        border-color: rgba(255,255,255,0.08);
        border-left-color: var(--hki-purple);
    }
    [data-bs-theme="dark"] .lb-table-cards td.lb-card-actions {
        border-top-color: rgba(255,255,255,0.08);
    }
}

/* ════════════════════════════════════════════════════════════════════
   Mobile UX : tap targets + safe-area + scroll inertiel (v1.0.07.3b)
   ════════════════════════════════════════════════════════════════════ */
@media (max-width: 767.98px) {
    /* Tap targets ≥ 44px (WCAG) */
    .btn, .nav-link, .dropdown-item {
        min-height: 38px;
    }
    .navbar-custom .nav-link {
        padding: 0.55rem 0.75rem !important;
    }
    /* Inputs ≥ 16px pour empêcher zoom iOS */
    input[type="text"], input[type="email"], input[type="tel"],
    input[type="number"], input[type="password"], input[type="date"],
    input[type="datetime-local"], textarea, select.form-select {
        font-size: 16px !important;
    }
    /* Scroll inertiel sur tables */
    .table-responsive { -webkit-overflow-scrolling: touch; }

    /* Safe area iOS (notch) */
    body {
        padding-left:   env(safe-area-inset-left);
        padding-right:  env(safe-area-inset-right);
    }
    footer {
        padding-bottom: max(env(safe-area-inset-bottom), 1rem);
    }

    /* Container plus serré */
    .container-fluid { padding-left: 0.6rem; padding-right: 0.6rem; }
}

/* ════════════════════════════════════════════════════════════════════
   Skip-link (a11y WCAG 2.4.1)
   ════════════════════════════════════════════════════════════════════ */
.lb-skip-link {
    position: absolute;
    left: -10000px;
    top: 6px;
    background: var(--hki-purple);
    color: #fff;
    padding: 8px 14px;
    border-radius: 4px;
    z-index: 1100;
    font-weight: 600;
    text-decoration: none;
}
.lb-skip-link:focus {
    left: 8px;
    outline: 2px solid var(--hki-coral);
    outline-offset: 2px;
}

/* Touch / no-zoom global */
body {
    -webkit-text-size-adjust: 100%;
    touch-action: manipulation;
}


/* ════════════════════════════════════════════════════════════════════
   Mobile bottom nav — flottante, permanente, couleurs HKI (v1.0.07.7)
   Inspirée du pattern budget mais aux couleurs LogBook (purple #0B2559).
   Visible uniquement < 768px. Cachée par défaut sur desktop.
   ════════════════════════════════════════════════════════════════════ */
.lb-mobile-nav {
    display: none;
    position: fixed;
    left: 12px;
    right: 12px;
    bottom: 12px;
    height: 60px;
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border: 1px solid rgba(122, 65, 131, 0.12);
    border-radius: 18px;
    box-shadow:
        0 8px 28px rgba(122, 65, 131, 0.18),
        0 2px 6px rgba(0, 0, 0, 0.06);
    z-index: 1080;
    padding: 0 6px;
    /* Safe-area iOS — incrément naturel */
    padding-bottom: 0;
    margin-bottom: env(safe-area-inset-bottom);
}

.lb-mobile-nav-items {
    display: flex;
    align-items: stretch;
    height: 100%;
    gap: 2px;
}

/* ── Items réguliers (gauche/droite du FAB) ─────────────────────── */
.lb-mobile-nav-item {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 3px;
    color: var(--hki-gray, #A7ACA2);
    text-decoration: none;
    font-size: 0.66rem;
    font-weight: 600;
    letter-spacing: 0.01em;
    padding: 4px 2px;
    border-radius: 12px;
    min-height: 56px;
    transition: color 0.15s, background 0.15s, transform 0.1s;
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
    position: relative;
}

.lb-mobile-nav-item:hover,
.lb-mobile-nav-item:focus {
    color: var(--hki-purple, #0B2559);
    background: var(--hki-purple-lt, #f3eaf5);
    text-decoration: none;
}

.lb-mobile-nav-item:active {
    transform: scale(0.97);
}

.lb-mobile-nav-item.active {
    color: var(--hki-purple, #0B2559);
}

.lb-mobile-nav-item .lb-nav-icon {
    font-size: 1.25rem;
    line-height: 1;
}

.lb-mobile-nav-item .lb-nav-label {
    font-size: 0.66rem;
    line-height: 1;
    white-space: nowrap;
}

.lb-mobile-nav-item .lb-mnav-dot {
    width: 4px;
    height: 4px;
    background: var(--hki-purple, #0B2559);
    border-radius: 50%;
    margin-top: 1px;
}

/* ── Wrap icône + badge alertes (anchor relative) ───────────────── */
.lb-mobile-nav-item .lb-nav-icon-wrap {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.lb-mnav-badge {
    position: absolute;
    top: -6px;
    right: -10px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    background: var(--hki-coral, #F87C56);
    color: #fff;
    font-size: 0.62rem;
    font-weight: 700;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    box-shadow: 0 1px 4px rgba(248, 124, 86, 0.45);
    border: 2px solid rgba(255, 255, 255, 0.96);
}

/* ── FAB central : grosse pastille purple gradient ─────────────── */
.lb-mobile-nav-fab {
    flex: 0 0 56px;
    width: 56px;
    height: 56px;
    margin: 0 6px;
    align-self: center;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--hki-purple, #0B2559), var(--hki-purple-dk, #06183d));
    color: #fff !important;
    border-radius: 50%;
    font-size: 1.5rem;
    text-decoration: none;
    box-shadow:
        0 6px 20px rgba(122, 65, 131, 0.45),
        0 0 0 4px rgba(255, 255, 255, 0.96);
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
    transition: transform 0.15s, box-shadow 0.15s;
    /* L'élève visuellement au-dessus de la barre */
    transform: translateY(-8px);
    position: relative;
    z-index: 1;
}

.lb-mobile-nav-fab:hover,
.lb-mobile-nav-fab:focus {
    color: #fff;
    text-decoration: none;
    box-shadow:
        0 8px 24px rgba(122, 65, 131, 0.55),
        0 0 0 4px rgba(255, 255, 255, 0.96);
}

.lb-mobile-nav-fab:active {
    transform: translateY(-8px) scale(0.94);
}

/* ── Affichage uniquement < 768px ───────────────────────────────── */
@media (max-width: 767.98px) {
    .lb-mobile-nav { display: block; }

    /* On laisse de la place sous le contenu pour ne pas masquer la dernière ligne */
    body.lb-has-mobile-nav main#lb-main-content,
    body main#lb-main-content {
        padding-bottom: calc(96px + env(safe-area-inset-bottom));
    }

    /* Cache les sub-menus desktop dont le bottom-nav prend le relais */
    /* (rien à cacher pour l'instant — la sidebar/topbar restent visibles
        en haut, la nav mobile est complémentaire) */
}

/* ── Dark theme : barre noire/violette translucide ──────────────── */
[data-bs-theme="dark"] .lb-mobile-nav {
    background: rgba(26, 26, 48, 0.92);
    border-color: rgba(255, 255, 255, 0.10);
    box-shadow:
        0 8px 28px rgba(0, 0, 0, 0.55),
        0 2px 6px rgba(0, 0, 0, 0.30);
}
[data-bs-theme="dark"] .lb-mobile-nav-item {
    color: #7878a0;
}
[data-bs-theme="dark"] .lb-mobile-nav-item:hover,
[data-bs-theme="dark"] .lb-mobile-nav-item:focus {
    color: #c084fc;
    background: rgba(192, 132, 252, 0.10);
}
[data-bs-theme="dark"] .lb-mobile-nav-item.active {
    color: #c084fc;
}
[data-bs-theme="dark"] .lb-mobile-nav-item.active .lb-mnav-dot {
    background: #c084fc;
}
[data-bs-theme="dark"] .lb-mnav-badge {
    border-color: rgba(26, 26, 48, 0.92);
}
[data-bs-theme="dark"] .lb-mobile-nav-fab {
    background: linear-gradient(135deg, #c084fc, #0B2559);
    box-shadow:
        0 6px 20px rgba(192, 132, 252, 0.55),
        0 0 0 4px rgba(26, 26, 48, 0.92);
}

/* ── Très petits écrans (< 380px) : labels condensés ─────────────── */
@media (max-width: 380px) {
    .lb-mobile-nav-item .lb-nav-label { font-size: 0.6rem; }
    .lb-mobile-nav-item .lb-nav-icon  { font-size: 1.15rem; }
    .lb-mobile-nav-fab { width: 50px; height: 50px; font-size: 1.35rem; }
}


/* ════════════════════════════════════════════════════════════════════
   Mobile bottom nav — auto-hide + dropdown "Plus" (v1.0.07.8)
   ════════════════════════════════════════════════════════════════════ */
.lb-mobile-nav {
    transition: transform 0.28s cubic-bezier(0.22, 1, 0.36, 1),
                opacity   0.18s ease-out;
    will-change: transform;
}
.lb-mobile-nav.is-hidden,
.lb-mobile-nav.is-keyboard-hidden {
    transform: translateY(140%);
    opacity: 0;
    pointer-events: none;
}

/* Bouton "Plus" : se distinguer visuellement du dot actif (pas de mnav-dot) */
.lb-mobile-nav button.lb-mobile-nav-item {
    background: none;
    border: 0;
    cursor: pointer;
    font-family: inherit;
}
.lb-mobile-nav button.lb-mobile-nav-item.active {
    color: var(--hki-purple, #0B2559);
    background: var(--hki-purple-lt, #f3eaf5);
}

/* ── Dropdown "Plus" ──────────────────────────────────────────────── */
.lb-mobile-more-menu {
    position: fixed;
    right: 14px;
    bottom: 86px;
    background: rgba(255, 255, 255, 0.98);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border: 1px solid rgba(122, 65, 131, 0.15);
    border-radius: 14px;
    box-shadow:
        0 12px 36px rgba(122, 65, 131, 0.22),
        0 4px 12px rgba(0, 0, 0, 0.08);
    z-index: 1085;
    min-width: 220px;
    padding: 6px;
    display: none;
    transform-origin: bottom right;
    animation: lbMoreFadeIn 0.18s ease-out;
}
.lb-mobile-more-menu.is-open {
    display: block;
}
@keyframes lbMoreFadeIn {
    from { opacity: 0; transform: translateY(8px) scale(0.96); }
    to   { opacity: 1; transform: translateY(0)   scale(1); }
}

.lb-mobile-more-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    border-radius: 10px;
    color: #212529;
    text-decoration: none;
    font-size: 0.88rem;
    font-weight: 500;
    transition: background 0.12s, color 0.12s;
    -webkit-tap-highlight-color: transparent;
}
.lb-mobile-more-item:hover,
.lb-mobile-more-item:focus {
    background: var(--hki-purple-lt, #f3eaf5);
    color: var(--hki-purple, #0B2559);
    text-decoration: none;
}
.lb-mobile-more-item i {
    font-size: 1.1rem;
    flex-shrink: 0;
    width: 22px;
    text-align: center;
}
.lb-mobile-more-item.lb-more-danger { color: #b02a37; }
.lb-mobile-more-item.lb-more-danger:hover {
    background: #fff5f4;
    color: #842029;
}

.lb-mobile-more-divider {
    height: 1px;
    background: rgba(0, 0, 0, 0.07);
    margin: 5px 8px;
}

/* Dark theme */
[data-bs-theme="dark"] .lb-mobile-more-menu {
    background: rgba(26, 26, 48, 0.96);
    border-color: rgba(255, 255, 255, 0.10);
    box-shadow:
        0 12px 36px rgba(0, 0, 0, 0.55),
        0 4px 12px rgba(0, 0, 0, 0.30);
}
[data-bs-theme="dark"] .lb-mobile-more-item       { color: #dde0f0; }
[data-bs-theme="dark"] .lb-mobile-more-item:hover { background: rgba(192, 132, 252, 0.15); color: #c084fc; }
[data-bs-theme="dark"] .lb-mobile-more-divider    { background: rgba(255, 255, 255, 0.08); }
[data-bs-theme="dark"] .lb-mobile-more-item.lb-more-danger        { color: #ff6b6b; }
[data-bs-theme="dark"] .lb-mobile-more-item.lb-more-danger:hover  { background: rgba(255, 107, 107, 0.12); color: #ff8a80; }


/* ════════════════════════════════════════════════════════════════════
   LogBook — DESIGN SYSTEM v1.0.07.8
   Préfixe `.lb-*` — opt-in, n'écrase pas Bootstrap.
   Voir docs/DESIGN_SYSTEM.md
   ════════════════════════════════════════════════════════════════════ */

:root {
    --lb-success: #198754;
    --lb-warning: #fd7e14;
    --lb-danger:  #dc3545;
    --lb-info:    #0dcaf0;

    --lb-radius-sm:   6px;
    --lb-radius:      12px;
    --lb-radius-lg:   18px;
    --lb-radius-pill: 50px;

    --lb-shadow-sm:  0 1px 3px rgba(0, 0, 0, 0.06);
    --lb-shadow:     0 4px 14px rgba(122, 65, 131, 0.10);
    --lb-shadow-lg:  0 10px 30px rgba(122, 65, 131, 0.18);
    --lb-shadow-fab: 0 6px 20px rgba(122, 65, 131, 0.45);

    --lb-transition: 0.15s ease-out;
}

/* ─── lb-section-header ─────────────────────────────────────────── */
.lb-section-header { margin-bottom: 1.25rem; }
.lb-section-header h2 {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--ks-text-main, #212529);
    margin: 0 0 0.25rem 0;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.lb-section-header h2 i { color: var(--hki-purple); font-size: 1.25rem; }
.lb-section-header p {
    font-size: 0.88rem;
    color: var(--ks-text-muted, #6c757d);
    margin: 0;
}

/* ─── lb-card ───────────────────────────────────────────────────── */
.lb-card {
    background: var(--ks-bg-card, #fff);
    border: 1px solid var(--ks-border-soft, rgba(0, 0, 0, 0.08));
    border-radius: var(--lb-radius);
    box-shadow: var(--lb-shadow);
    transition: box-shadow var(--lb-transition), transform var(--lb-transition);
    overflow: hidden;
}
.lb-card.lb-card-flat { box-shadow: none; }
.lb-card.lb-card-purple   { border-left: 3px solid var(--hki-purple); }
.lb-card.lb-card-coral    { border-left: 3px solid var(--hki-coral); }
.lb-card.lb-card-success  { border-left: 3px solid var(--lb-success); }
.lb-card.lb-card-danger   { border-left: 3px solid var(--lb-danger); }
.lb-card.lb-card-warning  { border-left: 3px solid var(--lb-warning); }
.lb-card.lb-card-info     { border-left: 3px solid var(--lb-info); }
.lb-card.is-clickable { cursor: pointer; }
.lb-card.is-clickable:hover { transform: translateY(-2px); box-shadow: var(--lb-shadow-lg); }

.lb-card-header {
    padding: 0.85rem 1.1rem;
    border-bottom: 1px solid var(--ks-border-soft, rgba(0, 0, 0, 0.06));
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    background: linear-gradient(180deg, rgba(122, 65, 131, 0.025), transparent);
}
.lb-card-title {
    margin: 0;
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--ks-text-main, #212529);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.lb-card-title i { color: var(--hki-purple); }
.lb-card-actions { display: flex; gap: 0.4rem; align-items: center; }
.lb-card-body { padding: 1.1rem; }
.lb-card-footer {
    padding: 0.75rem 1.1rem;
    border-top: 1px solid var(--ks-border-soft);
    background: var(--ks-bg-body, #f8f9fa);
    font-size: 0.82rem;
    color: var(--ks-text-muted);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.5rem;
}

/* ─── lb-btn ────────────────────────────────────────────────────── */
.lb-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    padding: 0.5rem 1rem;
    border-radius: var(--lb-radius-pill);
    font-size: 0.85rem;
    font-weight: 600;
    line-height: 1.2;
    text-decoration: none;
    border: 1px solid transparent;
    cursor: pointer;
    transition: background var(--lb-transition), color var(--lb-transition),
                border-color var(--lb-transition), transform 0.1s ease-out,
                box-shadow var(--lb-transition);
    -webkit-tap-highlight-color: transparent;
    white-space: nowrap;
}
.lb-btn:disabled, .lb-btn[disabled] { opacity: 0.55; cursor: not-allowed; }
.lb-btn:not(:disabled):hover { transform: translateY(-1px); }
.lb-btn:not(:disabled):active { transform: translateY(0); }

.lb-btn-primary  { background: var(--hki-purple); color: #fff; border-color: var(--hki-purple); }
.lb-btn-primary:hover {
    background: var(--hki-purple-dk); border-color: var(--hki-purple-dk);
    color: #fff; box-shadow: 0 4px 14px rgba(122, 65, 131, 0.30);
}
.lb-btn-secondary {
    background: var(--hki-purple-lt); color: var(--hki-purple); border-color: var(--hki-purple-lt);
}
.lb-btn-secondary:hover {
    background: rgba(122, 65, 131, 0.18); color: var(--hki-purple-dk);
}
.lb-btn-ghost { background: transparent; color: var(--ks-text-muted); border-color: transparent; }
.lb-btn-ghost:hover { background: var(--ks-bg-body, #f1f3f5); color: var(--ks-text-main); }
.lb-btn-outline { background: transparent; color: var(--hki-purple); border-color: var(--hki-purple); }
.lb-btn-outline:hover { background: var(--hki-purple); color: #fff; }
.lb-btn-coral { background: var(--hki-coral); color: #fff; border-color: var(--hki-coral); }
.lb-btn-coral:hover { background: #d96b48; border-color: #d96b48; color: #fff; }
.lb-btn-danger { background: var(--lb-danger); color: #fff; border-color: var(--lb-danger); }
.lb-btn-danger:hover { background: #b02a37; border-color: #b02a37; color: #fff; }
.lb-btn-sm  { padding: 0.3rem 0.7rem; font-size: 0.75rem; }
.lb-btn-lg  { padding: 0.7rem 1.4rem; font-size: 0.95rem; }
.lb-btn-icon { padding: 0.45rem; border-radius: 50%; width: 34px; height: 34px; }

/* ─── lb-stat-card ──────────────────────────────────────────────── */
.lb-stat-card {
    background: var(--ks-bg-card, #fff);
    border: 1px solid var(--ks-border-soft);
    border-radius: var(--lb-radius);
    padding: 1.1rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    transition: transform var(--lb-transition), box-shadow var(--lb-transition);
    box-shadow: var(--lb-shadow-sm);
    position: relative;
    overflow: hidden;
}
.lb-stat-card:hover { transform: translateY(-3px); box-shadow: var(--lb-shadow); }
.lb-stat-icon {
    width: 48px; height: 48px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    flex-shrink: 0;
}
.lb-stat-body { flex: 1; min-width: 0; }
.lb-stat-value {
    font-size: 1.6rem; font-weight: 700; line-height: 1;
    color: var(--ks-text-main, #212529);
    margin-bottom: 0.25rem;
}
.lb-stat-label {
    font-size: 0.75rem; font-weight: 600;
    color: var(--ks-text-muted, #6c757d);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    line-height: 1.2;
}
.lb-stat-trend { font-size: 0.72rem; color: var(--ks-text-muted); margin-top: 0.25rem; }

.lb-stat-purple   { border-left: 3px solid var(--hki-purple); }
.lb-stat-purple   .lb-stat-icon { background: var(--hki-purple-lt); color: var(--hki-purple); }
.lb-stat-coral    { border-left: 3px solid var(--hki-coral); }
.lb-stat-coral    .lb-stat-icon { background: rgba(248, 124, 86, 0.12); color: var(--hki-coral); }
.lb-stat-success  { border-left: 3px solid var(--lb-success); }
.lb-stat-success  .lb-stat-icon { background: rgba(25, 135, 84, 0.12); color: var(--lb-success); }
.lb-stat-warning  { border-left: 3px solid var(--lb-warning); }
.lb-stat-warning  .lb-stat-icon { background: rgba(253, 126, 20, 0.14); color: var(--lb-warning); }
.lb-stat-danger   { border-left: 3px solid var(--lb-danger); }
.lb-stat-danger   .lb-stat-icon { background: rgba(220, 53, 69, 0.12); color: var(--lb-danger); }
.lb-stat-info     { border-left: 3px solid var(--lb-info); }
.lb-stat-info     .lb-stat-icon { background: rgba(13, 202, 240, 0.14); color: #0aa2c0; }

/* ─── lb-chip ───────────────────────────────────────────────────── */
.lb-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.18rem 0.6rem;
    background: var(--ks-bg-body, #f1f3f5);
    color: var(--ks-text-muted, #6c757d);
    border-radius: var(--lb-radius-pill);
    font-size: 0.72rem;
    font-weight: 600;
    line-height: 1.4;
    white-space: nowrap;
    border: 1px solid transparent;
}
.lb-chip i { font-size: 0.78rem; }
.lb-chip-purple   { background: var(--hki-purple-lt); color: var(--hki-purple); }
.lb-chip-coral    { background: rgba(248, 124, 86, 0.14); color: #c0512c; }
.lb-chip-success  { background: rgba(25, 135, 84, 0.12); color: var(--lb-success); }
.lb-chip-warning  { background: rgba(253, 126, 20, 0.14); color: #b85d00; }
.lb-chip-danger   { background: rgba(220, 53, 69, 0.12); color: #b02a37; }
.lb-chip-info     { background: rgba(13, 202, 240, 0.14); color: #0aa2c0; }
.lb-chip-outline  { background: transparent; border-color: var(--ks-border-soft); }

/* ─── lb-empty-state ────────────────────────────────────────────── */
.lb-empty-state {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--ks-text-muted);
}
.lb-empty-state .lb-empty-icon {
    font-size: 3rem;
    color: var(--ks-text-muted);
    opacity: 0.4;
    margin-bottom: 0.75rem;
    display: block;
}
.lb-empty-state h3 {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--ks-text-main);
    margin: 0 0 0.4rem 0;
}
.lb-empty-state p {
    font-size: 0.88rem;
    color: var(--ks-text-muted);
    margin: 0 auto 1rem;
    max-width: 380px;
}

/* ─── Animations ────────────────────────────────────────────────── */
@keyframes lb-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}
@keyframes lb-slide-up {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}
.lb-animate-in { animation: lb-slide-up 0.22s cubic-bezier(0.22, 1, 0.36, 1); }

/* ─── Dark theme ────────────────────────────────────────────────── */
[data-bs-theme="dark"] .lb-card {
    background: #1a1a30;
    border-color: rgba(255, 255, 255, 0.07);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.30);
}
[data-bs-theme="dark"] .lb-card-header {
    background: linear-gradient(180deg, rgba(192, 132, 252, 0.04), transparent);
    border-bottom-color: rgba(255, 255, 255, 0.07);
}
[data-bs-theme="dark"] .lb-card-title { color: #dde0f0; }
[data-bs-theme="dark"] .lb-card-title i { color: #c084fc; }
[data-bs-theme="dark"] .lb-card-footer {
    background: #16162a;
    border-top-color: rgba(255, 255, 255, 0.07);
    color: #7878a0;
}
[data-bs-theme="dark"] .lb-stat-card {
    background: #1a1a30;
    border-color: rgba(255, 255, 255, 0.07);
}
[data-bs-theme="dark"] .lb-stat-value { color: #dde0f0; }
[data-bs-theme="dark"] .lb-stat-label { color: #7878a0; }
[data-bs-theme="dark"] .lb-section-header h2 { color: #dde0f0; }
[data-bs-theme="dark"] .lb-section-header p  { color: #7878a0; }
[data-bs-theme="dark"] .lb-section-header h2 i { color: #c084fc; }
[data-bs-theme="dark"] .lb-btn-primary {
    background: #c084fc; border-color: #c084fc; color: #1a1a30;
}
[data-bs-theme="dark"] .lb-btn-primary:hover {
    background: #b070f0; border-color: #b070f0; color: #1a1a30;
}
[data-bs-theme="dark"] .lb-btn-secondary {
    background: rgba(192, 132, 252, 0.15);
    color: #c084fc;
    border-color: transparent;
}
[data-bs-theme="dark"] .lb-btn-ghost { color: #7878a0; }
[data-bs-theme="dark"] .lb-btn-ghost:hover { background: rgba(255,255,255,0.05); color: #dde0f0; }
[data-bs-theme="dark"] .lb-btn-outline { color: #c084fc; border-color: #c084fc; }
[data-bs-theme="dark"] .lb-empty-state h3 { color: #dde0f0; }
[data-bs-theme="dark"] .lb-chip { background: rgba(255,255,255,0.05); color: #aaaacc; }
[data-bs-theme="dark"] .lb-chip-purple { background: rgba(192, 132, 252, 0.15); color: #c084fc; }
