*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:Arial,sans-serif;font-size:13px;background:#d6e4ec;min-height:100vh;}
.page{display:none!important;}
.page.active{display:block!important;}
#page-login.active{display:flex!important;align-items:center;justify-content:center;min-height:100vh;flex-direction:column;}
#page-map.active,#page-historique.active{display:flex!important;flex-direction:column;min-height:100vh;overflow:hidden;}

.topbar{background:#222;border-bottom:2px solid #444;padding:0 12px;height:38px;display:flex;align-items:center;gap:6px;position:sticky;top:0;z-index:100;}
.tb-btn{width:26px;height:26px;background:#333;border:1px solid #555;border-radius:4px;cursor:pointer;color:#ccc;font-size:13px;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;}
.tb-btn:hover{background:#444;}
.tb-right{margin-left:auto;display:flex;gap:10px;align-items:center;}
.tb-link{color:#ccc;cursor:pointer;font-size:12px;}
.tb-link:hover{color:#5cb85c;}
.tb-sep{width:1px;height:16px;background:#555;}

.login-wrap{display:flex;width:780px;max-width:97vw;border-radius:8px;overflow:hidden;box-shadow:0 6px 28px rgba(0,0,0,.55);}
.login-left{flex:1;background:linear-gradient(135deg,#1a2a1a,#2d3a2d,#1a1a1a);display:flex;align-items:center;justify-content:center;font-size:70px;min-height:340px;}
.login-right{width:285px;background:#2a2a2a;padding:22px 18px;display:flex;flex-direction:column;align-items:center;}
.logo{font-size:26px;font-weight:900;margin-bottom:14px;}
.logo-g{color:#5cb85c;}.logo-n{color:#1e9b9b;}
.lf{width:100%;display:flex;align-items:center;gap:5px;margin-bottom:7px;}
.lf label{font-size:11px;font-weight:bold;color:#ccc;font-style:italic;min-width:84px;}
.lf input,.lf select{flex:1;padding:5px 7px;border:1px solid #888;border-radius:3px;background:#f5f5f5;font-size:12px;}
.btn-conn{background:#1e90d4;color:#fff;border:none;border-radius:4px;padding:8px 20px;font-size:13px;font-weight:bold;cursor:pointer;margin-top:6px;}
.btn-conn:hover{background:#1570aa;}
.btn-forgot{background:none;border:none;color:#f0ad4e;font-size:12px;font-weight:bold;cursor:pointer;margin-top:5px;}
.err{color:#f85149;font-size:11px;text-align:center;margin-top:5px;min-height:15px;}
.copy{color:#888;font-size:11px;margin-top:9px;}

.menu-page{background:#d6e4ec;min-height:100vh;}
.menu-body{padding:14px;max-width:1200px;margin:0 auto;}
.section{border:2px solid #e0c060;border-radius:5px;margin-bottom:14px;background:#fff;}
.section-head{background:#2a7a7a;color:#fff;font-size:14px;font-weight:bold;padding:7px 14px;}
.icons{display:flex;flex-wrap:wrap;gap:4px;padding:12px 10px;}
.ico{display:flex;flex-direction:column;align-items:center;gap:5px;width:92px;padding:8px 4px;cursor:pointer;border-radius:5px;text-align:center;}
.ico:hover{background:rgba(30,144,212,.12);}
.ico-img{font-size:36px;}
.ico-lbl{font-size:11px;color:#333;font-weight:500;line-height:1.3;}

.dark-page{background:#2a2a2a;min-height:100vh;}
.dark-box{background:#2a2a2a;border:2px solid #f0ad4e;border-radius:5px;padding:14px;margin:10px;max-width:1200px;}
.dark-title{color:#f0ad4e;font-size:14px;font-weight:bold;border-bottom:1px solid #555;padding-bottom:7px;margin-bottom:10px;}
.dark-sub{color:#1e90d4;font-size:12px;font-weight:bold;margin-bottom:7px;}

.tbl{width:100%;border-collapse:collapse;font-size:12px;background:#fff;color:#000;}
.tbl thead tr{background:#1e90d4;color:#fff;}
.tbl th{padding:7px 9px;border:1px solid #1570aa;text-align:left;white-space:nowrap;}
.tbl tbody tr{border-bottom:1px solid #ddd;cursor:pointer;}
.tbl tbody tr:nth-child(even){background:#f9f9f9;}
.tbl tbody tr:hover{background:#e8f4fd;}
.tbl tbody tr.sel{background:#cce5f5;}
.tbl td{padding:6px 9px;border:1px solid #ddd;vertical-align:middle;}

.btn{padding:5px 13px;background:#eee;border:1px solid #aaa;border-radius:3px;font-size:12px;cursor:pointer;font-family:Arial;}
.btn:hover{background:#ddd;}
.btn-blue{background:#1e90d4;color:#fff;border-color:#1570aa;}
.btn-blue:hover{background:#1570aa;}
.btn-red{background:#d9534f;color:#fff;border-color:#c9302c;}
.btn-green{background:#5cb85c;color:#fff;border-color:#4cae4c;}

.fg{display:grid;grid-template-columns:170px 1fr;gap:8px 10px;align-items:center;}
.fg label{font-size:12px;color:#ddd;text-align:right;}
.fg input,.fg select{padding:6px 9px;border:1px solid #666;border-radius:3px;background:#f5f5f5;font-size:12px;}

.map-layout{display:flex;flex:1;height:calc(100vh - 38px - 42px - 140px);}
.map-area{flex:1;position:relative;background:#e8e8e8;}
.map-canvas{width:100%;height:100%;display:block;}
.map-sidebar{width:220px;flex-shrink:0;background:#f8f8f8;border-right:1px solid #ddd;display:flex;flex-direction:column;overflow:hidden;}
.map-sidebar-right{width:210px;flex-shrink:0;background:#f8f8f8;border-left:1px solid #ddd;overflow-y:auto;padding:8px;font-size:11px;}
.map-veh-list{flex:1;overflow-y:auto;}
.map-veh-item{padding:7px 10px;border-bottom:1px solid #eee;cursor:pointer;display:flex;align-items:center;gap:7px;}
.map-veh-item:hover,.map-veh-item.sel{background:#e0eef8;}
.status-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;}

.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px;}
.cal-nav button{background:none;border:none;color:#1e90d4;cursor:pointer;font-size:11px;padding:0 3px;}
.cal-lbl{font-size:11px;font-weight:bold;color:#1e90d4;}
.mini-cal table{width:100%;border-collapse:collapse;}
.mini-cal th{font-size:9px;color:#888;padding:1px;text-align:center;}
.mini-cal td{font-size:9px;text-align:center;padding:1px;cursor:pointer;border-radius:2px;}
.mini-cal td:hover{background:#ddd;}
.mini-cal td.today{background:#1e90d4;color:#fff;font-weight:bold;}
.mini-cal td.sel{background:#2a7a7a;color:#fff;}

#toast{position:fixed;bottom:20px;right:20px;background:#2a7a7a;color:#fff;padding:10px 16px;border-radius:5px;font-size:12px;z-index:9999;display:none;box-shadow:0 4px 14px rgba(0,0,0,.3);}

.stats-bar{display:flex;gap:12px;padding:6px 14px;background:#333;border-bottom:1px solid #444;flex-wrap:wrap;height:42px;align-items:center;}
.stat-item{display:flex;align-items:center;gap:5px;font-size:11px;color:#ddd;}
.stat-val{font-weight:bold;color:#fff;}
.stat-dot{width:10px;height:10px;border-radius:50%;}

/* ── MONITEUR VÉHICULE ─────────────────────────────────────── */
.veh-monitor{
  height:140px;
  background:linear-gradient(135deg,#1a3a5c 0%,#1e4d7a 100%);
  border-top:2px solid #4db8ff;
  color:#fff;
  font-size:12px;
  flex-shrink:0;
  box-shadow:0 -4px 18px rgba(0,0,0,.45);
  display:none;
  flex-direction:column;
}
.veh-monitor.visible{display:flex;}

.veh-monitor-header{
  background:rgba(0,0,0,.25);
  padding:4px 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  border-bottom:1px solid rgba(255,255,255,.12);
  flex-shrink:0;
}
.veh-monitor-title{font-size:13px;font-weight:bold;color:#fff;}
.veh-monitor-sub{font-size:10px;color:#a0c8f0;font-style:italic;}
.veh-monitor-close{background:rgba(255,255,255,.15);border:none;color:#fff;border-radius:50%;width:20px;height:20px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;}
.veh-monitor-close:hover{background:rgba(255,255,255,.3);}

.veh-monitor-body{display:grid;grid-template-columns:repeat(3,1fr);flex:1;overflow:hidden;}

.veh-monitor-col{padding:5px 14px;border-right:1px solid rgba(255,255,255,.1);overflow:hidden;}
.veh-monitor-col:last-child{border-right:none;}

.veh-monitor-row{display:flex;justify-content:space-between;align-items:center;padding:2px 0;border-bottom:1px solid rgba(255,255,255,.06);}
.veh-monitor-row:last-child{border-bottom:none;}
.veh-monitor-label{color:#a0c8f0;font-size:11px;}
.veh-monitor-value{font-weight:bold;color:#fff;font-size:12px;text-align:right;}
.veh-monitor-value.green{color:#5cb85c;}
.veh-monitor-value.red{color:#e74c3c;}
.veh-monitor-value.orange{color:#f39c12;}
.veh-monitor-value.blue{color:#4db8ff;}

.ign-badge{display:inline-block;padding:1px 8px;border-radius:10px;font-size:11px;font-weight:bold;}
.ign-on{background:#1d6b2a;color:#5cb85c;border:1px solid #5cb85c;}
.ign-off{background:#555;color:#aaa;border:1px solid #888;}
