:root{
  --bg:#f6f7f8; --panel:#fff; --line:#e4e6ea; --line2:#eceef1;
  --ink:#1c1e22; --ink2:#3b3f45; --muted:#6a7280;
  --black:#16171b; --black-h:#2a2c31;
  --link:#2456d6;
  --green:#0f9d58; --greenbg:#e3f5ea;
  --grey:#5f6670; --greybg:#eef0f3;
  --blue:#2456d6; --bluebg:#e4ebfc;
  --orange:#c9760a; --orangebg:#fcefd9;
  --yellow:#a8810a; --yellowbg:#fbf3d6;
  --red:#d23b3b; --redbg:#fbe5e5;
  --gbar:56px; --side:228px; --radius:10px;
  --shadow:0 1px 2px rgba(20,22,28,.05), 0 1px 3px rgba(20,22,28,.04);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}
a{color:var(--link);text-decoration:none}
a:hover{text-decoration:underline}
.muted{color:var(--muted)}
code{background:var(--greybg);padding:1px 6px;border-radius:5px;font-size:12px;font-family:ui-monospace,Menlo,Consolas,monospace}

/* ===== Top bar globale ===== */
.gbar{position:fixed;top:0;left:0;right:0;height:var(--gbar);background:var(--panel);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px;padding:0 16px;z-index:50}
.gbar-left{display:flex;align-items:center;gap:10px;width:var(--side);flex:0 0 auto}
.burger{display:flex;border:0;background:none;color:var(--ink2);cursor:pointer;padding:6px;border-radius:7px}
.burger:hover{background:var(--greybg)}
.burger svg{width:20px;height:20px}
.brand{display:flex;align-items:center;gap:9px;color:var(--ink);font-weight:700;font-size:17px;letter-spacing:-.02em}
.brand:hover{text-decoration:none}
.brand-mark{width:28px;height:28px;border-radius:8px;background:var(--black);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px}
.gbar-search{flex:1;max-width:560px;display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:0 12px;height:38px}
.gbar-search svg{width:16px;height:16px;color:var(--muted);flex:0 0 auto}
.gbar-search input{flex:1;border:0;background:none;outline:none;font-size:14px;color:var(--ink);font-family:inherit}
.kbd{font-size:11px;color:var(--muted);border:1px solid var(--line);border-radius:5px;padding:1px 6px;background:#fff}
.gbar-right{display:flex;align-items:center;gap:10px;flex:0 0 auto}
.ai-btn{display:flex;align-items:center;gap:7px;border:1px solid var(--line);background:#fff;border-radius:9px;padding:8px 12px;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer}
.ai-btn:hover{background:var(--bg)}
.ai-dot{width:9px;height:9px;border-radius:50%;background:linear-gradient(135deg,#7c5cff,#2456d6)}
.icon-btn{position:relative;display:flex;border:0;background:none;color:var(--ink2);cursor:pointer;padding:7px;border-radius:8px}
.icon-btn:hover{background:var(--greybg)}
.icon-btn svg{width:20px;height:20px}
.bell-badge{position:absolute;top:0;right:0;background:var(--red);color:#fff;font-size:10px;font-weight:700;border-radius:9px;padding:0 4px;min-width:16px;height:16px;display:flex;align-items:center;justify-content:center}
.upsell{font-size:13px;font-weight:600;color:var(--ink);border:1px solid var(--line);border-radius:9px;padding:8px 12px}
.upsell:hover{background:var(--bg);text-decoration:none}
.assist{font-size:13px;color:var(--muted);padding:0 6px}
@media(max-width:980px){.upsell,.assist,.ai-btn span{display:none}}

/* ===== Layout ===== */
.app{display:flex;margin-top:var(--gbar);min-height:calc(100vh - var(--gbar))}
.sidebar{position:fixed;top:var(--gbar);bottom:0;left:0;width:var(--side);background:var(--panel);border-right:1px solid var(--line);display:flex;flex-direction:column;overflow-y:auto}
.main{flex:1;margin-left:var(--side);min-width:0}
body.collapsed .sidebar{display:none}
body.collapsed .main{margin-left:0}

/* ===== Sidebar nav ===== */
.sidebar nav{padding:10px 10px 0}
.nav-group{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600;padding:14px 10px 5px}
.nav-item{display:flex;align-items:center;gap:11px;padding:8px 10px;color:var(--ink2);border-radius:8px;margin-bottom:1px;font-weight:500;position:relative}
.nav-item svg{width:18px;height:18px;flex:0 0 18px;color:var(--muted)}
.nav-item:hover{background:var(--greybg);text-decoration:none;color:var(--ink)}
.nav-item.active{background:#eef0f3;color:var(--black);font-weight:600}
.nav-item.active svg{color:var(--black)}
.nav-new{margin-left:auto;font-size:10px;font-weight:700;color:var(--green);background:var(--greenbg);border-radius:6px;padding:1px 6px;text-transform:uppercase;letter-spacing:.02em}
.sidebar-foot{margin-top:auto;padding:12px 12px;border-top:1px solid var(--line)}
.who{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.avatar{width:32px;height:32px;border-radius:50%;background:var(--black);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex:0 0 32px}
.who-name{font-weight:600;font-size:13px;line-height:1.2}
.who-role{font-size:11px;color:var(--muted);text-transform:capitalize}
.foot-links{font-size:12px;color:var(--muted)}
.foot-links a{color:var(--muted)}

/* ===== Content ===== */
.content{padding:28px 32px;max-width:1240px;width:100%}
.flash{margin:16px 32px -4px;padding:11px 15px;background:var(--bluebg);border:1px solid #c5d4f7;border-radius:9px;color:#1c3a8a;font-size:13px;font-weight:500}

.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;gap:14px;flex-wrap:wrap}
.page-head h1{font-size:24px;margin:0;font-weight:700;letter-spacing:-.02em}
.count{font-size:13px;color:var(--muted);font-weight:500;letter-spacing:0}
.head-actions{display:flex;gap:8px;align-items:center}

/* ===== KPI ===== */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:22px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px;box-shadow:var(--shadow)}
.kpi-val{font-size:28px;font-weight:700;letter-spacing:-.02em}
.kpi-label{color:var(--muted);font-size:13px;margin-top:5px}

/* ===== Cards ===== */
.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:20px;margin-bottom:18px;box-shadow:var(--shadow)}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:10px}
.card-head h2{font-size:15px;margin:0;font-weight:650}
.cols{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:820px){.cols{grid-template-columns:1fr}.content{padding:20px}}

/* ===== Tables ===== */
.table{width:100%;border-collapse:collapse}
.table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:600;padding:9px 10px;border-bottom:1px solid var(--line)}
.table td{padding:12px 10px;border-bottom:1px solid var(--line2);vertical-align:middle}
.table tbody tr:hover{background:#fafbfc}
.table tr:last-child td{border-bottom:0}

/* ===== Badges ===== */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;line-height:1.3}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.9}
.badge-green{background:var(--greenbg);color:var(--green)}
.badge-grey{background:var(--greybg);color:var(--grey)}
.badge-blue{background:var(--bluebg);color:var(--blue)}
.badge-orange{background:var(--orangebg);color:var(--orange)}
.badge-yellow{background:var(--yellowbg);color:var(--yellow)}
.badge-red{background:var(--redbg);color:var(--red)}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 15px;border:1px solid var(--line);background:var(--panel);border-radius:9px;cursor:pointer;font-size:13px;font-weight:600;color:var(--ink);font-family:inherit;line-height:1.2;transition:background .12s,border-color .12s}
.btn:hover{background:var(--bg);text-decoration:none;border-color:#d4d7dc}
.btn-primary{background:var(--black);color:#fff;border-color:var(--black)}
.btn-primary:hover{background:var(--black-h);border-color:var(--black-h)}
.btn-sm{padding:6px 11px;font-size:12.5px}
.btn-danger{color:var(--red);border-color:#f0c4c4}
.btn-danger:hover{background:var(--redbg);border-color:#e6a9a9}
.btn-block{width:100%;justify-content:center}
.btn:disabled{opacity:.45;cursor:not-allowed}
.inline{display:inline-block}
.link{color:var(--link);font-weight:500}

/* ===== Forms ===== */
label{display:block;margin-bottom:14px;font-size:13px;font-weight:600;color:var(--ink2)}
input,select,textarea{width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:9px;font-size:14px;font-weight:400;margin-top:6px;background:#fff;font-family:inherit;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--black);box-shadow:0 0 0 3px rgba(22,23,27,.08)}
textarea.code{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:13px;line-height:1.5}
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px}
.filters{display:flex;gap:10px;margin-bottom:18px;align-items:flex-start;flex-wrap:wrap}
.filters input,.filters select{margin-top:0;max-width:360px}
.kv{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line2);font-size:13px}
.kv:last-child{border-bottom:0}
.kv span{color:var(--muted)}
.pager{display:flex;gap:14px;align-items:center;justify-content:center;margin-top:10px}
.hidden{display:none}

/* Compléments */
.role-tag{font-size:10px;text-transform:uppercase;background:var(--greybg);color:var(--grey);padding:1px 6px;border-radius:6px;letter-spacing:.03em}
.chk{display:flex;align-items:center;gap:8px;font-weight:400}
.chk input{width:auto;margin:0}
.code-block{background:#15171c;color:#e2e8f0;padding:14px;border-radius:9px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12px;overflow:auto;white-space:pre-wrap;word-break:break-all;margin:0}
.seg-match{background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:11px 13px;margin:14px 0;font-size:14px}
.seg-match select{width:auto;display:inline-block;margin:0 4px}
.rule{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.rule select,.rule input{margin:0}
.rule .r-field{flex:0 0 220px}
.rule .r-op{flex:0 0 160px}
.rule .r-value{flex:1}

/* ===== Login ===== */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg)}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:36px;width:360px;box-shadow:0 12px 50px rgba(20,22,28,.08)}
.brand-big{font-size:26px;font-weight:800;text-align:center;letter-spacing:-.02em;display:flex;align-items:center;justify-content:center;gap:10px}
.login-card .muted{text-align:center;margin:6px 0 22px}
.error{background:var(--redbg);color:var(--red);padding:10px 13px;border-radius:9px;margin-bottom:16px;font-size:13px}
