:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.driver-dashboard{background:#f8fafc;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.top-nav{color:#fff;z-index:100;background:#0f172a;justify-content:space-between;align-items:center;padding:16px 20px;display:flex;position:sticky;top:0}.top-nav h2{margin:0;font-size:20px}.logout-btn{color:#f87171;cursor:pointer;background:0 0;border:none;font-weight:700}.content{max-width:600px;margin:0 auto;padding:20px}.bus-card{color:#fff;background:#2563eb;border-radius:24px;justify-content:space-between;align-items:center;margin-bottom:20px;padding:24px;display:flex}.bus-info .label{opacity:.8;text-transform:uppercase;margin:0;font-size:12px}.bus-info h1{margin:4px 0;font-size:28px}.status-badge{border-radius:12px;padding:6px 12px;font-size:12px;font-weight:700}.status-badge.on-trip{background:#10b981}.status-badge.off-duty{background:#64748b}.actions{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px;display:grid}.action-btn{color:#fff;cursor:pointer;transition:transform .2s active;border:none;border-radius:24px;padding:20px;font-size:16px;font-weight:700;box-shadow:0 4px 12px #0000001a}.action-btn:active{transform:scale(.98)}.start-btn{background:#10b981}.end-btn{background:#f43f5e}.sos-btn{color:#f43f5e;background:#000}.info-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff2;border:1px solid #f1f5f9;border-radius:24px;padding:24px;box-shadow:0 8px 32px #0000000d}.info-card h3{margin-top:0}.info-row{border-bottom:1px solid #f1f5f9;justify-content:space-between;margin-bottom:8px;padding-bottom:8px;display:flex}.info-row:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.info-row span:first-child{color:#64748b;font-size:14px}.info-row span:last-child{color:#1e293b;font-weight:600}.gps-active{color:#10b981!important}.gps-inactive{color:#f43f5e!important}.floating-sos-btn{color:#fff;cursor:pointer;z-index:1000;background-color:#ef4444;border:none;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;font-size:24px;font-weight:700;transition:transform .2s,background-color .2s;animation:2s infinite pulse-sos;display:flex;position:fixed;bottom:30px;right:30px;box-shadow:0 4px 20px #ef444466}.floating-sos-btn:hover{background-color:#dc2626;transform:scale(1.05)}.floating-sos-btn:active{transform:scale(.95)}@keyframes pulse-sos{0%{box-shadow:0 0 #ef4444b3}70%{box-shadow:0 0 0 20px #ef444400}to{box-shadow:0 0 #ef444400}}.modal-overlay{z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{text-align:center;background:#fff;border-radius:20px;width:400px;max-width:90%;padding:2rem;box-shadow:0 10px 25px #0003}.modal-content h2{color:#ef4444;margin-top:0}.modal-content p{color:#475569;margin-bottom:2rem;line-height:1.5}.modal-actions{gap:1rem;display:flex}.modal-actions button{cursor:pointer;border:none;border-radius:12px;flex:1;padding:12px;font-weight:700;transition:opacity .2s}.modal-actions .cancel-btn{color:#475569;background:#f1f5f9}.modal-actions .confirm-btn{color:#fff;background:#ef4444}.modal-actions button:hover{opacity:.9}.admin-dashboard{color:#1e293b;background-color:#f8fafc;min-height:100vh;font-family:Inter,-apple-system,sans-serif}.top-nav{color:#fff;background-color:#1e293b;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;box-shadow:0 2px 4px #0000001a}.admin-content{max-width:1200px;margin:0 auto;padding:2rem}.admin-content h1{margin-bottom:2rem;font-size:1.875rem;font-weight:700}.no-alerts{text-align:center;color:#64748b;background:#fff;border-radius:12px;padding:3rem;font-size:1.125rem;box-shadow:0 1px 3px #0000001a}.alerts-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem;display:grid}.alert-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;gap:1rem;padding:1.5rem;display:flex;box-shadow:0 4px 6px -1px #0000001a}.alert-header{justify-content:space-between;align-items:center;display:flex}.alert-type{color:#ef4444;font-size:1.25rem;font-weight:700}.alert-severity{color:#ef4444;background:#fee2e2;border-radius:4px;padding:.25rem .5rem;font-size:.75rem;font-weight:700}.alert-body p{color:#475569;margin:.5rem 0}.alert-body strong{color:#1e293b}.resolve-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:6px;margin-top:auto;padding:.75rem;font-weight:600;transition:background .2s}.resolve-btn:hover{background:#2563eb}.critical-flashing{border:3px solid #ef4444;animation:1.5s infinite flash-red}@keyframes flash-red{0%{background-color:#fff}50%{background-color:#fee2e2}to{background-color:#fff}}.logout-btn{color:#cbd5e1;cursor:pointer;background:0 0;border:1px solid #cbd5e1;border-radius:6px;padding:.5rem 1rem}.logout-btn:hover{color:#fff;background:#334155}
