@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-base:#0a0d14;--bg-surface:#111827;--bg-card:#1a2235;--bg-card-hover:#1f2a40;--border:#ffffff12;--border-active:#6366f180;--primary:#6366f1;--primary-light:#818cf8;--primary-glow:#6366f133;--secondary:#8b5cf6;--accent:#06b6d4;--success:#10b981;--warning:#f59e0b;--danger:#f43f5e;--info:#3b82f6;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--sidebar-w:240px;--header-h:64px;--radius:12px;--radius-lg:16px;--shadow:0 4px 24px #0006;--transition:all .2s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{background:var(--bg-base);height:100%;color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,sans-serif;font-size:14px}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}.app-layout{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--bg-surface);border-right:1px solid var(--border);z-index:100;flex-direction:column;flex-shrink:0;display:flex;overflow-y:auto}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:20px 16px;display:flex}.sidebar-logo-icon{background:linear-gradient(135deg, var(--primary), var(--secondary));width:36px;height:36px;box-shadow:0 0 20px var(--primary-glow);border-radius:10px;justify-content:center;align-items:center;font-size:18px;display:flex}.sidebar-logo-text{letter-spacing:-.3px;font-size:16px;font-weight:700}.sidebar-logo-sub{color:var(--text-muted);margin-top:1px;font-size:10px}.sidebar-section{padding:12px 8px 4px}.sidebar-section-label{color:var(--text-muted);letter-spacing:.8px;text-transform:uppercase;margin-bottom:4px;padding:0 8px;font-size:10px;font-weight:600}.nav-item{cursor:pointer;transition:var(--transition);color:var(--text-secondary);border-radius:8px;align-items:center;gap:10px;margin-bottom:2px;padding:9px 12px;font-size:13px;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{background:var(--bg-card);color:var(--text-primary)}.nav-item.active{background:var(--primary-glow);color:var(--primary-light);border:1px solid var(--border-active)}.nav-item svg{flex-shrink:0;width:16px;height:16px}.nav-badge{background:var(--danger);color:#fff;border-radius:99px;margin-left:auto;padding:2px 6px;font-size:10px;font-weight:700}.sidebar-footer{border-top:1px solid var(--border);align-items:center;gap:10px;margin-top:auto;padding:12px;display:flex}.avatar{background:linear-gradient(135deg, var(--primary), var(--secondary));border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:700;display:flex}.avatar.lg{width:40px;height:40px;font-size:15px}.avatar.xl{width:48px;height:48px;font-size:18px}.main-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{height:var(--header-h);background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:16px;padding:0 24px;display:flex}.topbar-title{flex:1;font-size:17px;font-weight:700}.topbar-sub{color:var(--text-muted);margin-top:2px;font-size:12px}.page{flex:1;padding:24px;overflow-y:auto}.page-header{margin-bottom:24px}.page-title{letter-spacing:-.5px;font-size:22px;font-weight:800}.page-desc{color:var(--text-secondary);margin-top:4px;font-size:13px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:var(--transition);padding:20px}.card:hover{border-color:#ffffff1f}.card-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:13px;font-weight:600}.kpi-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:var(--transition);padding:20px;position:relative;overflow:hidden}.kpi-card:before{content:"";background:var(--kpi-color,var(--primary));height:2px;position:absolute;top:0;left:0;right:0}.kpi-card:hover{box-shadow:var(--shadow);border-color:#ffffff1f;transform:translateY(-2px)}.kpi-label{color:var(--text-muted);margin-bottom:8px;font-size:12px;font-weight:500}.kpi-value{letter-spacing:-1px;font-size:28px;font-weight:800}.kpi-badge{border-radius:99px;align-items:center;gap:3px;margin-top:8px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.kpi-badge.up{color:var(--success);background:#10b98126}.kpi-badge.down{color:var(--danger);background:#f43f5e26}.kpi-icon{background:var(--primary-glow);border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;display:flex;position:absolute;top:20px;right:20px}.grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}.grid-60-40{grid-template-columns:60fr 40fr;gap:16px;display:grid}.grid-55-45{grid-template-columns:55fr 45fr;gap:16px;display:grid}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);padding:10px 12px;font-size:11px;font-weight:600}td{border-bottom:1px solid var(--border);padding:12px;font-size:13px}tr:last-child td{border-bottom:none}tr:hover td{background:#ffffff05}.pill{white-space:nowrap;border-radius:99px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.pill-success{color:var(--success);background:#10b98126}.pill-warning{color:var(--warning);background:#f59e0b26}.pill-danger{color:var(--danger);background:#f43f5e26}.pill-info{color:var(--primary-light);background:#6366f126}.pill-muted{color:var(--text-muted);background:#64748b26}.status-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.dot-active{background:var(--success);box-shadow:0 0 6px var(--success)}.dot-on_route{background:var(--accent);box-shadow:0 0 6px var(--accent)}.dot-finished{background:var(--text-muted)}.dot-delayed{background:var(--danger);box-shadow:0 0 6px var(--danger);animation:1.5s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.team-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.team-card{background:var(--bg-base);border:1px solid var(--border);transition:var(--transition);border-radius:10px;align-items:center;gap:12px;padding:14px;display:flex}.team-card:hover{background:var(--bg-card);border-color:#ffffff1f}.team-info{flex:1;min-width:0}.team-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.team-sub{color:var(--text-muted);margin-top:2px;font-size:11px}.timeline{padding-left:20px;position:relative}.timeline:before{content:"";background:var(--border);width:1px;position:absolute;top:0;bottom:0;left:7px}.tl-item{padding-bottom:16px;position:relative}.tl-dot{border:2px solid var(--bg-card);border-radius:50%;flex-shrink:0;width:10px;height:10px;position:absolute;top:4px;left:-17px}.tl-time{color:var(--text-muted);font-size:11px;font-weight:600}.tl-title{margin-top:2px;font-size:13px;font-weight:600}.tl-sub{color:var(--text-secondary);margin-top:2px;font-size:12px}.rank-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:10px 0;display:flex}.rank-item:last-child{border-bottom:none}.rank-pos{width:24px;color:var(--text-muted);text-align:center;font-size:13px;font-weight:800}.rank-bar-wrap{flex:1}.rank-name{margin-bottom:4px;font-size:13px;font-weight:600}.rank-bar{background:var(--border);border-radius:99px;height:4px;overflow:hidden}.rank-fill{background:linear-gradient(90deg, var(--primary), var(--secondary));border-radius:99px;height:100%;transition:width 1s}.rank-val{white-space:nowrap;font-size:13px;font-weight:700}.progress-wrap{margin-bottom:12px}.progress-header{justify-content:space-between;margin-bottom:6px;font-size:12px;display:flex}.progress-bar{background:var(--border);border-radius:99px;height:6px;overflow:hidden}.progress-fill{border-radius:99px;height:100%}.btn{cursor:pointer;transition:var(--transition);border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-light);box-shadow:0 0 20px var(--primary-glow)}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--bg-card);color:var(--text-primary)}.btn-danger{color:var(--danger);background:#f43f5e26;border:1px solid #f43f5e4d}.btn-danger:hover{background:#f43f5e40}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{padding:7px}.input-group{margin-bottom:16px}.input-label{color:var(--text-secondary);margin-bottom:6px;font-size:12px;font-weight:600;display:block}.input{background:var(--bg-base);border:1px solid var(--border);width:100%;color:var(--text-primary);transition:var(--transition);border-radius:8px;outline:none;padding:10px 12px;font-family:inherit;font-size:13px}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.input-with-icon{position:relative}.input-with-icon .input{padding-left:36px}.input-icon{color:var(--text-muted);width:16px;height:16px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}select.input{cursor:pointer}.map-container{border-radius:var(--radius);z-index:1;height:340px;position:relative;overflow:hidden}.map-container .leaflet-container{background:#0f172a;width:100%;height:100%}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:500px;max-width:90vw;padding:24px;animation:.25s slideUp}.modal-title{margin-bottom:20px;font-size:18px;font-weight:700}.modal-footer{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.search-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.chart-box{height:240px}.chart-box-lg{height:300px}.login-page{background:radial-gradient(ellipse at 30% 40%, #6366f126 0%, transparent 60%), radial-gradient(ellipse at 80% 80%, #8b5cf61a 0%, transparent 50%), var(--bg-base);min-height:100vh;display:flex}.login-left{flex-direction:column;flex:1;justify-content:center;padding:60px;display:flex}.login-right{background:var(--bg-surface);border-left:1px solid var(--border);justify-content:center;align-items:center;width:480px;padding:40px;display:flex}.login-logo{align-items:center;gap:12px;margin-bottom:40px;display:flex}.login-logo-icon{background:linear-gradient(135deg, var(--primary), var(--secondary));width:48px;height:48px;box-shadow:0 0 30px var(--primary-glow);border-radius:14px;justify-content:center;align-items:center;font-size:24px;display:flex}.login-headline{letter-spacing:-1.5px;font-size:42px;font-weight:800;line-height:1.15}.login-headline span{background:linear-gradient(135deg, var(--primary-light), var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.login-sub{color:var(--text-secondary);max-width:420px;margin-top:16px;font-size:16px}.login-features{flex-direction:column;gap:14px;margin-top:40px;display:flex}.login-feature{color:var(--text-secondary);align-items:center;gap:12px;font-size:14px;display:flex}.login-feature-icon{background:var(--primary-glow);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.login-form{width:100%}.login-form-title{margin-bottom:6px;font-size:24px;font-weight:800}.login-form-sub{color:var(--text-secondary);margin-bottom:28px;font-size:13px}.recharts-tooltip-wrapper .recharts-default-tooltip{background:var(--bg-surface)!important;border:1px solid var(--border)!important;border-radius:8px!important}@media (width<=1280px){.kpi-grid,.team-grid{grid-template-columns:repeat(2,1fr)}.grid-60-40,.grid-55-45{grid-template-columns:1fr}}@media (width<=768px){:root{--sidebar-w:0px}.sidebar{display:none}.kpi-grid{grid-template-columns:repeat(2,1fr)}.grid-2,.grid-3{grid-template-columns:1fr}.login-left{display:none}.login-right{width:100%}}.kanban-board{flex:1;gap:16px;padding-bottom:16px;display:flex;overflow-x:auto}.kanban-column{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border)}.kanban-card{cursor:grab;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;transition:transform .2s,box-shadow .2s}.kanban-card:active{cursor:grabbing}.kanban-card:hover{border-color:#ffffff26}.data-table th,.data-table td{padding:12px 16px}.data-table tr{border-bottom:1px solid var(--border)}
