@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-main:#020617;--bg-card:#0f172a99;--bg-card-solid:#0f172a;--bg-input:#0b0f19;--border-color:#ffffff14;--border-focus:#6366f1;--text-primary:#f9fafb;--text-secondary:#94a3b8;--text-muted:#64748b;--color-indigo:#6366f1;--color-indigo-hover:#4f46e5;--color-indigo-glow:#6366f126;--color-emerald:#10b981;--color-emerald-hover:#059669;--color-emerald-glow:#10b98126;--color-rose:#f43f5e;--color-rose-hover:#e11d48;--color-rose-glow:#f43f5e26;--color-amber:#f59e0b;--color-amber-hover:#d97706;--color-amber-glow:#f59e0b26;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000004d, 0 4px 6px -2px #0000000d;--shadow-glow:0 0 20px #6366f126}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-main);color:var(--text-primary);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.5;overflow-x:hidden}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-main)}::-webkit-scrollbar-thumb{background:#1e293b;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#334155}#root{text-align:left;border-inline:none;flex-direction:column;width:100%;max-width:100%;min-height:100vh;margin:0;padding:0;display:flex}h1,h2,h3,h4,h5,h6{font-family:var(--font-sans);color:var(--text-primary);letter-spacing:-.025em;font-weight:700}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulseGlow{0%,to{box-shadow:0 0 15px #6366f126}50%{box-shadow:0 0 25px #6366f14d}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade{animation:.3s ease-out forwards fadeIn}.animate-slide{animation:.4s cubic-bezier(.16,1,.3,1) forwards slideUp}.animate-scale{animation:.3s cubic-bezier(.16,1,.3,1) forwards scaleIn}.auth-container{background:radial-gradient(circle at 100% 0,#6366f11a,#0000 45%),radial-gradient(circle at 0 100%,#10b9810d,#0000 45%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:var(--bg-card);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:440px;box-shadow:var(--shadow-lg);padding:40px 32px;animation:.4s cubic-bezier(.16,1,.3,1) scaleIn}.auth-header{text-align:center;margin-bottom:32px}.auth-logo{border-radius:var(--radius-md);background:var(--color-indigo-glow);width:56px;height:56px;color:var(--color-indigo);border:1px solid #6366f14d;justify-content:center;align-items:center;margin-bottom:16px;display:inline-flex}.auth-title{margin-bottom:6px;font-size:24px}.auth-subtitle{color:var(--text-secondary);font-size:14px}.dashboard-layout{background-color:var(--bg-main);flex-direction:column;min-height:100vh;display:flex}.dashboard-header{-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);z-index:50;background:#0f172a66;justify-content:space-between;align-items:center;padding:16px 32px;display:flex;position:sticky;top:0}.header-brand{align-items:center;gap:12px;display:flex}.header-logo{border-radius:var(--radius-sm);background:var(--color-indigo-glow);width:36px;height:36px;color:var(--color-indigo);border:1px solid #6366f133;justify-content:center;align-items:center;display:flex}.header-title{letter-spacing:-.01em;background:linear-gradient(135deg,#fff 40%,#818cf8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:18px;font-weight:700}.header-meta{color:var(--color-emerald);background:#ffffff0a;border:1px solid #10b98133;border-radius:9999px;align-items:center;gap:8px;padding:4px 10px;font-size:12px;display:flex}.header-meta-dot{background-color:var(--color-emerald);width:6px;height:6px;box-shadow:0 0 8px var(--color-emerald);border-radius:50%}.header-nav{align-items:center;gap:8px;display:flex}.nav-tab{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;background:0 0;border:1px solid #0000;align-items:center;gap:8px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.nav-tab:hover{color:var(--text-primary);background:#ffffff0a}.nav-tab.active{color:var(--color-indigo);background:var(--color-indigo-glow);border-color:#6366f133}.header-user{align-items:center;gap:16px;display:flex}.user-info{text-align:right}.user-email{color:var(--text-primary);font-size:13px;font-weight:500}.user-role{color:var(--text-muted);font-size:11px}.logout-btn{border-radius:var(--radius-sm);border:1px solid var(--border-color);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;background:0 0;justify-content:center;align-items:center;transition:all .2s;display:flex}.logout-btn:hover{color:var(--color-rose);background:var(--color-rose-glow);border-color:#f43f5e33}.dashboard-main{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:40px 32px}.card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:24px;transition:all .3s cubic-bezier(.16,1,.3,1)}.card:hover{box-shadow:var(--shadow-lg);border-color:#ffffff1f;transform:translateY(-2px)}.form-group{margin-bottom:20px}.form-label{color:var(--text-secondary);margin-bottom:8px;font-size:13px;font-weight:500;display:block}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-muted);pointer-events:none;position:absolute;left:12px}.form-input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font-sans);outline:none;padding:10px 14px;font-size:14px;transition:all .2s}.form-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--color-indigo-glow)}.input-with-icon{padding-left:38px}.form-textarea{resize:vertical;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;min-height:100px;color:var(--text-primary);font-family:var(--font-sans);outline:none;padding:10px 14px;font-size:14px;transition:all .2s}.form-textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--color-indigo-glow)}.form-select{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font-sans);appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%2394a3b8' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:20px;outline:none;padding:10px 40px 10px 14px;font-size:14px;transition:all .2s}.form-select:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--color-indigo-glow)}.file-upload-box{border:2px dashed var(--border-color);border-radius:var(--radius-sm);cursor:pointer;text-align:center;background:#ffffff03;flex-direction:column;justify-content:center;align-items:center;padding:24px;transition:all .2s;display:flex}.file-upload-box:hover{border-color:var(--border-focus);background:#6366f105}.file-upload-icon{color:var(--text-muted);margin-bottom:12px}.file-upload-text{color:var(--text-secondary);margin-bottom:4px;font-size:13px}.file-upload-hint{color:var(--text-muted);font-size:11px}.btn{border-radius:var(--radius-sm);cursor:pointer;border:1px solid #0000;outline:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .2s cubic-bezier(.16,1,.3,1);display:inline-flex}.btn-primary{background:var(--color-indigo);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-indigo-hover);box-shadow:0 0 16px #6366f166}.btn-success{background:var(--color-emerald);color:#fff}.btn-success:hover:not(:disabled){background:var(--color-emerald-hover);box-shadow:0 0 16px #10b98166}.btn-danger{background:var(--color-rose);color:#fff}.btn-danger:hover:not(:disabled){background:var(--color-rose-hover);box-shadow:0 0 16px #f43f5e66}.btn-secondary{border-color:var(--border-color);color:var(--text-primary);background:0 0}.btn-secondary:hover:not(:disabled){background:#ffffff0a;border-color:#ffffff26}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:6px 12px;font-size:12px}.btn-full{width:100%}.spinner{animation:1s linear infinite spin;display:inline-block}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:40px;display:grid}.stat-card{align-items:center;gap:20px;display:flex}.stat-icon{border-radius:var(--radius-md);border:1px solid var(--border-color);background:#ffffff08;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stat-icon.indigo{color:var(--color-indigo);background:var(--color-indigo-glow);border-color:#6366f133}.stat-icon.emerald{color:var(--color-emerald);background:var(--color-emerald-glow);border-color:#10b98133}.stat-icon.rose{color:var(--color-rose);background:var(--color-rose-glow);border-color:#f43f5e33}.stat-info{flex-direction:column;display:flex}.stat-value{font-size:28px;font-weight:800;line-height:1.1}.stat-label{color:var(--text-secondary);font-size:13px}.overview-content{grid-template-columns:2fr 1fr;gap:32px;display:grid}@media (width<=1024px){.overview-content{grid-template-columns:1fr}}.recent-activity-list{flex-direction:column;gap:16px;margin-top:16px;display:flex}.activity-item{border-radius:var(--radius-sm);background:#ffffff03;border:1px solid #ffffff05;align-items:flex-start;gap:14px;padding:12px;display:flex}.activity-icon-bullet{background-color:var(--color-indigo);border-radius:50%;width:8px;height:8px;margin-top:6px}.activity-detail{flex:1}.activity-text{color:var(--text-primary);font-size:13px}.activity-time{color:var(--text-muted);font-size:11px}.fares-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px;display:grid}.fare-card{border-left:4px solid var(--color-indigo);flex-direction:column;justify-content:space-between;display:flex}.fare-card.bolt{border-left-color:var(--color-emerald)}.fare-card.danfo{border-left-color:var(--color-amber)}.fare-card.brt{border-left-color:#3b82f6}.fare-card.keke{border-left-color:#a855f7}.fare-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.vehicle-type{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:12px;font-weight:700}.vehicle-name{margin-top:2px;font-size:20px}.fare-badge{color:var(--color-indigo);background:#6366f11f;border:1px solid #6366f133;border-radius:9999px;padding:4px 8px;font-size:11px;font-weight:600}.fare-badge.bolt{color:var(--color-emerald);background:#10b9811f;border-color:#10b98133}.fare-badge.danfo{color:var(--color-amber);background:#f59e0b1f;border-color:#f59e0b33}.fare-badge.brt{color:#3b82f6;background:#3b82f61f;border-color:#3b82f633}.fare-badge.keke{color:#a855f7;background:#a855f71f;border-color:#a855f733}.fare-metrics{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;display:grid}.fare-metric-item{border-radius:var(--radius-sm);background:#ffffff05;border:1px solid #ffffff0a;padding:10px}.metric-lbl{color:var(--text-secondary);font-size:11px}.metric-val{margin-top:2px;font-size:16px;font-weight:700}.fare-card-footer{border-top:1px solid var(--border-color);justify-content:flex-end;padding-top:16px;display:flex}.traffic-header-actions{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:32px;display:flex}.search-filters-bar{flex:1;gap:12px;max-width:600px;display:flex}.traffic-grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:24px;display:grid}@media (width<=640px){.traffic-grid{grid-template-columns:1fr}}.traffic-card{flex-direction:column;height:100%;display:flex}.traffic-card-image{object-fit:cover;border-radius:var(--radius-sm);background:#0003;width:100%;height:160px;margin-bottom:16px}.traffic-card-meta{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.severity-badge{text-transform:uppercase;border-radius:9999px;padding:4px 10px;font-size:11px;font-weight:700}.severity-badge.light{color:var(--color-emerald);background:#10b9811f;border:1px solid #10b98133}.severity-badge.moderate{color:var(--color-amber);background:#f59e0b1f;border:1px solid #f59e0b33}.severity-badge.heavy{color:var(--color-rose);background:#ef44441f;border:1px solid #ef444433}.severity-badge.severe{color:#f87171;background:#ef444440;border:1px solid #ef444466;box-shadow:0 0 10px #ef444433}.traffic-time{color:var(--text-muted);font-size:12px}.traffic-card-title{margin-bottom:8px;font-size:18px;line-height:1.3}.traffic-card-body{color:var(--text-secondary);flex:1;margin-bottom:16px;font-size:13px}.traffic-meta-row{border-top:1px solid var(--border-color);flex-direction:column;gap:6px;margin-top:auto;padding-top:14px;font-size:12px;display:flex}.traffic-meta-item{color:var(--text-secondary);align-items:center;gap:8px;display:flex}.traffic-meta-item svg{color:var(--text-muted);width:14px;height:14px}.traffic-actions{border-top:1px solid var(--border-color);justify-content:flex-end;margin-top:14px;padding-top:12px;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:100;background:#020617cc;justify-content:center;align-items:center;padding:24px;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-card-solid);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:560px;box-shadow:var(--shadow-lg);animation:.3s cubic-bezier(.16,1,.3,1) scaleIn;overflow:hidden}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-title{font-size:18px}.modal-close{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.modal-close:hover{color:var(--text-primary);background:#ffffff0d}.modal-body{max-height:70vh;padding:24px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border-color);background:#0f172a33;justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.snackbar-container{z-index:200;flex-direction:column;gap:8px;width:100%;max-width:380px;display:flex;position:fixed;bottom:24px;right:24px}.snackbar{border-radius:var(--radius-md);background:var(--bg-card-solid);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);color:var(--text-primary);align-items:center;gap:12px;padding:14px 20px;font-size:13px;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;display:flex}.snackbar.success{border-left:4px solid var(--color-emerald)}.snackbar.error{border-left:4px solid var(--color-rose)}.snackbar.info{border-left:4px solid var(--color-indigo)}.snackbar.warning{border-left:4px solid var(--color-amber)}.snackbar-icon{flex-shrink:0}.snackbar-icon.success{color:var(--color-emerald)}.snackbar-icon.error{color:var(--color-rose)}.snackbar-icon.info{color:var(--color-indigo)}.snackbar-icon.warning{color:var(--color-amber)}.snackbar-content{flex:1}.snackbar-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:all .2s;display:flex}.snackbar-close:hover{color:var(--text-primary)}.database-badge{border-radius:4px;align-items:center;gap:6px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.database-badge.success{background-color:var(--color-emerald-glow);color:var(--color-emerald);border:1px solid #10b98133}.database-badge.warning{background-color:var(--color-amber-glow);color:var(--color-amber);border:1px solid #f59e0b33}.empty-state{text-align:center;border:1px dashed var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;padding:48px;display:flex}.empty-state-icon{color:var(--text-muted);margin-bottom:16px}.empty-state-title{color:var(--text-primary);margin-bottom:4px;font-size:16px;font-weight:600}.empty-state-subtitle{font-size:13px}.image-preview-thumb{border-radius:var(--radius-sm);object-fit:cover;background:#0003;width:48px;height:48px}
