/* ============================================================
   MySEVEN — Espace client. Charte alignée CRM SEVEN.
   ============================================================ */
:root{
  --primary:#2563EB; --primary-d:#1D4ED8; --active-bg:#E8F0FE;
  --green:#16A34A; --green-d:#15803D; --green-soft:#DCFCE7;
  --ink:#1E293B; --navy:#0F172A; --muted:#64748B; --muted-2:#94A3B8;
  --border:#E5EAF1; --bg:#F4F6FB; --card:#FFFFFF;
  --radius:12px; --radius-sm:8px;
  --sidebar-w:250px;
  --shadow-xs:0 1px 2px rgba(15,23,42,.05);
  --shadow:0 4px 14px rgba(15,23,42,.06);
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:'Inter',system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-size:14px; line-height:1.5; color:var(--ink); background:var(--bg);
  -webkit-font-smoothing:antialiased; min-height:100vh;
}
a{color:var(--primary);text-decoration:none}
h1,h2,h3{color:var(--navy);margin:0}

/* ── Layout ── */
.app{display:flex;min-height:100vh}
.app-main{flex:1;min-width:0;display:flex;flex-direction:column}

/* ── Sidebar ── */
.sidebar{
  position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);background:var(--card);
  border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:600;
  overflow-y:auto;transition:transform .22s ease;
}
.sb-brand{display:flex;align-items:center;gap:.6rem;padding:1.15rem 1.2rem;border-bottom:1px solid var(--border)}
.sb-logo{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--primary),#4F46E5);
  display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:1rem;flex-shrink:0}
.sb-brand-txt{font-weight:800;font-size:1.05rem;color:var(--navy);letter-spacing:-.02em}
.sb-brand-txt span{color:var(--primary)}
.sb-nav{flex:1;padding:.7rem .7rem}
.sb-section{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;
  color:var(--muted-2);padding:.95rem .6rem .3rem}
.sb-link{display:flex;align-items:center;gap:.7rem;padding:.6rem .7rem;border-radius:var(--radius-sm);
  color:var(--muted);text-decoration:none;font-weight:500;font-size:.9rem;margin-bottom:.15rem;transition:.12s}
