/* ===========================
   Variables & base
   =========================== */
@media (prefers-color-scheme: dark){ :root{ color-scheme: dark; } }

:root{
    /* Light */
    --bg:#f6f7fb;
    --surface:#fff;
    --surface-2:#f9fafc;

    --text:#0f1222;
    --muted:#6b7083;

    --primary:#5b7cff;
    --primary-ink:#0b102b;
    --primary-soft:rgba(91,124,255,.12);

    --success:#22c55e;
    --warning:#f59e0b;
    --danger:#ef4444;
    --info:#06b6d4;

    --border:#e7e9f2;
    --ring:rgba(91,124,255,.35);
    --shadow:0 8px 24px rgba(15,18,34,.06);

    --radius:16px; --radius-sm:12px; --gap:16px; --z-topbar:1030;

    /* Topbar (suit le thème) */
    --topbar-bg:var(--surface);
    --topbar-ink:var(--text);
    --topbar-hover:rgba(0,0,0,.06);

    /* Accents optionnels */
    --accent:#b25996; --accent-contrast:#fff; --accent-soft:rgba(178,89,150,.12);
    --red:#e55d42; --gold:#af8855; --yellow:#ffb30c; --grey-300:#ccc;
}

/* DARK aliased: .theme-dark OR html.dark OR body.dark */
.theme-dark, html.dark, body.dark{
    --bg:#0b0b0c;
    --surface:#141416;
    --surface-2:#121316;

    --text:#f3f4f6;
    --muted:#9aa0ae;

    --primary:#6ee7ff;
    --primary-ink:#06121a;
    --primary-soft:rgba(110,231,255,.12);

    --success:#22c55e;
    --warning:#fbbf24;
    --danger:#f87171;
    --info:#22d3ee;

    --border:#26272b;
    --ring:rgba(110,231,255,.28);
    --shadow:0 10px 30px rgba(0,0,0,.35);

    --topbar-bg:var(--surface);
    --topbar-ink:var(--text);
    --topbar-hover:rgba(255,255,255,.08);
}

html,body{height:100%}
body{
    margin:0; background:var(--bg); color:var(--text);
    font:14px/1.45 ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial;
    -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
*{box-sizing:border-box}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}
:focus-visible{outline:2px solid var(--ring);outline-offset:2px;border-radius:10px}

/* Transitions douces lors du switch thème */
html, body, .navbar.header, .client-sidebar, .panel_s, .card, .table, .dropdown-menu{
    transition:background-color .2s ease, color .2s ease, border-color .2s ease;
}

/* Utils */
.muted{color:var(--muted)}
.mt{margin-top:16px}
.hidden-xs{display:none}
@media (min-width:1280px){.hidden-xs{display:inline}}
.badge{
    display:inline-flex;align-items:center;gap:6px;
    font-size:11px;padding:3px 8px;border-radius:999px;
    border:1px solid var(--border);background:var(--surface-2);color:var(--text);
}

/* ===========================
   TOPBAR (icons only + tooltips) — propre & aligné
   =========================== */
.navbar.header{
    background: var(--topbar-bg) !important;
    border: 0;
    border-bottom: 1px solid var(--border);
    border-radius: 0;
    margin: 0;
    position: sticky;
    top: 0;
    z-index: var(--z-topbar);
    min-height: 64px;
}

/* Le conteneur de la topbar s'aligne sur la grille layout */
.navbar.header .container{
    max-width: none;         /* override .container { max-width:1200px } */
    width: 100%;
    padding-left: var(--gap);   /* aligné sur le bord gauche (sidebar) */
    padding-right: var(--gap);  /* aligné sur le bord droit (contenu)  */
    display: flex;
    align-items: center;        /* centrage vertical */
    justify-content: space-between;
    min-height: 64px;
}

/* Groupe gauche : burger + bouton sidebar + logo */
.navbar.header .navbar-header{
    display: flex;
    align-items: center;
    gap: 8px;
    margin-right: auto;         /* pousse les icônes à droite */
}
.navbar.header .navbar-toggle{ border: 0; margin-right: 6px; }
.navbar.header .navbar-toggle .icon-bar{ background: var(--topbar-ink); }
.navbar.header .navbar-brand{
    display: flex; align-items: center;
    padding: 10px 12px;
    margin-left: 0;
}
.navbar.header .navbar-brand img{ max-height: 28px; }

