*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f4f4f0;--bg2:#fff;--bg3:#f4f4f0;
  --text:#1a1a1a;--text2:#666;--text3:#888;--text4:#aaa;
  --border:#e5e5e0;--border2:#f0f0ec;--border3:#d0d0ca;
  --accent:#185FA5;--accent-bg:#EBF4FF;
  --input-bg:#fff;--card-bg:#fff;--sidebar-bg:#fff;
  --metric-bg:#fff;--tool-bg:#f4f4f0;--bar-bg:#f4f4f0;
  --modal-bg:#fff;--row-hover:#f9f9f7;
}
body.dark{
  --bg:#111318;--bg2:#1a1d24;--bg3:#111318;
  --text:#e8e8e8;--text2:#aaa;--text3:#777;--text4:#555;
  --border:#2a2d36;--border2:#222530;--border3:#333744;
  --accent:#4d9de0;--accent-bg:#1a2a3a;
  --input-bg:#1e2130;--card-bg:#1a1d24;--sidebar-bg:#13151c;
  --metric-bg:#1a1d24;--tool-bg:#111318;--bar-bg:#1e2130;
  --modal-bg:#1a1d24;--row-hover:#1e2130;
}
body{font-family:system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;transition:background 0.2s,color 0.2s}
.app{display:flex;height:100vh;overflow:hidden}
.sidebar{width:210px;background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:16px 0;flex-shrink:0;transition:background 0.2s}
.logo{padding:0 18px 14px;border-bottom:1px solid var(--border);margin-bottom:10px}
.logo-title{font-size:15px;font-weight:600;color:var(--text)}
.logo-sub{font-size:11px;color:var(--text3);margin-top:2px}
.dark-toggle{margin:0 12px 4px;padding:8px 10px;cursor:pointer;font-size:12px;color:var(--text2);display:flex;align-items:center;gap:8px;border-radius:8px;border:none;background:none;width:calc(100% - 24px);font-family:inherit}
.dark-toggle:hover{background:var(--bar-bg)}
.nav-item{padding:10px 18px;cursor:pointer;font-size:13px;color:var(--text2);display:flex;align-items:center;gap:9px;border-left:2px solid transparent}
.nav-item:hover{background:var(--bar-bg);color:var(--text)}
.nav-item.active{color:var(--accent);background:var(--accent-bg);border-left:2px solid var(--accent);font-weight:500}
.nav-icon{width:15px;height:15px;flex-shrink:0}
.main{flex:1;overflow-y:auto;padding:24px}
.page{display:none}
.page.active{display:block}
.page-title{font-size:18px;font-weight:600;color:var(--text);margin-bottom:18px}
.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}
.metric{background:var(--metric-bg);border:1px solid var(--border);border-radius:10px;padding:14px 16px}
.metric-label{font-size:11px;color:var(--text3);margin-bottom:5px;text-transform:uppercase;letter-spacing:0.05em}
.metric-value{font-size:24px;font-weight:600;color:var(--text)}
.metric-sub{font-size:11px;color:var(--text4);margin-top:3px}
.card{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:16px 18px;margin-bottom:16px}
.card-title{font-size:11px;font-weight:600;color:var(--text3);margin-bottom:14px;text-transform:uppercase;letter-spacing:0.06em}
.row{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border2)}
.row:last-child{border-bottom:none}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--accent-bg);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--accent);flex-shrink:0;margin-top:2px}
.info{flex:1;min-width:0}
.info-name{font-size:13px;font-weight:500;color:var(--text)}
.info-sub{font-size:11px;color:var(--text3);margin-top:2px}
.badge{font-size:10px;padding:3px 9px;border-radius:20px;font-weight:500;white-space:nowrap}
.badge-ok{background:#1a3d2a;color:#6fcf97}
.badge-wait{background:#3d2e0a;color:#f2994a}
.badge-new{background:var(--accent-bg);color:var(--accent)}
.badge-done{background:#2d1a3d;color:#bb86fc}
body:not(.dark) .badge-ok{background:#EAF5E9;color:#2E7D32}
body:not(.dark) .badge-wait{background:#FFF8E1;color:#F57F17}
body:not(.dark) .badge-done{background:#F3E5F5;color:#6A1B9A}
.btn{background:var(--card-bg);border:1px solid var(--border3);border-radius:8px;padding:7px 14px;font-size:12px;cursor:pointer;color:var(--text);font-family:inherit}
.btn:hover{background:var(--bar-bg)}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:#0d4a8a}
.btn-danger{background:var(--card-bg);border-color:#e57373;color:#e57373}
.btn-danger:hover{background:#2d1515}
body:not(.dark) .btn-danger{color:#c62828}
body:not(.dark) .btn-danger:hover{background:#ffebee}
.btn-edit{background:var(--card-bg);border-color:var(--border3);color:var(--text2)}
.btn-edit:hover{background:var(--bar-bg)}
.row-actions{display:flex;gap:5px;flex-shrink:0;margin-top:2px}
.top-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}
.form-input{border:1px solid var(--border3);border-radius:8px;padding:7px 10px;font-size:13px;background:var(--input-bg);color:var(--text);font-family:inherit;width:100%}
.form-input:focus{outline:none;border-color:var(--accent)}
select.form-input{cursor:pointer}
.note-textarea{width:100%;border:1px solid var(--border3);border-radius:8px;padding:8px;font-size:13px;font-family:inherit;resize:vertical;min-height:70px;color:var(--text);background:var(--input-bg)}
.note-textarea:focus{outline:none;border-color:var(--accent)}
.bar-container{display:flex;flex-direction:column;gap:10px}
.bar-row{display:flex;align-items:center;gap:10px}
.bar-label{font-size:12px;color:var(--text3);width:30px;text-align:right;flex-shrink:0}
.bar-bg{flex:1;background:var(--bar-bg);height:20px;border-radius:4px;overflow:hidden}
.bar-fill{height:100%;border-radius:4px;background:var(--accent);display:flex;align-items:center;padding-right:8px;justify-content:flex-end}
.bar-val{font-size:10px;color:#fff;font-weight:500;white-space:nowrap}
.tools-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.tool-card{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:16px}
.tool-card-title{font-size:13px;font-weight:600;margin-bottom:12px;color:var(--text)}
.tool-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.tool-label{font-size:12px;color:var(--text2)}
.tool-input{width:100px;text-align:right;border:1px solid var(--border3);border-radius:8px;padding:5px 8px;font-size:13px;font-family:inherit;color:var(--text);background:var(--input-bg)}
.tool-result{background:var(--tool-bg);border-radius:8px;padding:10px;text-align:center;margin-top:8px}
.tool-result-val{font-size:20px;font-weight:600;color:var(--accent)}
.tool-result-label{font-size:10px;color:var(--text3);margin-top:2px}
.progress-bar{background:var(--bar-bg);border-radius:4px;height:14px;overflow:hidden;margin:6px 0}
.progress-fill{height:100%;background:var(--accent);border-radius:4px;transition:width 0.3s}
.empty{text-align:center;color:var(--text4);font-size:13px;padding:20px 0}
#map{height:440px;border-radius:10px;border:1px solid var(--border);margin-bottom:16px}
.geo-status{font-size:11px;margin-top:4px;min-height:16px;color:var(--text3)}
.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--card-bg);border:1px solid var(--border);border-radius:8px;z-index:9999;box-shadow:0 4px 12px rgba(0,0,0,0.15);max-height:200px;overflow-y:auto}
.autocomplete-item{padding:10px 12px;cursor:pointer;font-size:13px;color:var(--text);border-bottom:1px solid var(--border2)}
.autocomplete-item:last-child{border-bottom:none}
.autocomplete-item:hover{background:var(--bar-bg)}
.autocomplete-item small{display:block;font-size:11px;color:var(--text3);margin-top:2px}
.addr-wrap{position:relative}
.geo-ok{color:#6fcf97}
.geo-err{color:#e57373}
body:not(.dark) .geo-ok{color:#2E7D32}
body:not(.dark) .geo-err{color:#c62828}
.map-legend{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:12px}
.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text2)}
.legend-dot{width:12px;height:12px;border-radius:50%}
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:1000;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal{background:var(--modal-bg);border-radius:14px;padding:24px;width:520px;max-width:95vw;max-height:90vh;overflow-y:auto;position:relative;border:1px solid var(--border);overflow:visible}
.modal-title{font-size:16px;font-weight:600;margin-bottom:16px;color:var(--text)}
.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:18px;cursor:pointer;color:var(--text3)}
.modal-close:hover{color:var(--text)}
.loading{text-align:center;color:var(--text4);font-size:13px;padding:30px 0}
.spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 0.7s linear infinite;margin-right:6px;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}

/* MOBILE */
@media (max-width: 768px){
  .app{flex-direction:column}
  .sidebar{width:100%;height:auto;border-right:none;border-bottom:1px solid var(--border);padding:8px 0;flex-direction:row;flex-wrap:wrap;overflow-x:auto;display:none;position:fixed;top:0;left:0;right:0;z-index:500;max-height:100vh;overflow-y:auto;flex-direction:column}
  .sidebar.mobile-open{display:flex}
  .logo{padding:12px 16px 12px;border-bottom:none;margin-bottom:0;display:flex;align-items:center;gap:10px}
  .main{padding:60px 12px 12px;height:100vh;overflow-y:auto}
  .metrics{grid-template-columns:1fr 1fr}
  .form-grid{grid-template-columns:1fr}
  .tools-grid{grid-template-columns:1fr}
  .tool-card[style*="grid-column"]{grid-column:1!important}
  .row{flex-wrap:wrap;gap:6px}
  .row-actions{width:100%;justify-content:flex-end}
  .top-bar{flex-wrap:wrap;gap:8px}
  .modal{padding:16px;width:100%!important;max-width:100vw!important;margin:8px;border-radius:10px}
  .modal-overlay.open{align-items:flex-end}
  #map{height:300px}
  .mobile-header{display:flex!important}
  .page-title{font-size:15px}
}

.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:52px;background:var(--sidebar-bg);border-bottom:1px solid var(--border);z-index:400;align-items:center;padding:0 16px;gap:12px}
.hamburger{background:none;border:none;cursor:pointer;color:var(--text);padding:4px;display:flex;flex-direction:column;gap:4px}
.hamburger span{display:block;width:20px;height:2px;background:var(--text);border-radius:2px}
.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:490}
.mobile-overlay.open{display:block}

/* ---- RESPONSIVE MOBILE ---- */
.nav-label{display:inline}
.desktop-only{display:block}
@media (max-width:768px){.desktop-only{display:none!important}}
@media (max-width:768px){
  .nav-label{display:none}
}
@media (max-width: 768px){
  .app{flex-direction:column}
  .sidebar{
    width:100%;height:auto;
    border-right:none;border-bottom:1px solid var(--border);
    padding:0;flex-direction:row;flex-shrink:0;
    position:fixed;bottom:0;left:0;right:0;z-index:100;
    background:var(--sidebar-bg);
    overflow-x:auto;overflow-y:hidden;
    display:flex;align-items:center;
    height:56px;
  }
  .logo{display:none}
  .dark-toggle{display:none}
  #admin-nav{display:none!important}
  .sidebar>div[style*="margin-top:auto"]{display:none}
  .sidebar>div[style*="padding:0 12px"]{display:none}
  .nav-item{
    padding:8px 12px;border-left:none!important;
    border-bottom:2px solid transparent;
    flex-direction:column;gap:2px;font-size:9px;
    min-width:56px;align-items:center;justify-content:center;
    white-space:nowrap;flex-shrink:0;height:56px;
  }
  .nav-item.active{
    border-bottom:2px solid var(--accent)!important;
    border-left:none!important;
    background:var(--accent-bg);
  }
  .nav-icon{width:18px;height:18px}
  .sidebar a.nav-item-link{display:none}
  .main{
    padding:12px;
    height:calc(100vh - 56px);
    overflow-y:auto;
    padding-bottom:70px;
  }
  .metrics{grid-template-columns:1fr 1fr!important}
  .form-grid{grid-template-columns:1fr!important}
  .tools-grid{grid-template-columns:1fr!important}
  .top-bar{flex-wrap:wrap;gap:8px}
  .row-actions{flex-wrap:wrap}
  .page-title{font-size:16px}
  #map{height:280px}
  .modal{width:95vw!important;max-height:85vh}
  .metrics .metric:nth-child(3){grid-column:1/-1}
}

@media (max-width: 768px){
  .sidebar a[href]{display:none}
}
/* ITINERAIRE */
.itineraire-bar{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:12px 16px;margin-bottom:12px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.client-marker-selected{border:3px solid #ff6b00!important;box-shadow:0 0 0 3px rgba(255,107,0,0.3)!important}
.etape-badge{background:#ff6b00;color:#fff;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.badge-pending{background:#2d2d35;color:#999}
body:not(.dark) .badge-pending{background:#f0f0ec;color:#777}