.sb-link svg{width:18px;height:18px;flex-shrink:0;stroke:currentColor;fill:none}
.sb-link:hover{background:#F8FAFC;color:var(--navy)}
.sb-link.active{background:var(--active-bg);color:var(--primary);font-weight:600}
.sb-link.soon{color:var(--muted-2);cursor:default}
.sb-link.soon:hover{background:transparent;color:var(--muted-2)}
.sb-soon-tag{margin-left:auto;font-size:.62rem;font-weight:600;color:var(--muted-2);
  background:#F1F5F9;border-radius:20px;padding:.05rem .45rem}
.sb-foot{padding:1rem 1.2rem;border-top:1px solid var(--border);color:var(--muted-2);font-size:.74rem}
.sb-foot a{color:var(--muted);font-weight:500}

/* ── Topbar ── */
.topbar{position:sticky;top:0;z-index:200;background:var(--card);border-bottom:1px solid var(--border);
  height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;gap:1rem}
.topbar-title{font-size:1.15rem;font-weight:700;color:var(--navy);min-width:0;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-right{display:flex;align-items:center;gap:.8rem;flex-shrink:0}
.user-chip{display:flex;align-items:center;gap:.55rem}
.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#4F46E5);
  color:#fff;font-weight:700;font-size:.78rem;display:flex;align-items:center;justify-content:center}
.user-name{font-weight:600;color:var(--ink);font-size:.85rem;max-width:200px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.switcher-form{margin:0}
.switcher{font-family:inherit;font-size:.85rem;font-weight:600;color:var(--ink);background:#fff;
  border:1px solid var(--border);border-radius:var(--radius-sm);padding:.4rem 1.8rem .4rem .6rem;
  cursor:pointer;max-width:220px;
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .55rem center}
.switcher:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.13)}
.btn-logout{display:inline-flex;align-items:center;gap:.4rem;border:1px solid var(--border);background:#fff;
  color:var(--muted);font-size:.82rem;font-weight:500;padding:.4rem .75rem;border-radius:var(--radius-sm);cursor:pointer}
.btn-logout:hover{background:#F8FAFC;color:var(--navy)}
.btn-logout svg{stroke:currentColor;fill:none}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:.3rem;color:var(--ink)}
.hamburger svg{width:24px;height:24px}

/* ── Content ── */
.content{flex:1;padding:1.6rem 1.5rem 2.5rem}
.flash{display:flex;align-items:center;gap:.6rem;padding:.7rem 1rem;border-radius:var(--radius-sm);
  margin-bottom:1rem;font-size:.88rem;font-weight:500}
.flash-error{background:#FEF2F2;color:#991B1B;border-left:4px solid #DC2626}
.flash-ok{background:var(--green-soft);color:var(--green-d);border-left:4px solid var(--green)}

/* ── KPI cards ── */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.3rem}
.kpi{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.1rem 1.15rem;box-shadow:var(--shadow-xs);position:relative}
.kpi-label{font-size:.76rem;color:var(--muted);font-weight:500;margin-bottom:.45rem;padding-right:2.6rem}
.kpi-value{font-size:1.7rem;font-weight:800;color:var(--navy);letter-spacing:-.02em;line-height:1.1}
.kpi-value .unit{font-size:.85rem;font-weight:600;color:var(--muted-2)}
.kpi-delta{font-size:.78rem;font-weight:600;margin-top:.35rem}
.kpi-delta.up{color:var(--green)}.kpi-delta.down{color:#DC2626}.kpi-delta.flat{color:var(--muted)}
.kpi-ic{position:absolute;top:1rem;right:1rem;width:34px;height:34px;border-radius:9px;
  display:flex;align-items:center;justify-content:center}
.kpi-ic svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2}
.ic-blue{background:var(--active-bg);color:var(--primary)}
.ic-green{background:var(--green-soft);color:var(--green-d)}
.ic-slate{background:#F1F5F9;color:var(--muted)}

/* ── Panels ── */
.panel{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow-xs);margin-bottom:1.3rem;overflow:hidden}
.panel-head{padding:.95rem 1.2rem;border-bottom:1px solid var(--border);display:flex;
  align-items:center;justify-content:space-between}
.panel-head h2{font-size:1rem;font-weight:700}
.panel-sub{font-size:.78rem;color:var(--muted);font-weight:400}
.panel-body{padding:1.2rem}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}

/* ── Chart ── */
.chart-wrap{position:relative;height:300px}

/* ── Top véhicules : barres horizontales vertes ── */
.vbars{display:flex;flex-direction:column;gap:.85rem}
.vbar-row{display:grid;grid-template-columns:1fr;gap:.3rem}
.vbar-top{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem}
.vbar-name{font-weight:600;color:var(--ink);font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vbar-name small{color:var(--muted-2);font-weight:400;margin-left:.4rem}
.vbar-val{font-weight:700;color:var(--green-d);font-size:.88rem;white-space:nowrap;font-variant-numeric:tabular-nums}
.vbar-track{background:#F1F5F9;border-radius:6px;height:10px;overflow:hidden}
.vbar-fill{background:linear-gradient(90deg,var(--green),#22C55E);height:100%;border-radius:6px}

/* ── Tableau ── */
.tbl{width:100%;border-collapse:collapse;font-size:.86rem}
.tbl th{text-align:left;color:var(--muted);font-weight:600;font-size:.76rem;text-transform:uppercase;
  letter-spacing:.03em;padding:.55rem .5rem;border-bottom:1px solid var(--border)}
.tbl td{padding:.6rem .5rem;border-bottom:1px solid #F1F5F9;color:var(--ink)}
.tbl tr:last-child td{border-bottom:none}
.tbl .r{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}
.tbl .mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.78rem;color:var(--muted)}
.pill-bio{display:inline-block;background:var(--green-soft);color:var(--green-d);
  font-size:.72rem;font-weight:600;padding:.12rem .55rem;border-radius:20px}
.pill-on{display:inline-block;background:var(--green-soft);color:var(--green-d);
  font-size:.72rem;font-weight:600;padding:.12rem .6rem;border-radius:20px}
.pill-off{display:inline-block;background:#F1F5F9;color:var(--muted);
  font-size:.72rem;font-weight:600;padding:.12rem .6rem;border-radius:20px}

/* ── Empty states ── */
.empty{padding:2.5rem 1rem;text-align:center;color:var(--muted)}
.empty svg{width:40px;height:40px;color:var(--muted-2);margin-bottom:.5rem;stroke:currentColor;fill:none;stroke-width:1.8}
.empty p{margin:.2rem 0 0;font-size:.9rem}

/* ── Auth (login / invite) ── */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:var(--bg)}
.auth-card{width:100%;max-width:400px;background:var(--card);border:1px solid var(--border);
  border-radius:16px;box-shadow:var(--shadow);padding:2.2rem 2rem}
.auth-brand{display:flex;align-items:center;justify-content:center;gap:.6rem;margin-bottom:.4rem}
.auth-brand .sb-logo{width:38px;height:38px}
.auth-brand-txt{font-weight:800;font-size:1.3rem;color:var(--navy)}
.auth-brand-txt span{color:var(--primary)}
.auth-sub{text-align:center;color:var(--muted);margin:0 0 1.5rem;font-size:.9rem}
.field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}
.field label{font-size:.82rem;font-weight:600;color:var(--ink)}
.field input{padding:.65rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);
  font-size:.95rem;font-family:inherit;color:var(--ink)}
.field input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.13)}
.hint{font-size:.78rem;color:var(--muted)}
.btn-primary{width:100%;background:var(--primary);color:#fff;border:none;padding:.7rem;
  border-radius:var(--radius-sm);font-weight:700;font-size:.95rem;cursor:pointer;font-family:inherit;margin-top:.3rem}