/* Groupe droit : icônes */
.topbar-actions{ display: flex; align-items: center; margin: 0; }
.topbar-actions > li > a.topbar-icon,
.topbar-actions > li > button.topbar-icon{
    display: flex; align-items: center; justify-content: center;
    width: 40px; height: 40px; margin: 12px 6px;
    border-radius: 12px; border: 0;
    color: var(--topbar-ink); background: transparent;
}
.topbar-actions > li > a.topbar-icon:hover,
.topbar-actions > li > button.topbar-icon:hover{
    background: var(--topbar-hover); text-decoration: none;
}
.topbar-actions > li.active > a.topbar-icon{ background: var(--topbar-hover); }
.topbar-actions i{ font-size: 18px; line-height: 1; }
.topbar-avatar img{ width: 36px; height: 36px; border-radius: 50%; object-fit: cover; }

/* Dropdown profil (contraste thème) */
.navbar.header .dropdown-menu{
    border-radius: 12px;
    border: 1px solid var(--border);
    padding: 8px; min-width: 220px;
    box-shadow: var(--shadow);
}
.navbar.header .dropdown-menu > li > a{ padding: 8px 12px; color: var(--text); }
.navbar.header .dropdown-menu > li > a:hover{ background: var(--primary-soft); color: var(--text); }

/* Desktop : garder la nav à droite quand le collapse est ouvert */
@media (min-width: 768px){
    .navbar.header .navbar-collapse{
        display: flex !important;
        align-items: center;
        justify-content: flex-end;   /* tout à droite */
        margin-left: auto;
    }
    .navbar.header .navbar-right{
        display: flex; align-items: center; margin: 0;
    }
}


/* ===========================
   Layout & Sidebar
   =========================== */
.layout{display:grid;grid-template-columns:258px 1fr;gap:var(--gap);padding:var(--gap)}
@media (max-width:992px){.layout{grid-template-columns:1fr}}

.client-sidebar{
    position:sticky;top:calc(64px + var(--gap));align-self:start;height:calc(100dvh - 96px);
    background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
    padding:12px;box-shadow:var(--shadow);display:flex;flex-direction:column;
}
.sidebar-title{
    font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.06em;
    color:var(--muted);margin:4px 8px 8px
}
.sidebar-nav{list-style:none;padding:0;margin:0}
.sidebar-nav li a{
    display:flex;align-items:center;gap:10px;padding:10px 12px;margin:4px;border-radius:12px;
    color:var(--text);text-decoration:none;border:1px solid transparent
}
.sidebar-nav li a:hover{background:rgba(0,0,0,.04)}
.theme-dark .sidebar-nav li a:hover{background:rgba(255,255,255,.05)}
.sidebar-nav li a i{width:18px;text-align:center}
.sidebar-nav li a.active{background:rgba(0,0,0,.06);font-weight:600}
.theme-dark .sidebar-nav li a.active{background:rgba(255,255,255,.06)}
.sidebar-section.muted a{display:flex;align-items:center;gap:10px;color:var(--muted);padding:8px 12px;text-decoration:none}
.sidebar-footer{margin-top:auto;padding:8px 12px;border-top:1px dashed var(--border)}
.client-sidebar.collapsed{width:64px;overflow:hidden;padding:8px}
.client-sidebar.collapsed .sidebar-title,.client-sidebar.collapsed .sidebar-section.muted,.client-sidebar.collapsed .sidebar-footer{display:none}
.client-sidebar.collapsed .sidebar-nav li a{justify-content:center}

/* Cacher l'ancien sous-menu horizontal Perfex */
ul.submenu.customer-top-submenu{display:none}

/* ===========================
   Content / Cards / Panels
   =========================== */
.client-page{min-height:calc(100dvh - 96px)}
.panel_s,.card{
    background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)
}
.panel_s>.panel-body,.card .card-body{padding:16px}
.panel_s>.panel-heading,.card .card-header{
    padding:14px 16px;border-bottom:1px solid var(--border);font-weight:600;color:var(--text);background:var(--surface)
}
h1,h2,h3{color:var(--text)}
.dash .dash-title{font-size:28px;font-weight:800;margin:16px 0}
.kpi .value{font-size:28px;font-weight:800}
.kpi .sub{font-size:12px;color:var(--muted)}

