*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5;color:#1a1a1a}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{display:flex;align-items:center;gap:12px;padding:10px 20px;background:#1e293b;color:#fff;z-index:1000}.app-header h1{font-size:18px;font-weight:700}.live-badge{background:#ef4444;color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:4px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.vehicle-count{margin-left:auto;font-size:13px;color:#94a3b8}.app-body{position:relative;flex:1;display:flex;overflow:hidden}.bus-map{flex:1;height:100%;z-index:1}.bus-marker,.stop-marker,.stop-marker-selected{background:transparent!important;border:none!important}.search-bar{position:absolute;top:12px;left:12px;z-index:1000;width:340px;max-width:calc(100vw - 24px)}.search-input-row{display:flex;gap:6px}.search-bar input[type=text]{flex:1;padding:10px 14px;font-size:14px;border:none;border-radius:8px;background:#fff;box-shadow:0 2px 8px #00000026;outline:none}.search-bar input[type=text]:focus{box-shadow:0 2px 8px #00000026,0 0 0 2px #2563eb}.locate-btn{padding:10px 14px;font-size:13px;font-weight:600;border:none;border-radius:8px;background:#2563eb;color:#fff;cursor:pointer;box-shadow:0 2px 8px #00000026;white-space:nowrap}.locate-btn:hover{background:#1d4ed8}.search-results{list-style:none;margin-top:4px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;overflow:hidden}.search-results li{display:flex;align-items:baseline;gap:8px;padding:10px 14px;cursor:pointer;font-size:13px;border-bottom:1px solid #f1f1f1}.search-results li:last-child{border-bottom:none}.search-results li:hover{background:#f0f7ff}.result-name{font-weight:600;flex:1}.result-locality{color:#6b7280;font-size:12px}.result-distance{color:#2563eb;font-size:12px;font-weight:500}.side-panel{position:absolute;top:0;right:0;width:380px;max-width:100vw;height:100%;background:#fff;box-shadow:-4px 0 16px #0000001a;z-index:1001;overflow-y:auto;padding:20px;animation:slideIn .2s ease-out}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.panel-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.panel-header h2{font-size:18px;font-weight:700}.panel-subtitle{font-size:13px;color:#6b7280;font-weight:400;margin-top:2px}.close-btn{padding:6px 12px;font-size:12px;font-weight:600;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;cursor:pointer;flex-shrink:0}.close-btn:hover{background:#f3f4f6}.side-panel h3{font-size:14px;font-weight:700;color:#374151;margin:16px 0 8px;text-transform:uppercase;letter-spacing:.5px}.panel-loading,.panel-empty{font-size:13px;color:#9ca3af;padding:12px 0}.departure-list{list-style:none}.departure-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid #f3f4f6;font-size:14px}.dep-line{background:#2563eb;color:#fff;font-weight:700;font-size:13px;padding:2px 8px;border-radius:4px;min-width:40px;text-align:center}.dep-dest{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dep-time{font-weight:600;font-variant-numeric:tabular-nums}.dep-status{font-size:11px;font-weight:600;padding:1px 6px;border-radius:3px}.dep-status.realtime{background:#dcfce7;color:#166534}.dep-status.scheduled{background:#f3f4f6;color:#6b7280}.vehicle-status{margin-bottom:12px}.status-late{color:#ef4444;font-weight:600;font-size:15px}.status-early{color:#2563eb;font-weight:600;font-size:15px}.status-ontime{color:#16a34a;font-weight:600;font-size:15px}.status-unknown{color:#9ca3af;font-size:14px}.detail-table{width:100%;font-size:13px;border-collapse:collapse}.detail-table td{padding:6px 0;border-bottom:1px solid #f3f4f6}.detail-table td:first-child{color:#6b7280;width:110px;font-weight:500}.detail-table td:last-child{font-weight:600}.photos-header{display:flex;justify-content:space-between;align-items:center}.upload-toggle-btn{font-size:12px;font-weight:600;padding:4px 10px;border:1px solid #2563eb;border-radius:5px;background:transparent;color:#2563eb;cursor:pointer}.upload-toggle-btn:hover{background:#eff6ff}.upload-form{display:flex;flex-direction:column;gap:8px;padding:12px;background:#f9fafb;border-radius:8px;margin-bottom:12px}.upload-form input[type=text]{padding:8px 10px;font-size:13px;border:1px solid #d1d5db;border-radius:6px;outline:none}.upload-form button{padding:8px;font-size:13px;font-weight:600;border:none;border-radius:6px;background:#2563eb;color:#fff;cursor:pointer}.upload-form button:disabled{opacity:.6;cursor:not-allowed}.upload-error{color:#ef4444;font-size:12px}.upload-note{color:#9ca3af;font-size:11px}.photo-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.photo-card img{width:100%;border-radius:6px;object-fit:cover;aspect-ratio:4/3}.photo-caption{font-size:12px;margin-top:4px;color:#374151}.photo-credit{font-size:11px;color:#9ca3af}.error-toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#ef4444;color:#fff;padding:10px 20px;border-radius:8px;font-size:13px;font-weight:500;box-shadow:0 4px 12px #0003;z-index:9999}@media (max-width:640px){.app-header{padding:8px 12px}.app-header h1{font-size:15px}.search-bar{width:calc(100vw - 24px)}.side-panel{width:100vw;border-radius:16px 16px 0 0;height:60vh;top:auto;bottom:0;animation:slideUp .2s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}}