.btn-primary:hover{background:var(--primary-d)}
.src-note{color:var(--muted-2);font-size:.78rem;text-align:center;margin-top:.4rem}

/* ── Transactions : filtres / exports / pagination ── */
.kpis-3{grid-template-columns:repeat(3,1fr)}
.exports{display:flex;gap:.4rem}
.btn-export{display:inline-flex;align-items:center;gap:.3rem;border:1px solid var(--border);background:#fff;
  color:var(--primary);font-size:.8rem;font-weight:600;padding:.35rem .7rem;border-radius:var(--radius-sm);text-decoration:none}
.btn-export:hover{background:var(--active-bg)}
.filters{display:flex;flex-direction:column;gap:.85rem}
.preset-row{display:flex;flex-wrap:wrap;gap:.4rem}
.preset-btn{border:1px solid var(--border);background:#fff;color:var(--muted);font-size:.82rem;font-weight:500;
  padding:.4rem .8rem;border-radius:20px;cursor:pointer;font-family:inherit}
.preset-btn:hover{background:#F8FAFC;color:var(--navy)}
.preset-btn.active{background:var(--active-bg);color:var(--primary);border-color:rgba(37,99,235,.2);font-weight:600}
.filter-fields{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.7rem}
.ff{display:flex;flex-direction:column;gap:.25rem;font-size:.76rem;font-weight:600;color:var(--muted)}
.ff input,.ff select{padding:.45rem .55rem;border:1px solid var(--border);border-radius:var(--radius-sm);
  font-size:.88rem;font-family:inherit;color:var(--ink);background:#fff;min-width:140px}
.ff input:focus,.ff select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.btn-apply{background:var(--primary);color:#fff;border:none;padding:.5rem 1.1rem;border-radius:var(--radius-sm);
  font-weight:700;font-size:.85rem;cursor:pointer;font-family:inherit}
.btn-apply:hover{background:var(--primary-d)}
.btn-reset{align-self:center;color:var(--muted);font-size:.82rem;font-weight:500;padding:.5rem .2rem}
.btn-reset:hover{color:var(--navy)}
.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.1rem}
.pg-btn{border:1px solid var(--border);background:#fff;color:var(--primary);font-size:.85rem;font-weight:600;
  padding:.45rem .9rem;border-radius:var(--radius-sm);text-decoration:none}
.pg-btn:hover{background:var(--active-bg)}
.pg-btn.disabled{color:var(--muted-2);background:#F8FAFC;pointer-events:none}
.pg-info{font-size:.85rem;color:var(--muted);font-weight:500}
@media(max-width:700px){.filter-fields{flex-direction:column;align-items:stretch}.ff input,.ff select{min-width:0;width:100%}}

/* ── Admin : groupes / formulaires inline ── */
.grp-node{border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem .8rem;margin-bottom:.6rem}
.grp-row{display:flex;align-items:center;justify-content:space-between;gap:.8rem;flex-wrap:wrap;padding:.3rem 0}
.grp-child{padding-left:1.2rem;border-top:1px dashed var(--border)}
.grp-name{font-weight:600;color:var(--navy);font-size:.9rem}
.grp-count{font-weight:400;color:var(--muted-2);font-size:.78rem;margin-left:.3rem}
.grp-actions{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}
.inline-form{display:flex;gap:.35rem;align-items:center;flex-wrap:wrap;margin:0}
.grp-rename{padding:.3rem .5rem;border:1px solid var(--border);border-radius:6px;font-size:.82rem;font-family:inherit}
.grp-select{padding:.3rem .45rem;border:1px solid var(--border);border-radius:6px;font-size:.82rem;font-family:inherit;min-width:160px}
.chk-list{max-height:150px;overflow-y:auto;border:1px solid var(--border);border-radius:6px;
  padding:.45rem .55rem;display:flex;flex-direction:column;gap:.3rem;min-width:200px;background:#fff}
.chk{display:flex;align-items:center;gap:.45rem;font-size:.84rem;font-weight:500;color:var(--ink);cursor:pointer}
.chk input{width:auto;margin:0;flex-shrink:0}
.pg-btn.danger{color:#DC2626;border-color:#fecaca}
.pg-btn.danger:hover{background:#FEF2F2}
.btn-apply,.pg-btn{font-family:inherit}
details>summary{list-style:none;display:inline-block}
details>summary::-webkit-details-marker{display:none}

/* ── Sidebar overlay (mobile) ── */
.sb-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.35);z-index:550}
.table-scroll{overflow-x:auto}

/* ── Responsive ── */
@media(max-width:1100px){.kpis{grid-template-columns:repeat(2,1fr)}.grid2{grid-template-columns:1fr}}
@media(max-width:900px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .app-main{margin-left:0!important}
  .hamburger{display:inline-flex}
  .sb-overlay.show{display:block}
}
@media(min-width:901px){.app-main{margin-left:var(--sidebar-w)}}
@media(max-width:520px){
  .kpis{grid-template-columns:1fr}
  .content{padding:1.1rem 1rem 2rem}
  .topbar{padding:0 1rem}
  .user-name{display:none}
}