/* ===========================
   Forms
   =========================== */
.form-control,.bootstrap-select .btn{
    background:var(--surface);color:var(--text);
    border:1px solid var(--border);border-radius:10px;box-shadow:none
}
.form-control:focus,.bootstrap-select .btn:focus{border-color:transparent;box-shadow:0 0 0 3px var(--ring)}
.input-group .input-group-addon{background:var(--surface);border:1px solid var(--border);color:var(--muted);border-radius:10px}
.bootstrap-select .dropdown-menu{border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow)}

/* ===========================
   Tables / DataTables
   =========================== */
.table{background:var(--surface)}
.table>thead>tr>th{
    background:var(--surface-2);color:var(--text);border-bottom:1px solid var(--border);font-weight:600
}
.table>tbody>tr>td{border-top:1px solid var(--border);color:var(--text)}
.table-hover>tbody>tr:hover{background:rgba(0,0,0,.03)}
.theme-dark .table-hover>tbody>tr:hover{background:rgba(255,255,255,.04)}

.dataTables_wrapper .dataTables_length select{
    border:1px solid var(--border);border-radius:10px;padding:6px 8px;background:var(--surface);color:var(--text)
}
.dataTables_wrapper .dataTables_filter input{
    border:1px solid var(--border);border-radius:10px;padding:8px 10px;background:var(--surface);color:var(--text)
}
.dataTables_wrapper .paginate_button{
    border-radius:10px!important;border:1px solid var(--border)!important;background:var(--surface)!important;color:var(--text)!important;margin:0 2px
}
.dataTables_wrapper .paginate_button.current{background:var(--primary-soft)!important;border-color:transparent!important;font-weight:700}
.dataTables_wrapper .dataTables_info{color:var(--muted)}

/* ===========================
   Progress bars / Status
   =========================== */
.progress{height:10px;background:var(--surface-2);border-radius:999px;box-shadow:inset 0 0 0 1px var(--border)}
.progress-bar{border-radius:999px}
.progress-bar-success{background-color:var(--success)}
.progress-bar-warning{background-color:var(--warning)}
.progress-bar-danger{background-color:var(--danger)}

