﻿/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   Filab CRM â€” design system premium
   Base : Vuexy + Filab theme override
   IdentitÃ© : #07243E (deep) + #ee7d41 (accent) + gradient #E97435â†’#B94B10
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

:root {
    /* Couleurs Filab */
    --filab-primary: #07243e;
    --filab-secondary: #1c2c54;
    --filab-accent: #ee7d41;
    --filab-accent-2: #b94b10;
    --filab-accent-light: #fcd9c5;
    --filab-menu-bg: #07243e;
    --filab-menu-bg-2: #0a2e4f;
    --filab-menu-color: #e1def5;
    --filab-menu-color-muted: rgba(225, 222, 245, 0.55);
    --filab-gradient: linear-gradient(135deg, #ee7d41 0%, #b94b10 100%);
    --filab-gradient-soft: linear-gradient(135deg, rgba(238, 125, 65, 0.12) 0%, rgba(185, 75, 16, 0.06) 100%);
    --filab-gradient-mesh:
        radial-gradient(at 20% 20%, rgba(238, 125, 65, 0.22) 0px, transparent 50%),
        radial-gradient(at 80% 30%, rgba(7, 36, 62, 0.14) 0px, transparent 55%),
        radial-gradient(at 50% 80%, rgba(185, 75, 16, 0.10) 0px, transparent 50%);

    /* Surfaces & Ã©lÃ©vation */
    --filab-surface: #ffffff;
    --filab-surface-2: #fbfaf9;
    --filab-surface-3: #f5f3f1;
    --filab-border: rgba(7, 36, 62, 0.08);
    --filab-border-strong: rgba(7, 36, 62, 0.16);

    --shadow-1: 0 1px 2px rgba(7, 36, 62, 0.04), 0 1px 3px rgba(7, 36, 62, 0.03);
    --shadow-2: 0 4px 8px -2px rgba(7, 36, 62, 0.05), 0 2px 4px -2px rgba(7, 36, 62, 0.04);
    --shadow-3: 0 12px 16px -4px rgba(7, 36, 62, 0.07), 0 4px 6px -2px rgba(7, 36, 62, 0.04);
    --shadow-glow: 0 8px 24px -8px rgba(238, 125, 65, 0.45);

    /* Typo */
    --filab-font: 'Public Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

    /* Bootstrap variables override */
    --bs-body-bg: #fbfaf9;
    --bs-body-color: #2f2b3d;
    --bs-primary: #ee7d41;
    --bs-primary-rgb: 238, 125, 65;
    --bs-border-color: var(--filab-border);
    --bs-border-radius: 0.625rem;
    --bs-border-radius-sm: 0.375rem;
    --bs-border-radius-lg: 1rem;
}

* { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

html, body { font-family: var(--filab-font); }

body {
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
    letter-spacing: -0.005em;
}

::selection { background: var(--filab-accent); color: #fff; }

/* â”€â”€â”€ Layout container â€” fond lÃ©ger avec mesh subtil â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.layout-wrapper .layout-page {
    background:
        radial-gradient(at 0% 0%, rgba(238, 125, 65, 0.05) 0px, transparent 50%),
        var(--bs-body-bg);
}

.content-wrapper {
    padding-top: 5rem;
}


/* =============================================================== */
/*  SIDEBAR                                                        */
/* =============================================================== */
.layout-menu {
    width: 252px;
    background: var(--filab-menu-bg);
    color: var(--filab-menu-color);
    position: fixed;
    top: 0; left: 0; bottom: 0;
    z-index: 1040;
    display: flex;
    flex-direction: column;
    border-right: 1px solid rgba(255, 255, 255, 0.04);
}

.sb {
    display: flex;
    flex-direction: column;
    height: 100%;
}

/* Header */
.sb-head {
    padding: 1.25rem 1rem 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}
.sb-brand {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    text-decoration: none;
}
.sb-brand img {
    height: 26px;
    width: auto;
    filter: brightness(0) invert(1);
}
.sb-brand-badge {
    font-size: 0.6rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 2px 6px;
    border-radius: 4px;
    background: rgba(238, 125, 65, 0.18);
    color: var(--filab-accent);
}
.sb-toggle {
    width: 28px; height: 28px;
    border-radius: 6px;
    display: inline-flex;
    align-items: center; justify-content: center;
    background: transparent;
    border: 0;
    color: rgba(225, 222, 245, 0.45);
    font-size: 0.95rem;
    cursor: pointer;
    transition: all 160ms;
}
.sb-toggle:hover { background: rgba(255, 255, 255, 0.06); color: #fff; }

/* Search trigger */
.sb-search {
    margin: 0.75rem 0.75rem 0.5rem;
    padding: 0.5rem 0.625rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.07);
    border-radius: 0.5rem;
    color: rgba(225, 222, 245, 0.55);
    font-size: 0.82rem;
    cursor: pointer;
    transition: all 160ms;
}
.sb-search:hover {
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
    border-color: rgba(255, 255, 255, 0.12);
}
.sb-search .ti { font-size: 0.95rem; }
.sb-search-label { flex: 1; text-align: left; }
.sb-search kbd {
    background: rgba(255, 255, 255, 0.08);
    color: rgba(225, 222, 245, 0.65);
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 1px 5px;
    border-radius: 4px;
    font-size: 0.62rem;
    font-family: var(--bs-font-monospace);
    line-height: 1.4;
}

/* Nav */
.sb-nav {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 0.5rem 0;
}
.sb-nav::-webkit-scrollbar { width: 0; }

.sb-section {
    font-size: 0.62rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: rgba(225, 222, 245, 0.32);
    padding: 1rem 1.25rem 0.4rem;
}
.sb-section:first-child { padding-top: 0.5rem; }

.sb-link {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    margin: 1px 0.625rem;
    padding: 0.5rem 0.75rem;
    border-radius: 0.5rem;
    color: rgba(225, 222, 245, 0.78);
    text-decoration: none;
    font-size: 0.875rem;
    transition: all 160ms;
    position: relative;
    cursor: pointer;
}
.sb-link .ti { font-size: 1.1rem; width: 20px; text-align: center; flex-shrink: 0; opacity: 0.8; }
.sb-link__label { flex: 1; min-width: 0; }
.sb-link:hover {
    background: rgba(255, 255, 255, 0.05);
    color: #fff;
}
.sb-link:hover .ti { opacity: 1; }

.sb-link.is-active {
    background: linear-gradient(90deg, rgba(238, 125, 65, 0.18) 0%, rgba(238, 125, 65, 0.04) 100%);
    color: #fff;
    font-weight: 500;
}
.sb-link.is-active .ti { color: var(--filab-accent); opacity: 1; }
.sb-link.is-active::before {
    content: '';
    position: absolute;
    left: -0.625rem;
    top: 50%; transform: translateY(-50%);
    width: 3px; height: 60%;
    background: var(--filab-accent);
    border-radius: 0 3px 3px 0;
    box-shadow: 0 0 8px var(--filab-accent);
}

.sb-link__badge {
    background: rgba(238, 125, 65, 0.16);
    color: var(--filab-accent);
    padding: 1px 6px;
    border-radius: 999px;
    font-size: 0.65rem;
    font-weight: 600;
    line-height: 1.4;
}

/* Footer user card */
.sb-user {
    margin: 0.5rem 0.625rem 0.75rem;
    padding: 0.625rem 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.625rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 0.5rem;
    text-decoration: none;
    color: inherit;
    transition: background 160ms;
}
.sb-user:hover { background: rgba(255, 255, 255, 0.08); }
.sb-user__avatar {
    width: 34px; height: 34px;
    border-radius: 0.5rem;
    background: var(--filab-gradient);
    display: inline-flex;
    align-items: center; justify-content: center;
    color: #fff;
    font-size: 0.75rem;
    font-weight: 600;
    flex-shrink: 0;
    overflow: hidden;
}
.sb-user__avatar-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.sb-user__info { flex: 1; min-width: 0; line-height: 1.2; }
.sb-user__name {
    color: #fff;
    font-size: 0.82rem;
    font-weight: 500;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.sb-user__role {
    color: rgba(225, 222, 245, 0.45);
    font-size: 0.68rem;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.sb-user__chev {
    color: rgba(225, 222, 245, 0.4);
    font-size: 0.95rem;
    flex-shrink: 0;
}

/* Collapsed state (icons only) */
.layout-menu-collapsed:not(.layout-menu-hover) .layout-menu { width: 72px; }
.layout-menu-collapsed:not(.layout-menu-hover) .sb-brand img,
.layout-menu-collapsed:not(.layout-menu-hover) .sb-brand-badge,
.layout-menu-collapsed:not(.layout-menu-hover) .sb-search-label,
.layout-menu-collapsed:not(.layout-menu-hover) .sb-search kbd,
.layout-menu-collapsed:not(.layout-menu-hover) .sb-section,
.layout-menu-collapsed:not(.layout-menu-hover) .sb-link__label,
.layout-menu-collapsed:not(.layout-menu-hover) .sb-link__badge,
.layout-menu-collapsed:not(.layout-menu-hover) .sb-user__info,
.layout-menu-collapsed:not(.layout-menu-hover) .sb-user__chev { display: none; }
.layout-menu-collapsed:not(.layout-menu-hover) .sb-link { justify-content: center; }
.layout-menu-collapsed:not(.layout-menu-hover) .sb-link.is-active::before { left: 0; }
.layout-menu-collapsed:not(.layout-menu-hover) .sb-search { justify-content: center; }

/* Page shift relative to sidebar */
.layout-page {
    margin-left: 252px;
    padding-left: 0 !important;   /* écrase le 16.25rem de Vuexy */
    padding-right: 0 !important;
    transition: margin-left 220ms cubic-bezier(.4,0,.2,1);
}
.layout-menu-collapsed:not(.layout-menu-hover) .layout-page { margin-left: 72px; }
@media (max-width: 1199.98px) {
    .layout-menu {
        transform: translateX(-100%);
        transition: transform 240ms cubic-bezier(.4,0,.2,1);
    }
    html.layout-menu-expanded .layout-menu { transform: translateX(0); }
    html.layout-menu-expanded .layout-overlay {
        position: fixed; inset: 0;
        background: rgba(7, 36, 62, 0.5);
        backdrop-filter: blur(4px);
        z-index: 1035;
    }
    .layout-page { margin-left: 0; }
}


/* =============================================================== */
/*  TOPBAR                                                         */
/* =============================================================== */
.tb {
    position: fixed;
    top: 0; left: 252px; right: 0;
    height: 60px;
    z-index: 1030;
    background: rgba(251, 250, 249, 0.85);
    backdrop-filter: saturate(180%) blur(14px);
    -webkit-backdrop-filter: saturate(180%) blur(14px);
    border-bottom: 1px solid var(--filab-border);
    display: flex;
    align-items: center;
    padding: 0 1.25rem;
    gap: 1rem;
    transition: left 220ms cubic-bezier(.4,0,.2,1);
}
.layout-menu-collapsed:not(.layout-menu-hover) .tb { left: 72px; }
@media (max-width: 1199.98px) { .tb { left: 0; } }

.tb-burger {
    width: 36px; height: 36px;
    border-radius: 8px;
    display: inline-flex;
    align-items: center; justify-content: center;
    background: transparent;
    border: 0;
    color: var(--filab-primary);
    font-size: 1.15rem;
    cursor: pointer;
    transition: background 160ms;
}
.tb-burger:hover { background: var(--filab-surface-3); }

.tb-title {
    color: var(--filab-primary);
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: -0.005em;
    margin: 0;
    line-height: 1.2;
}
.tb-subtitle {
    color: #a5a3ae;
    font-size: 0.72rem;
    line-height: 1.2;
    display: block;
    margin-top: 1px;
}

.tb-actions {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 0.375rem;
}

.tb-btn {
    width: 36px; height: 36px;
    border-radius: 8px;
    display: inline-flex;
    align-items: center; justify-content: center;
    background: transparent;
    border: 0;
    color: #6f6b7d;
    font-size: 1.1rem;
    cursor: pointer;
    transition: all 160ms;
    position: relative;
    padding: 0;
}
.tb-btn:hover {
    background: var(--filab-surface-3);
    color: var(--filab-primary);
}
.tb-btn__dot {
    position: absolute;
    top: 8px; right: 8px;
    width: 8px; height: 8px;
    border-radius: 999px;
    background: var(--filab-accent);
    box-shadow: 0 0 0 2px #fff;
}
.tb-btn__badge {
    position: absolute;
    top: 4px; right: 4px;
    min-width: 16px; height: 16px;
    padding: 0 4px;
    border-radius: 999px;
    background: var(--filab-gradient);
    color: #fff;
    font-size: 0.6rem;
    font-weight: 600;
    display: inline-flex;
    align-items: center; justify-content: center;
    box-shadow: 0 0 0 2px #fff;
    line-height: 1;
}

.tb-divider {
    width: 1px; height: 22px;
    background: var(--filab-border);
    margin: 0 0.25rem;
}

.tb-user {
    display: inline-flex;
    align-items: center;
    gap: 0.625rem;
    padding: 0.25rem 0.5rem 0.25rem 0.75rem;
    border-radius: 0.5rem;
    text-decoration: none !important;
    color: inherit;
    background: transparent;
    border: 0;
    cursor: pointer;
    transition: background 160ms;
}
.tb-user:hover { background: var(--filab-surface-3); }
.tb-user__info { line-height: 1.2; text-align: right; min-width: 0; }
.tb-user__name {
    color: var(--filab-primary);
    font-size: 0.82rem;
    font-weight: 500;
    display: block;
}
.tb-user__role {
    color: #a5a3ae;
    font-size: 0.66rem;
    display: block;
}
.tb-user__avatar {
    width: 34px; height: 34px;
    border-radius: 0.5rem;
    background: var(--filab-gradient);
    display: inline-flex;
    align-items: center; justify-content: center;
    color: #fff;
    font-size: 0.75rem;
    font-weight: 600;
    flex-shrink: 0;
    overflow: hidden;
}
.tb-user__avatar-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* ─── Topbar popovers (Alpine-driven — sans Bootstrap dropdown) ─── */
.tb-popover { position: relative; }
.tb-popover-menu {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 240px;
    background: #fff;
    border: 1px solid var(--filab-border);
    border-radius: 0.75rem;
    box-shadow: 0 18px 36px -12px rgba(7, 36, 62, 0.18), 0 4px 8px -4px rgba(7, 36, 62, 0.08);
    padding: 0.375rem;
    z-index: 1050;
    overflow: hidden;
}
.tb-popover-menu--wide { min-width: 360px; max-width: 92vw; padding: 0; }

.tb-menu-item {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    padding: 0.55rem 0.75rem;
    border-radius: 0.5rem;
    color: var(--filab-primary);
    text-decoration: none;
    font-size: 0.875rem;
    cursor: pointer;
    transition: background 140ms, color 140ms;
}
.tb-menu-item .ti { font-size: 1rem; color: #6f6b7d; }
.tb-menu-item:hover {
    background: var(--filab-surface-2);
    color: var(--filab-primary);
}
.tb-menu-item:hover .ti { color: var(--filab-accent); }

.tb-menu-header {
    padding: 0.875rem 1rem;
    border-bottom: 1px solid var(--filab-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.tb-menu-body {
    max-height: 360px;
    overflow-y: auto;
}
.tb-menu-body .alert-row { border-radius: 0; }
.tb-menu-body .alert-row:last-child { border-bottom: 0; }

.tb-menu-footer {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.375rem;
    padding: 0.625rem;
    border-top: 1px solid var(--filab-border);
    color: var(--filab-accent-2);
    font-size: 0.82rem;
    font-weight: 500;
    text-decoration: none;
    background: var(--filab-surface-2);
    transition: background 140ms;
}
.tb-menu-footer:hover { background: var(--filab-surface-3); color: var(--filab-accent); }

.tb-menu-divider {
    height: 1px;
    background: var(--filab-border);
    margin: 0.375rem 0;
}


/* â”€â”€â”€ Boutons â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.btn {
    font-weight: 500;
    letter-spacing: -0.005em;
    transition: all 180ms cubic-bezier(.4, 0, .2, 1);
}
.btn-primary {
    background: var(--filab-gradient) !important;
    border: none !important;
    color: #fff !important;
    box-shadow: var(--shadow-glow);
}
.btn-primary:hover,
.btn-primary:focus {
    filter: brightness(1.05);
    transform: translateY(-1px);
    box-shadow: 0 12px 28px -8px rgba(238, 125, 65, 0.55);
    color: #fff !important;
}
.btn-primary:active { transform: translateY(0); filter: brightness(0.96); }

.btn-outline-primary {
    color: var(--filab-accent-2) !important;
    border-color: rgba(238, 125, 65, 0.30) !important;
    background: transparent !important;
}
.btn-outline-primary:hover {
    background: var(--filab-gradient-soft) !important;
    border-color: var(--filab-accent) !important;
    color: var(--filab-accent-2) !important;
}

.btn-outline-secondary {
    color: #4b4b4b !important;
    border-color: var(--filab-border) !important;
    background: #fff !important;
    box-shadow: var(--shadow-1);
}
.btn-outline-secondary:hover {
    background: var(--filab-surface-2) !important;
    border-color: var(--filab-border-strong) !important;
    color: var(--filab-primary) !important;
    transform: translateY(-1px);
    box-shadow: var(--shadow-2);
}

.btn-sm { padding: 0.375rem 0.875rem; font-size: 0.8125rem; }

.text-primary { color: var(--filab-accent-2) !important; }
.text-deep    { color: var(--filab-primary) !important; }
.bg-primary   { background: var(--filab-gradient) !important; }

/* â”€â”€â”€ Liens & accents â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
a { color: var(--filab-accent-2); text-decoration: none; transition: color 160ms; }
a:hover { color: var(--filab-accent); }

/* â”€â”€â”€ Cards premium â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.card {
    border: 1px solid var(--filab-border);
    box-shadow: var(--shadow-1);
    border-radius: 0.875rem;
    background: var(--filab-surface);
    transition: box-shadow 240ms, transform 240ms;
    overflow: hidden;
}
.card:hover { box-shadow: var(--shadow-2); }
.card-hover-lift:hover { transform: translateY(-2px); box-shadow: var(--shadow-3); }

.card-header {
    background: transparent;
    border-bottom: 1px solid var(--filab-border);
    padding: 1.125rem 1.25rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.card-header .card-title {
    font-size: 1rem;
    font-weight: 500;
    color: var(--filab-primary);
    margin: 0;
    letter-spacing: -0.005em;
}
.card-body { padding: 1.25rem; }

/* â”€â”€â”€ KPI tiles premium â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.kpi-tile {
    background: var(--filab-surface);
    border-radius: 0.875rem;
    padding: 1.25rem 1.5rem;
    border: 1px solid var(--filab-border);
    box-shadow: var(--shadow-1);
    position: relative;
    overflow: hidden;
    transition: all 240ms;
}
.kpi-tile::after {
    content: '';
    position: absolute;
    top: -40%; right: -20%;
    width: 220px; height: 220px;
    background: var(--filab-gradient-soft);
    border-radius: 50%;
    opacity: 0;
    transition: opacity 320ms;
    pointer-events: none;
}
.kpi-tile:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-3);
    border-color: var(--filab-border-strong);
}
.kpi-tile:hover::after { opacity: 0.6; }

.kpi-tile .kpi-label {
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #6f6b7d;
}
.kpi-tile .kpi-value {
    font-size: 2.25rem;
    font-weight: 500;
    color: var(--filab-primary);
    line-height: 1.05;
    margin-top: 0.375rem;
    letter-spacing: -0.02em;
    font-variant-numeric: tabular-nums;
}
.kpi-tile .kpi-hint {
    color: #6f6b7d;
    font-size: 0.75rem;
    margin-top: 0.25rem;
    display: flex;
    align-items: center;
    gap: 0.375rem;
}
.kpi-tile .kpi-trend-up   { color: #28c76f; }
.kpi-tile .kpi-trend-down { color: #ea5455; }
.kpi-tile .kpi-icon {
    width: 44px; height: 44px;
    border-radius: 0.625rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--filab-gradient-soft);
    color: var(--filab-accent-2);
    font-size: 1.125rem;
    position: relative;
    z-index: 1;
}
.kpi-tile .kpi-spark { margin-top: 0.5rem; height: 36px; position: relative; z-index: 1; }

/* â”€â”€â”€ Badges / chips â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 0.22rem 0.65rem;
    border-radius: 999px;
    background: rgba(7, 36, 62, 0.06);
    color: var(--filab-primary);
    font-size: 0.7rem;
    font-weight: 500;
    letter-spacing: 0.01em;
    line-height: 1.2;
}
.chip-accent { background: var(--filab-gradient-soft); color: var(--filab-accent-2); }
.chip-success { background: rgba(40, 199, 111, 0.12); color: #1ea760; }
.chip-warn    { background: rgba(255, 159, 67, 0.14); color: #cf6f00; }
.chip-danger  { background: rgba(234, 84, 85, 0.12); color: #c43e3f; }

.badge-temp-hot  {
    background: var(--filab-gradient) !important;
    color: #fff !important;
    box-shadow: 0 2px 6px rgba(238, 125, 65, 0.35);
}
.badge-temp-warm {
    background: rgba(238, 125, 65, 0.16) !important;
    color: var(--filab-accent-2) !important;
}
.badge-temp-cold {
    background: rgba(7, 36, 62, 0.08) !important;
    color: var(--filab-primary) !important;
}

/* â”€â”€â”€ Kanban pipeline premium â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.kanban-board {
    display: flex;
    gap: 1rem;
    overflow-x: auto;
    padding-bottom: 1rem;
    scroll-snap-type: x proximity;
}
.kanban-column {
    min-width: 300px;
    flex: 0 0 auto;
    background: var(--filab-surface);
    border-radius: 0.875rem;
    padding: 0.875rem;
    border: 1px solid var(--filab-border);
    box-shadow: var(--shadow-1);
    scroll-snap-align: start;
    display: flex;
    flex-direction: column;
    min-height: 600px;
}
.kanban-column-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.25rem 0.5rem 0.875rem;
    font-size: 0.7rem;
    color: #6f6b7d;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    font-weight: 600;
    border-bottom: 1px solid var(--filab-border);
    margin-bottom: 0.75rem;
}
.kanban-column-header .stage-dot {
    display: inline-block;
    width: 8px; height: 8px;
    border-radius: 999px;
    margin-right: 0.5rem;
    box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.04);
}
.kanban-column-header .count {
    background: var(--filab-surface-3);
    padding: 2px 8px;
    border-radius: 999px;
    color: var(--filab-primary);
    font-family: var(--bs-font-monospace);
    font-size: 0.7rem;
}
.kanban-card {
    background: #fff;
    border-radius: 0.625rem;
    padding: 0.875rem 1rem;
    margin-bottom: 0.625rem;
    box-shadow: var(--shadow-1);
    border: 1px solid var(--filab-border);
    cursor: grab;
    transition: all 200ms cubic-bezier(.4, 0, .2, 1);
}
.kanban-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-3);
    border-color: var(--filab-border-strong);
}
.kanban-card:active { cursor: grabbing; }
.kanban-card .kanban-subject {
    font-weight: 500;
    color: var(--filab-primary);
    font-size: 0.875rem;
    line-height: 1.3;
    margin: 0.25rem 0;
    letter-spacing: -0.005em;
}
.kanban-card .kanban-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 0.72rem;
    color: #6f6b7d;
    margin-top: 0.625rem;
}

/* â”€â”€â”€ Tables â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.table {
    --bs-table-bg: transparent;
    --bs-table-hover-bg: var(--filab-surface-2);
    margin-bottom: 0;
}
.table thead th {
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: #6f6b7d;
    border-bottom: 1px solid var(--filab-border);
    padding: 0.875rem 0.75rem;
}
.table tbody td {
    padding: 0.875rem 0.75rem;
    border-bottom: 1px solid var(--filab-border);
    vertical-align: middle;
}
.table-hover tbody tr { transition: background 160ms; }
.table-hover tbody tr:hover { background: var(--filab-surface-2); }
.table > :not(caption) > * > * { background: transparent; }

/* â”€â”€â”€ Forms â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.form-control, .form-select {
    border: 1px solid var(--filab-border);
    border-radius: 0.5rem;
    padding: 0.55rem 0.875rem;
    font-size: 0.875rem;
    background: var(--filab-surface);
    transition: all 180ms;
    color: var(--bs-body-color);
}
.form-control::placeholder { color: #a5a3ae; }
.form-control:focus, .form-select:focus {
    border-color: var(--filab-accent);
    box-shadow: 0 0 0 3px rgba(238, 125, 65, 0.15);
    background: #fff;
}
.input-group-text {
    background: var(--filab-surface-2);
    border: 1px solid var(--filab-border);
    color: #6f6b7d;
}
.form-label { font-size: 0.8rem; font-weight: 500; color: var(--filab-primary); margin-bottom: 0.375rem; }

/* â”€â”€â”€ Avatars â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.avatar { position: relative; display: inline-flex; }
.avatar .avatar-initial {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%; height: 100%;
    font-weight: 500;
    text-transform: uppercase;
    font-size: 0.75rem;
}
.avatar-sm { width: 32px; height: 32px; }
.avatar-md { width: 40px; height: 40px; }
.avatar-lg { width: 56px; height: 56px; }

/* â”€â”€â”€ Dropdowns â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.dropdown-menu {
    border: 1px solid var(--filab-border);
    border-radius: 0.875rem;
    box-shadow: var(--shadow-3);
    padding: 0.5rem;
    min-width: 240px;
    margin-top: 0.5rem !important;
    animation: dropdown-in 180ms cubic-bezier(.4, 0, .2, 1);
}
@keyframes dropdown-in {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}
.dropdown-item {
    border-radius: 0.5rem;
    padding: 0.5rem 0.75rem;
    font-size: 0.875rem;
    transition: background 140ms;
}
.dropdown-item:hover, .dropdown-item:focus {
    background: var(--filab-surface-3);
    color: var(--filab-primary);
}
.dropdown-divider { border-color: var(--filab-border); }

/* â”€â”€â”€ Notifications panel (topbar dropdown) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.notif-panel { min-width: 360px; max-width: 90vw; padding: 0 !important; }
.notif-panel .notif-header {
    padding: 0.875rem 1rem;
    border-bottom: 1px solid var(--filab-border);
    display: flex; align-items: center; justify-content: space-between;
}
.notif-panel .notif-item {
    padding: 0.875rem 1rem;
    border-bottom: 1px solid var(--filab-border);
    display: flex; gap: 0.75rem;
    transition: background 140ms;
    cursor: pointer;
}
.notif-panel .notif-item:hover { background: var(--filab-surface-2); }
.notif-panel .notif-item:last-child { border-bottom: none; }

/* IcÃ´ne avatar carrÃ©e colorÃ©e (utilisÃ©e partout â€” notifs + alertes + tables) */
.notif-icon {
    width: 36px; height: 36px;
    border-radius: 0.5rem;
    display: inline-flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    font-size: 1rem;
    line-height: 1;
}
.notif-icon-critical { background: rgba(234, 84, 85, 0.14); color: #c43e3f; }
.notif-icon-warn     { background: rgba(255, 159, 67, 0.16); color: #cf6f00; }
.notif-icon-info     { background: rgba(7, 36, 62, 0.08); color: var(--filab-primary); }

/* â”€â”€â”€ Alert row (dashboard + page /alertes) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.alert-row {
    display: flex;
    gap: 0.875rem;
    padding: 0.875rem 1rem 0.875rem 0.75rem;
    border-bottom: 1px solid var(--filab-border);
    border-left: 3px solid transparent;
    background: var(--filab-surface);
    transition: background 160ms;
    position: relative;
}
.alert-row:last-child { border-bottom: none; }
.alert-row:hover { background: var(--filab-surface-2); }
.alert-row.is-critical { border-left-color: #ea5455; }
.alert-row.is-warn     { border-left-color: #ff9f43; }
.alert-row.is-info     { border-left-color: var(--filab-primary); }

.alert-row__icon {
    width: 34px; height: 34px;
    border-radius: 0.5rem;
    display: inline-flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    font-size: 1rem;
    line-height: 1;
}
.alert-row.is-critical .alert-row__icon { background: rgba(234, 84, 85, 0.12); color: #c43e3f; }
.alert-row.is-warn     .alert-row__icon { background: rgba(255, 159, 67, 0.14); color: #cf6f00; }
.alert-row.is-info     .alert-row__icon { background: rgba(7, 36, 62, 0.08); color: var(--filab-primary); }

.alert-row__body { flex: 1; min-width: 0; }
.alert-row__title {
    color: var(--filab-primary);
    font-size: 0.875rem;
    font-weight: 500;
    line-height: 1.35;
    margin-bottom: 2px;
}
.alert-row__desc {
    color: #6f6b7d;
    font-size: 0.8rem;
    line-height: 1.4;
    margin: 0;
}
.alert-row__meta {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.375rem;
    color: #a5a3ae;
    font-size: 0.72rem;
}
.alert-row__time { color: #a5a3ae; font-size: 0.72rem; flex-shrink: 0; }

/* â”€â”€â”€ Search bar (Cmd-K) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.cmdk-trigger .btn { gap: 0.5rem; }
.cmdk-trigger kbd, .cmdk-panel kbd {
    background: var(--filab-surface-3);
    color: #6f6b7d;
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 0.7rem;
    font-family: var(--bs-font-monospace);
    border: 1px solid var(--filab-border);
    line-height: 1.2;
}

.cmdk-panel-wrapper {
    position: fixed; inset: 0;
    z-index: 1080;
    display: none;
}
.cmdk-panel-wrapper.open { display: block; }
.cmdk-backdrop {
    position: absolute; inset: 0;
    background: rgba(7, 36, 62, 0.50);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}
.cmdk-panel {
    position: absolute;
    top: 12vh;
    left: 50%;
    transform: translateX(-50%);
    width: min(680px, 92vw);
    background: #fff;
    border-radius: 1rem;
    box-shadow: 0 32px 64px -16px rgba(7, 36, 62, 0.30), 0 0 0 1px rgba(0, 0, 0, 0.04);
    overflow: hidden;
}
.cmdk-input-wrap {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--filab-border);
}
.cmdk-input {
    flex: 1;
    border: none;
    outline: none;
    background: transparent;
    font-size: 1rem;
    color: var(--filab-primary);
}
.cmdk-input::placeholder { color: #a5a3ae; }
.cmdk-results { max-height: 56vh; overflow-y: auto; padding: 0.5rem; }
.cmdk-section-header {
    padding: 0.5rem 0.75rem 0.375rem;
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #a5a3ae;
}
.cmdk-result {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.625rem 0.75rem;
    border-radius: 0.5rem;
    cursor: pointer;
    transition: background 120ms;
    text-decoration: none;
    color: inherit;
}
.cmdk-result:hover,
.cmdk-result.active {
    background: var(--filab-gradient-soft);
    color: var(--filab-primary);
}
.cmdk-result .cmdk-result-icon {
    width: 32px; height: 32px;
    border-radius: 0.375rem;
    background: var(--filab-surface-3);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #6f6b7d;
    flex-shrink: 0;
}
.cmdk-result .cmdk-result-title {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--filab-primary);
    line-height: 1.2;
}
.cmdk-result .cmdk-result-meta {
    font-size: 0.7rem;
    color: #6f6b7d;
    margin-top: 2px;
}
.cmdk-empty {
    padding: 2rem 1rem;
    text-align: center;
    color: #a5a3ae;
}
.cmdk-empty i { font-size: 1.5rem; margin-bottom: 0.5rem; display: block; }

/* â”€â”€â”€ Login (page-auth) â€” finition premium â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.page-auth {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 2rem 1.5rem;
    position: relative;
    overflow: hidden;
    background:
        var(--filab-gradient-mesh),
        linear-gradient(180deg, #fbfaf9 0%, #f5f3f1 100%);
}
.page-auth .auth-card {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 460px;
}
.page-auth .card {
    border: 1px solid var(--filab-border);
    box-shadow: 0 32px 64px -16px rgba(7, 36, 62, 0.18), var(--shadow-2);
    border-radius: 1.25rem;
    overflow: hidden;
}

/* â”€â”€â”€ Loader plein Ã©cran â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#loader {
    position: fixed; inset: 0;
    background:
        var(--filab-gradient-mesh),
        linear-gradient(180deg, #fbfaf9 0%, #f5f3f1 100%);
    display: grid; place-items: center;
    z-index: 9999;
    transition: opacity 320ms ease, visibility 320ms ease;
}
#loader.hidden { opacity: 0; visibility: hidden; pointer-events: none; }
#loader .spinner {
    width: 48px; height: 48px;
    border: 3px solid rgba(238, 125, 65, 0.20);
    border-top-color: var(--filab-accent);
    border-radius: 999px;
    animation: filab-spin 0.8s linear infinite;
}
@keyframes filab-spin { to { transform: rotate(360deg); } }

/* â”€â”€â”€ App brand (logo) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.app-brand-link { display: flex; align-items: center; gap: 0.5rem; text-decoration: none; }
.app-brand .full-logo {
    height: 32px;
    width: auto;
    filter: brightness(0) invert(1);
    transition: opacity 0.35s ease-in-out;
}
.layout-menu-collapsed .app-brand .full-logo { opacity: 0; }
.layout-menu-collapsed.layout-menu-hover .app-brand .full-logo { opacity: 1; }

/* â”€â”€â”€ Activity feed â€” icÃ´nes plates (sans bloc de fond) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.activity-icon {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.05rem;
    line-height: 1;
    color: var(--filab-primary);
}
.activity-icon .ti {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    vertical-align: middle;
}

/* â”€â”€â”€ Empty states â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.empty-state {
    padding: 3rem 1.5rem;
    text-align: center;
    color: #a5a3ae;
}
.empty-state .empty-icon {
    width: 64px; height: 64px;
    border-radius: 50%;
    background: var(--filab-gradient-soft);
    color: var(--filab-accent-2);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    margin-bottom: 1rem;
}
.empty-state h6 { color: var(--filab-primary); font-weight: 500; margin-bottom: 0.25rem; }

/* â”€â”€â”€ Animations d'apparition (Livewire-friendly) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@keyframes fade-up { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.anim-fade-up { animation: fade-up 360ms cubic-bezier(.4, 0, .2, 1) both; }
.anim-stagger > * { animation: fade-up 360ms cubic-bezier(.4, 0, .2, 1) both; }
.anim-stagger > *:nth-child(1) { animation-delay: 0ms; }
.anim-stagger > *:nth-child(2) { animation-delay: 60ms; }
.anim-stagger > *:nth-child(3) { animation-delay: 120ms; }
.anim-stagger > *:nth-child(4) { animation-delay: 180ms; }
.anim-stagger > *:nth-child(5) { animation-delay: 240ms; }
.anim-stagger > *:nth-child(6) { animation-delay: 300ms; }

/* â”€â”€â”€ Utilitaires divers â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.cursor-pointer { cursor: pointer; }
.text-muted-2 { color: #a5a3ae !important; }
.text-deep-muted { color: rgba(7, 36, 62, 0.6) !important; }
.tabular { font-variant-numeric: tabular-nums; }

/* â”€â”€â”€ Scrollbar custom â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: rgba(7, 36, 62, 0.16); border-radius: 999px; border: 2px solid transparent; background-clip: padding-box; }
::-webkit-scrollbar-thumb:hover { background-color: rgba(7, 36, 62, 0.30); background-clip: padding-box; border: 2px solid transparent; }
::-webkit-scrollbar-track { background: transparent; }

/* â”€â”€â”€ Mobile menu toggle â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width: 1199.98px) {
    .layout-menu {
        position: fixed;
        top: 0; left: -260px;
        height: 100vh;
        width: 260px;
        z-index: 1050;
        transition: left 280ms cubic-bezier(.4, 0, .2, 1);
    }
    html.layout-menu-expanded .layout-menu { left: 0; }
    html.layout-menu-expanded .layout-overlay {
        position: fixed;
        inset: 0;
        background: rgba(7, 36, 62, 0.40);
        backdrop-filter: blur(4px);
        z-index: 1040;
    }
}

/* â”€â”€â”€ Hide Alpine cloak until init â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
[x-cloak] { display: none !important; }
