:root{--ink:#f4f7fb;--surface:#fff;--surface-2:#eef2f8;--line:#e3e9f1;--line-2:#d9e0ea;--text:#1a2330;--muted:#516072;--muted-2:#7c8696;--blue:#1f6feb;--blue-soft:#e6f1fb;--green:#1f9d63;--green-soft:#e7f6ee;--amber:#c98a12;--amber-soft:#faf0d9;--danger:#d6463a;--danger-soft:#fbeceb;--violet:#6c5ce7;--radius:14px}*{box-sizing:border-box}body,html{padding:0;margin:0}body{background:var(--ink);color:var(--text);font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.wrap{max-width:1160px;margin:0 auto;padding:24px 20px 70px}.appbar{background:var(--surface);border-bottom:1px solid var(--line);position:-webkit-sticky;position:sticky;top:0;z-index:20}.appbar-in{max-width:1160px;margin:0 auto;padding:12px 20px;gap:18px;flex-wrap:wrap}.appbar-in,.brand{display:flex;align-items:center}.brand{gap:10px}.logo{width:34px;height:34px;border-radius:9px;background:var(--blue);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}.brand b{font-size:17px;letter-spacing:-.3px}.nav{display:flex;gap:4px;flex-wrap:wrap;flex:1 1}.nav a{font-size:14px;padding:8px 12px;border-radius:8px;color:var(--muted)}.nav a.on{background:var(--blue-soft);color:#0c447c;font-weight:600}.nav a:hover{background:var(--surface-2)}.grid{display:grid;grid-gap:16px;gap:16px}.kpis{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));margin-bottom:16px}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px}.card h2{font-size:14px;color:var(--muted);margin:0 0 4px;font-weight:600}.card .sub{font-size:12px;color:var(--muted-2);margin:0 0 14px}.kpi .l{font-size:13px;color:var(--muted)}.kpi .v{font-size:26px;font-weight:700;margin:4px 0 2px;letter-spacing:-.5px}.tile{background:var(--surface-2);border-radius:10px;padding:12px 14px}.tile .l{font-size:11px;color:var(--muted-2);text-transform:uppercase;letter-spacing:.4px}.tile .v{font-size:19px;font-weight:600;margin-top:3px}.page-title{font-size:22px;font-weight:700;letter-spacing:-.3px;margin:4px 0 18px}table{width:100%;border-collapse:collapse}th{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted-2);text-align:left;font-weight:600;padding:0 10px 10px}td{padding:12px 10px;border-top:1px solid var(--line);font-size:14px}.pill{font-size:12px;padding:3px 11px;border-radius:30px;white-space:nowrap;font-weight:600;display:inline-block}.st-online{background:var(--green-soft);color:var(--green)}.st-offline{background:var(--danger-soft);color:var(--danger)}.st-success{background:var(--green-soft);color:var(--green)}.st-warning{background:var(--amber-soft);color:var(--amber)}.st-danger{background:var(--danger-soft);color:var(--danger)}.pill.annuaire{background:var(--blue-soft);color:#0c447c}.pill.boutique{background:#efeafe;color:#4b34a8}.pill.autre{background:var(--surface-2);color:var(--muted)}.dot{width:9px;height:9px;border-radius:50%;display:inline-block;margin-right:8px;background:var(--green)}.dot.off{background:var(--danger)}.btn{border:none;border-radius:9px;background:var(--blue);color:#fff;font:inherit;font-weight:600;padding:10px 18px;cursor:pointer;display:inline-block}.btn.ghost{background:transparent;color:var(--text);border:1px solid var(--line-2)}.btn.danger{background:var(--danger)}.btn.sm{padding:7px 12px;font-size:13px}.field{display:block;margin-bottom:14px}.field label{display:block;font-size:13px;color:var(--muted);margin-bottom:5px;font-weight:600}.field input,.field select{width:100%;padding:11px 13px;border:1px solid var(--line-2);border-radius:9px;font:inherit;background:var(--surface);color:var(--text)}.row-actions{display:flex;gap:14px;align-items:center}.link{color:var(--blue);font-weight:600;font-size:14px;background:none;border:none;cursor:pointer;padding:0;font-family:inherit}.link.danger{color:var(--danger)}.note{font-size:12px}.empty,.note{color:var(--muted-2)}.empty{font-size:14px;padding:8px 0}.notice{padding:11px 14px;border-radius:10px;font-size:14px;margin-bottom:16px}.notice.ok{background:var(--green-soft);color:var(--green)}.alert-line,.notice.err{background:var(--danger-soft);color:var(--danger)}.alert-line{display:flex;align-items:center;gap:10px;padding:11px 13px;border-radius:9px;margin-bottom:8px;font-size:13px}.mono{font-family:IBM Plex Mono,ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.92em}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.login-card{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:32px;width:100%;max-width:380px;box-shadow:0 10px 40px rgba(20,30,50,.08)}.login-card .logo{margin:0 auto 14px}.login-card h1{text-align:center;font-size:20px;margin:0 0 4px}.login-card p.sub{text-align:center;color:var(--muted-2);font-size:13px;margin:0 0 22px}.seg{display:inline-flex;background:var(--surface-2);border-radius:10px;padding:3px;gap:2px;flex-wrap:wrap}.seg a{font-size:13px;padding:7px 13px;border-radius:7px;color:var(--muted)}.seg a.on{background:var(--surface);font-weight:600;box-shadow:0 1px 3px rgba(20,30,50,.1)}.seg a.on,.seg a:hover{color:var(--text)}.period-row{gap:14px;margin-bottom:18px}.custom-form,.period-row{display:flex;align-items:center;flex-wrap:wrap}.custom-form{gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:8px 12px}.custom-form label{font-size:13px;color:var(--muted)}.custom-form input{padding:7px 9px;border:1px solid var(--line-2);border-radius:7px;font:inherit;color:var(--text)}