.label,.badge{border-radius:999px;padding:4px 8px;font-size:11px}
.label-success,.badge-success{background:rgba(34,197,94,.12);color:#16a34a;border:1px solid rgba(34,197,94,.18)}
.label-warning,.badge-warning{background:rgba(245,158,11,.12);color:#b45309;border:1px solid rgba(245,158,11,.2)}
.label-danger,.badge-danger{background:rgba(239,68,68,.12);color:#b91c1c;border:1px solid rgba(239,68,68,.2)}

/* ===========================
   Buttons
   =========================== */
.btn{border-radius:10px;font-weight:600}
.btn-primary{background:var(--primary);border-color:var(--primary)}
.btn-primary:hover{filter:brightness(.95)}
.btn-default,.btn-white{background:var(--surface);border-color:var(--border);color:var(--text)}
.btn-link{color:var(--primary);text-decoration:none}
.btn-link:hover{text-decoration:underline}

/* Variantes couleur (optionnelles) */
.btn--black{color:#fff!important;background:#262b2f!important;border-color:#262b2f!important}
.btn--tra-black{color:#262b2f!important;background:transparent!important;border:1px solid #262b2f!important}
.theme-dark .btn--black{color:#363636!important;background:#fff!important;border-color:#fff!important}
.theme-dark .btn--tra-black{color:#e5e5e5!important;border-color:#e5e5e5!important}
.btn--white{color:#363636!important;background:#fff!important;border-color:#fff!important}
.btn--tra-white{color:#fff!important;background:transparent!important;border:1px solid #fff!important}
.theme-dark .btn--tra-white{color:#fff!important;border-color:#fff!important}
.btn--gold{color:#fff!important;background:var(--gold)!important;border-color:var(--gold)!important}
.btn--tra-gold{color:var(--gold)!important;background:transparent!important;border:1px solid var(--gold)!important}
.btn--red{color:#fff!important;background:var(--red)!important;border-color:var(--red)!important}
.btn--tra-red{color:var(--red)!important;background:transparent!important;border:1px solid var(--red)!important}
.btn--magenta{color:var(--accent-contrast)!important;background:var(--accent)!important;border-color:var(--accent)!important}
.btn--tra-magenta{color:var(--accent)!important;background:transparent!important;border:1px solid var(--accent)!important}
.btn--magenta:hover,.btn--gold:hover,.btn--red:hover,.btn--black:hover,.btn--white:hover{filter:brightness(.96)}
.btn--tra-gold:hover,.btn--tra-red:hover,.btn--tra-magenta:hover,.btn--tra-white:hover,.btn--tra-black:hover{background:rgba(0,0,0,.03)}
.theme-dark .btn--tra-gold:hover,.theme-dark .btn--tra-red:hover,.theme-dark .btn--tra-magenta:hover,.theme-dark .btn--tra-white:hover,.theme-dark .btn--tra-black:hover{background:rgba(255,255,255,.05)}
.btn--magenta:focus,.btn--red:focus,.btn--gold:focus,.btn--black:focus,.btn--white:focus,
.btn--tra-magenta:focus,.btn--tra-red:focus,.btn--tra-gold:focus,.btn--tra-black:focus,.btn--tra-white:focus{outline:0;box-shadow:0 0 0 3px var(--ring)}

/* ===========================
   Media / Extras
   =========================== */
.relative{position:relative} canvas{background:transparent}
.flash{margin-bottom:12px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:10px 12px;box-shadow:var(--shadow)}
a.btn-link,.panel_s a,.card a{text-decoration:none}
a.btn-link:hover,.panel_s a:hover,.card a:hover{text-decoration:underline}
.container{max-width:1200px}
hr{border-color:var(--border)}
.popover,.tooltip-inner{color:#fff}

/* Accents utilitaires (facultatif) */
.color--grey,.color--grey *{color:var(--grey-300)!important}
.color--gold,.color--gold *{color:var(--gold)!important}
.color--magenta,.color--magenta *{color:var(--accent)!important}
.color--red,.color--red *{color:var(--red)!important}
.color--yellow,.color--yellow *{color:var(--yellow)!important}
.bg--black{background-color:#212223!important}
.bg--white{background-color:#fff!important}
.bg--red{background-color:var(--red)!important}
.bg--magenta{background-color:var(--accent)!important}
.bg--stone{background-color:#f5f5f5!important}
.bg--smoke{background-color:#f2f2f0!important}
.bg--ivory{background-color:#f8f5f2!important}
.bg--blush{background-color:#faf3f7!important}
.bg--poudre{background-color:#f9efed!important}
.theme-dark .bg--white,.theme-dark .bg--poudre,.theme-dark .bg--blush,.theme-dark .bg--ivory,.theme-dark .bg--smoke,.theme-dark .bg--stone{background-color:#1c1d1e!important}
.block-shadow{box-shadow:var(--shadow)!important}
.pe-6{padding-right:4rem!important}.pe-7{padding-right:5rem!important}
.pb-6{padding-bottom:4rem!important}.pb-7{padding-bottom:5rem!important}
.ps-6{padding-left:4rem!important}.ps-7{padding-left:5rem!important}
.grey-img img{filter:grayscale(100%)}
.hover-overlay{position:relative;overflow:hidden}
.hover-overlay img{transform:scale(1);transition:transform 400ms}
.hover-overlay:hover img{transform:scale(1.03)}
.item-overlay{position:absolute;inset:0;background:rgba(20,20,20,.5);opacity:0;transition:all 400ms}
.hover-overlay:hover .item-overlay{opacity:1}

/* ===========================
   Footer
   =========================== */
.client-footer{
    margin:24px;padding:14px 16px;background:var(--surface);
    border:1px solid var(--border);border-radius:var(--radius);color:var(--muted)
}
.client-footer__inner{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;text-align:center}
.client-footer__brand{font-weight:600;color:var(--text)}
.client-footer__sep{opacity:.4}
.client-footer a{color:inherit;text-decoration:underline}