/* ===== LDS Repair Manager — charte "Ardoise claire" (direction A) ===== */
:root{
  --canvas:#F8FAFC; --brand:#00A86B; --brand-600:#00875A; --accent:#00897B; --ink:#0F172A;
  --surface:#fff; --line:#e6ebe9; --line-soft:#eef2f0; --muted:#51616f; --muted-2:#94a3b1;
  --ok:#10b981; --warn:#f59e0b; --hot:#e11d48;
  /* statuts */
  --st-depose:#64748b; --st-diagnostic:#3b82f6; --st-attente:#f59e0b;
  --st-intervention:#8b5cf6; --st-termine:#10b981; --st-restitue:#14b8a6;
  --radius:14px; --radius-sm:10px;
  --shadow-sm:0 1px 2px rgba(17,24,39,.05); --shadow:0 4px 14px rgba(17,24,39,.07);
  --shadow-lg:0 18px 50px rgba(17,24,39,.16);
}
*{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:var(--brand);display:grid;place-items:center;color:#fff;font-weight:800;font-size:15px}
.brand .name{font-weight:800;font-size:15.5px;line-height:1.1;color:#00897B}
.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:#00897B;transition:.15s}
.nav-item svg{width:18px;height:18px}
.nav-item:hover{background:var(--line-soft);color:var(--ink)}
.nav-item.active{background:#e8eaee;color:#00897B}
.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:#374151;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;color:#00897B}
.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 2px 8px rgba(0,168,107,.22)}
.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;color:#00897B}
.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;color:#00897B}
.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(--muted);background:#eef0f2;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: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:var(--brand);display:grid;place-items:center;color:#fff;font-weight:800;font-size:19px;margin:0 auto 18px}
.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:#f7f8fa;transition:.15s}
.field input:focus{outline:none;border-color:var(--brand);background:#fff;box-shadow:0 0 0 3px rgba(0,168,107,.14)}
.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)}}
