/* ===== LDS Repair Manager — charte ===== */
:root{
  --canvas:#d8e9ff; --brand:#004AAD; --brand-600:#003a87; --ink:#162a68;
  --surface:#fff; --line:#d2e0f7; --line-soft:#e6eefc; --muted:#5d6f9e; --muted-2:#8595bd;
  --ok:#0f9d6b; --warn:#e8830c; --hot:#e11d48;
  --radius:14px; --radius-sm:10px;
  --shadow-sm:0 1px 3px rgba(22,42,104,.08); --shadow:0 4px 14px rgba(22,42,104,.10);
  --shadow-lg:0 18px 50px rgba(22,42,104,.22);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Plus Jakarta Sans',system-ui,Segoe UI,sans-serif;background:var(--canvas);color:var(--ink);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}

/* Layout app */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.sidebar{background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:18px 14px;gap:4px;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:11px;padding:8px 10px 18px}
.brand .logo{width:38px;height:38px;border-radius:11px;background:linear-gradient(140deg,var(--brand),#0a63d6);display:grid;place-items:center;color:#fff;font-weight:800;font-size:15px;box-shadow:0 6px 16px rgba(0,74,173,.35)}
.brand .name{font-weight:800;font-size:15.5px;line-height:1.1}
.brand .name span{display:block;font-weight:500;font-size:11px;color:var(--muted-2)}
.nav-label{font-size:10.5px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--muted-2);padding:14px 12px 6px}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:600;color:var(--muted);transition:.15s}
.nav-item svg{width:18px;height:18px}
.nav-item:hover{background:var(--line-soft);color:var(--ink)}
.nav-item.active{background:var(--brand);color:#fff;box-shadow:0 6px 16px rgba(0,74,173,.28)}
.sidebar .bottom{margin-top:auto;border-top:1px solid var(--line-soft);padding-top:12px}
.user-chip{display:flex;align-items:center;gap:10px;padding:8px 10px}
.avatar{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,#162a68,#2d4aa3);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px}
.user-chip .u-name{font-size:13px;font-weight:700}
.user-chip .u-role{font-size:11px;color:var(--muted-2)}
.logout-btn{width:100%;margin-top:8px;height:36px;border:1px solid var(--line);background:#fff;border-radius:10px;font-family:inherit;font-weight:700;font-size:12.5px;color:var(--muted);cursor:pointer;transition:.15s}
.logout-btn:hover{border-color:var(--hot);color:var(--hot)}

.main{display:flex;flex-direction:column}
.topbar{height:64px;background:var(--surface);border-bottom:1px solid var(--line);display:flex;align-items:center;padding:0 24px}
.page-title{font-weight:800;font-size:18px}
.content{padding:24px}

/* Boutons */
.btn{height:40px;padding:0 16px;border-radius:11px;border:1px solid transparent;font-family:inherit;font-weight:700;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:.15s}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 6px 16px rgba(0,74,173,.26)}
.btn-primary:hover{background:var(--brand-600)}

/* KPI */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm)}
.kpi .val{font-weight:800;font-size:30px;line-height:1}
.kpi .lbl{font-size:12.5px;color:var(--muted);font-weight:600;margin-top:6px}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.panel-h{padding:16px 18px;border-bottom:1px solid var(--line-soft);font-weight:800;font-size:14.5px}
.recent-row{display:flex;align-items:center;gap:12px;padding:11px 18px;border-bottom:1px solid var(--line-soft);font-size:13px}
.recent-row:last-child{border-bottom:none}
.rep-num{font-family:'IBM Plex Mono',monospace;font-weight:600;font-size:12px;color:var(--brand);background:#eaf2ff;padding:3px 8px;border-radius:7px}
.empty{padding:40px;text-align:center;color:var(--muted-2);font-size:13.5px}

/* Connexion */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:20px;background:radial-gradient(1200px 600px at 50% -10%, #eaf2ff, var(--canvas))}
.login-card{width:100%;max-width:400px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-lg);padding:34px 30px}
.login-logo{width:54px;height:54px;border-radius:15px;background:linear-gradient(140deg,var(--brand),#0a63d6);display:grid;place-items:center;color:#fff;font-weight:800;font-size:19px;margin:0 auto 18px;box-shadow:0 8px 20px rgba(0,74,173,.32)}
.login-card h1{font-size:20px;font-weight:800;text-align:center}
.login-card .sub{text-align:center;font-size:13px;color:var(--muted);margin:6px 0 24px}
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;font-weight:700;color:var(--muted);margin-bottom:6px}
.field input{width:100%;height:44px;border:1px solid var(--line);border-radius:11px;padding:0 14px;font-family:inherit;font-size:14px;color:var(--ink);background:#f7faff;transition:.15s}
.field input:focus{outline:none;border-color:var(--brand);background:#fff;box-shadow:0 0 0 3px rgba(0,74,173,.12)}
.login-card .btn-primary{width:100%;justify-content:center;height:46px;margin-top:6px}
.remember{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted);margin-bottom:16px}
.alert{background:#fde7ec;border:1px solid #f6c6d1;color:#b91c4a;font-size:12.5px;font-weight:600;padding:10px 13px;border-radius:10px;margin-bottom:16px}

@media(max-width:900px){.app{grid-template-columns:1fr}.sidebar{display:none}.kpis{grid-template-columns:repeat(2,1fr)}}
