:root{--primary:#0b3d91;--primary-dark:#082d6b;--accent:#e8a317;--accent-hover:#d4940f}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Open Sans,sans-serif;background:linear-gradient(135deg,#0b3d91,#1a5bc4 50%,#0b3d91);min-height:100vh;color:#333}h1,h2,h3{font-family:Montserrat,sans-serif}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;border-radius:16px;padding:40px;max-width:440px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.3)}.login-card h1{color:var(--primary);text-align:center;font-size:1.6rem}.login-card .subtitle{text-align:center;color:#888;margin:4px 0 24px;font-size:.9rem}.login-card label{display:block;font-weight:600;margin-bottom:6px;font-size:.85rem}.login-card input{width:100%;padding:12px 14px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;outline:none;transition:border-color .2s}.login-card input:focus{border-color:var(--primary)}.login-card button[type=submit]{width:100%;padding:14px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;margin-top:16px;transition:background .2s}.login-card button[type=submit]:hover{background:var(--accent-hover)}.login-error{color:#dc3545;font-size:.85rem;margin-top:8px}.pw-wrapper{position:relative}.pw-wrapper input{width:100%;padding-right:50px}.pw-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:36px;height:36px;background:var(--accent);border:none;border-radius:6px;cursor:pointer;color:#fff;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:1}.dashboard{min-height:100vh;background:#f5f6fa}.dash-header{background:var(--primary);color:#fff;padding:16px 24px;display:flex;align-items:center;justify-content:space-between}.dash-header h1{font-size:1.3rem}.dash-header .sub{opacity:.7;font-size:.85rem}.dash-header button{background:hsla(0,0%,100%,.15);border:1px solid hsla(0,0%,100%,.3);color:#fff;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.85rem}.dash-header button:hover{background:hsla(0,0%,100%,.25)}.dash-content{padding:24px;max-width:1200px;margin:0 auto}.vehicle-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));grid-gap:16px;gap:16px;margin-top:16px}.vehicle-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px rgba(0,0,0,.08);cursor:pointer;transition:transform .15s,box-shadow .15s;text-decoration:none;color:inherit;display:block}.vehicle-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.12)}.vehicle-card h3{color:var(--primary);font-size:1.1rem;margin-bottom:4px}.vehicle-card .plate{display:inline-block;background:#f0f0f0;padding:2px 10px;border-radius:4px;font-size:.8rem;font-weight:600;margin-bottom:8px}.vehicle-card .meta{display:flex;gap:16px;font-size:.85rem;color:#666}.vehicle-card .meta span{display:flex;align-items:center;gap:4px}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.status-dot.online{background:#28a745}.status-dot.offline{background:#dc3545}.status-dot.unknown{background:#ffc107}.detail-page{min-height:100vh;background:#f5f6fa}.detail-header{background:var(--primary);color:#fff;padding:12px 24px;display:flex;align-items:center;gap:16px}.detail-header a{color:#fff;text-decoration:none;font-size:1.2rem}.detail-header h1{font-size:1.2rem}.detail-header .plate-badge{background:hsla(0,0%,100%,.2);padding:2px 10px;border-radius:4px;font-size:.85rem}.detail-body{display:flex;height:calc(100vh - 52px)}.detail-map{flex:1 1;min-height:400px}.detail-sidebar{width:360px;background:#fff;overflow-y:auto;padding:20px;box-shadow:-2px 0 8px rgba(0,0,0,.05)}.info-section{margin-bottom:20px}.info-section h3{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--primary);margin-bottom:10px}.info-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.info-item .label{display:block;font-size:.7rem;text-transform:uppercase;color:#888;letter-spacing:.03em}.info-item .value{display:block;font-size:1rem;font-weight:600;color:#222}.time-filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}.time-filter{padding:5px 12px;border:1px solid #ddd;border-radius:20px;background:#fff;cursor:pointer;font-size:.8rem;transition:all .15s}.time-filter.active{background:var(--primary);color:#fff;border-color:var(--primary)}.stops-list{margin-top:12px}.stops-list h4{font-size:.75rem;text-transform:uppercase;color:var(--primary);margin-bottom:6px}.stop-entry{display:flex;align-items:center;gap:8px;font-size:.83rem;padding:4px 0;color:#444}.stop-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);flex-shrink:0}.route-notice{font-style:italic;font-size:.8rem;color:#aaa;margin-top:12px}.info-footer{font-size:.75rem;color:#bbb;margin-top:8px}.loading-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#fff;gap:16px}.spinner{width:40px;height:40px;border:3px solid hsla(0,0%,100%,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.add-btn{background:var(--accent)!important;border-color:var(--accent)!important;font-weight:700}.add-btn:hover{background:var(--accent-hover)!important}.vehicle-card-link{text-decoration:none;color:inherit;display:block}.delete-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:#f0f0f0;border:none;cursor:pointer;font-size:1.1rem;color:#999;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .15s;opacity:0}.vehicle-card:hover .delete-btn{opacity:1}.delete-btn:hover{background:#dc3545;color:#fff}.delete-confirm{position:absolute;top:8px;right:8px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;background:#fff;padding:6px 10px;border-radius:6px;box-shadow:0 2px 12px rgba(0,0,0,.2);font-size:.8rem}.admin-pw-input{width:120px;padding:4px 8px;border:1px solid #ddd;border-radius:4px;font-size:.8rem;outline:none}.admin-pw-input:focus{border-color:var(--primary)}.delete-error{color:#dc3545;font-size:.75rem;width:100%}.confirm-yes{background:#dc3545;color:#fff}.confirm-no,.confirm-yes{border:none;padding:3px 10px;border-radius:4px;cursor:pointer;font-size:.8rem}.confirm-no{background:#e0e0e0}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-card{background:#fff;border-radius:16px;padding:32px;max-width:480px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.3);max-height:90vh;overflow-y:auto}.modal-card h2{color:var(--primary);font-size:1.3rem;margin-bottom:20px}.form-row{margin-bottom:14px}.form-row label{display:block;font-weight:600;margin-bottom:4px;font-size:.85rem;color:#444}.form-row input,.form-row select{width:100%;padding:10px 12px;border:2px solid #e0e0e0;border-radius:8px;font-size:.95rem;outline:none;transition:border-color .2s}.form-row input:focus,.form-row select:focus{border-color:var(--primary)}.provider-fields{border-top:1px solid #eee;padding-top:14px;margin-top:14px}.modal-error{color:#dc3545;font-size:.85rem;margin:8px 0}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.btn-cancel{padding:10px 20px;background:#e0e0e0;border:none;border-radius:8px;cursor:pointer;font-size:.9rem}.btn-cancel:hover{background:#d0d0d0}.btn-save{padding:10px 24px;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:700}.btn-save:hover{background:var(--accent-hover)}.btn-save:disabled{opacity:.6;cursor:not-allowed}@media (max-width:768px){.detail-body{flex-direction:column;height:auto}.detail-map{height:50vh}.detail-sidebar{width:100%}.vehicle-grid{grid-template-columns:1fr}.modal-card{padding:24px}}