.home-container{max-width:1200px;margin:0 auto;padding:2rem;text-align:center;min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center}.home-container h1{font-size:2.5rem;color:#333;margin-bottom:1rem;font-weight:700}.home-container p{font-size:1.2rem;color:#666;margin-bottom:3rem;max-width:600px}.home-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;width:100%;max-width:800px}.home-card{background:#fff;border:2px solid #e1e5e9;border-radius:12px;padding:2rem;box-shadow:0 4px 6px #0000001a;transition:transform .2s ease,box-shadow .2s ease}.home-card:hover{transform:translateY(-2px);box-shadow:0 8px 15px #00000026}.home-card h3{font-size:1.5rem;color:#333;margin-bottom:1rem;font-weight:600}.home-card p{font-size:1rem;color:#666;margin-bottom:2rem;line-height:1.5}.home-card div{display:flex;flex-direction:column;gap:.75rem}.btn{display:inline-block;padding:.75rem 1.5rem;background-color:#007bff;color:#fff;text-decoration:none;border-radius:6px;font-weight:500;font-size:1rem;transition:background-color .2s ease;border:none;cursor:pointer}.btn:hover{background-color:#0056b3;text-decoration:none}.btn:active{transform:translateY(1px)}@media (max-width: 768px){.home-container{padding:1rem}.home-container h1{font-size:2rem}.home-container p{font-size:1rem;margin-bottom:2rem}.home-cards{grid-template-columns:1fr;gap:1.5rem}.home-card{padding:1.5rem}}@media (max-width: 480px){.home-container h1{font-size:1.75rem}.home-card div{gap:.5rem}.btn{padding:.625rem 1.25rem;font-size:.9rem}}.passenger-login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4facfe,#00f2fe);padding:1rem}.passenger-login-form{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 10px 25px #0000001a;width:100%;max-width:420px}.passenger-login-title{font-size:1.75rem;font-weight:700;color:#1f2937;text-align:center;margin:0 0 1.5rem}.passenger-form-group{margin-bottom:1rem}.passenger-form-input{width:100%;padding:.875rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease;background-color:#fff;box-sizing:border-box}.passenger-form-input:focus{outline:none;border-color:#4facfe;box-shadow:0 0 0 3px #4facfe1a}.passenger-form-input::placeholder{color:#9ca3af}.passenger-submit-btn{width:100%;background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff;border:none;border-radius:8px;padding:.875rem;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;margin-top:.5rem}.passenger-submit-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4facfe4d}.passenger-submit-btn:active{transform:translateY(0)}.passenger-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.passenger-error-message{background-color:#fee2e2;border:1px solid #fca5a5;color:#b91c1c;padding:.75rem;border-radius:6px;font-size:.9rem;margin-bottom:1rem;text-align:center}.passenger-login-footer{text-align:center;margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb;color:#6b7280;font-size:.9rem}.passenger-login-footer a{color:#4facfe;text-decoration:none;font-weight:500;transition:color .2s ease}.passenger-login-footer a:hover{color:#00f2fe;text-decoration:underline}.passenger-submit-btn.loading{position:relative;color:transparent}.passenger-submit-btn.loading:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;border:2px solid transparent;border-top:2px solid white;border-radius:50%;animation:passenger-spin 1s linear infinite}@keyframes passenger-spin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.signup-highlight{background:linear-gradient(135deg,#4facfe,#00f2fe);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:600}@media (max-width: 480px){.passenger-login-container{padding:.5rem}.passenger-login-form{padding:1.5rem}.passenger-login-title{font-size:1.5rem}.passenger-form-input,.passenger-submit-btn{padding:.75rem;font-size:.95rem}}.passenger-login-form:focus-within{box-shadow:0 15px 35px #00000026}.passenger-login-form{animation:passenger-slideUp .3s ease-out}@keyframes passenger-slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.passenger-form-input:invalid:not(:placeholder-shown){border-color:#f87171}.passenger-form-input:valid:not(:placeholder-shown){border-color:#10b981}.welcome-text{text-align:center;color:#6b7280;font-size:.9rem;margin-bottom:1.5rem;line-height:1.4}.passenger-signup-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.passenger-signup-form{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 10px 25px #0000001a;width:100%;max-width:420px}.passenger-signup-title{font-size:1.75rem;font-weight:700;color:#1f2937;text-align:center;margin:0 0 .75rem}.signup-welcome-text{text-align:center;color:#6b7280;font-size:.9rem;margin-bottom:1.5rem;line-height:1.4}.passenger-signup-form-group{margin-bottom:1rem}.passenger-signup-form-input{width:100%;padding:.875rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease;background-color:#fff;box-sizing:border-box}.passenger-signup-form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.passenger-signup-form-input::placeholder{color:#9ca3af}.passenger-signup-submit-btn{width:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;padding:.875rem;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;margin-top:.5rem}.passenger-signup-submit-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.passenger-signup-submit-btn:active{transform:translateY(0)}.passenger-signup-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.passenger-signup-error-message{background-color:#fee2e2;border:1px solid #fca5a5;color:#b91c1c;padding:.75rem;border-radius:6px;font-size:.9rem;margin-bottom:1rem;text-align:center}.passenger-signup-footer{text-align:center;margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb;color:#6b7280;font-size:.9rem}.passenger-signup-footer a{color:#667eea;text-decoration:none;font-weight:500;transition:color .2s ease}.passenger-signup-footer a:hover{color:#764ba2;text-decoration:underline}.passenger-signup-submit-btn.loading{position:relative;color:transparent}.passenger-signup-submit-btn.loading:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;border:2px solid transparent;border-top:2px solid white;border-radius:50%;animation:signup-spin 1s linear infinite}@keyframes signup-spin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.passenger-signup-form-input:invalid:not(:placeholder-shown){border-color:#f87171;box-shadow:0 0 0 3px #f871711a}.passenger-signup-form-input:valid:not(:placeholder-shown){border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.optional-field{position:relative}.optional-field:after{content:"Optional";position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:.75rem;color:#9ca3af;background:#fff;padding:0 4px;pointer-events:none}.optional-field input:focus::placeholder,.optional-field input:not(:placeholder-shown){color:transparent}.optional-field input:focus+.optional-label,.optional-field input:not(:placeholder-shown)+.optional-label{display:none}.password-strength{margin-top:.25rem;font-size:.75rem}.password-strength.weak{color:#ef4444}.password-strength.medium{color:#f59e0b}.password-strength.strong{color:#10b981}.form-progress{height:2px;background:#e5e7eb;border-radius:1px;margin-bottom:1.5rem;overflow:hidden}.form-progress-bar{height:100%;background:linear-gradient(135deg,#667eea,#764ba2);transition:width .3s ease;border-radius:1px}@media (max-width: 480px){.passenger-signup-container{padding:.5rem}.passenger-signup-form{padding:1.5rem}.passenger-signup-title{font-size:1.5rem}.signup-welcome-text{font-size:.85rem}.passenger-signup-form-input,.passenger-signup-submit-btn{padding:.75rem;font-size:.95rem}.optional-field:after{display:none}}.passenger-signup-form:focus-within{box-shadow:0 15px 35px #00000026}.passenger-signup-form{animation:signup-slideUp .3s ease-out}@keyframes signup-slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.success-message{background-color:#d1fae5;border:1px solid #a7f3d0;color:#065f46;padding:.75rem;border-radius:6px;font-size:.9rem;margin-bottom:1rem;text-align:center}.trips-browse{display:grid;gap:12px;max-width:800px;margin:0 auto;padding:20px}.trips-browse h2{margin:0;font-size:1.75rem;font-weight:600;color:#1f2937;text-align:center}.trip-card-link{display:block;padding:16px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;text-decoration:none;color:inherit;box-shadow:0 1px 3px #0000001a;transition:all .2s ease-in-out;cursor:pointer}.trip-card-link:hover{text-decoration:none;color:inherit;box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-1px);border-color:#3b82f6}.trip-card-link:active{transform:translateY(0);box-shadow:0 2px 4px -1px #0000001a}.trip-route{font-weight:600;font-size:1.125rem;color:#1f2937;margin-bottom:6px;line-height:1.4}.trip-details{color:#64748b;font-size:.875rem;display:flex;align-items:center;gap:8px;flex-wrap:wrap;line-height:1.4}.trip-details-separator{color:#9ca3af;font-weight:700}.trip-price{color:#059669;font-weight:600}.trip-date{color:#6b7280}.loading-state{text-align:center;padding:48px 16px;color:#6b7280;font-size:.875rem}.loading-spinner{display:inline-block;width:20px;height:20px;border:2px solid #e5e7eb;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-right:8px;vertical-align:middle}.empty-state{text-align:center;padding:64px 16px;color:#6b7280}.empty-state-icon{font-size:3rem;margin-bottom:16px;opacity:.5}.empty-state-text{font-size:1.125rem;font-weight:500;margin-bottom:8px}.empty-state-subtext{font-size:.875rem;color:#9ca3af}.bus-type{background-color:#f3f4f6;color:#4b5563;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:500;white-space:nowrap}@media (max-width: 768px){.trips-browse{padding:16px;gap:16px}.trips-browse h2{font-size:1.5rem}.trip-card-link{padding:16px}.trip-route{font-size:1rem}.trip-details{flex-direction:column;align-items:flex-start;gap:4px}.trip-details-separator{display:none}}@media (max-width: 480px){.trips-browse,.trip-card-link{padding:12px}.trip-details{font-size:.8rem}}.trip-card-link:focus{outline:2px solid #3b82f6;outline-offset:2px}.trip-card-link{animation:fadeInUp .3s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.trip-card-link:nth-child(2){animation-delay:.1s}.trip-card-link:nth-child(3){animation-delay:.2s}.trip-card-link:nth-child(4){animation-delay:.3s}.trip-card-link:nth-child(5){animation-delay:.4s}.trip-status{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;font-weight:500}.trip-status-live{color:#059669}.trip-status-live:before{content:"●";color:#10b981}.trip-status-upcoming{color:#d97706}.trip-status-upcoming:before{content:"●";color:#f59e0b}.trip-detail-container{display:grid;gap:12px}.trip-detail-title{margin:0}.seats-grid{display:grid;grid-template-columns:repeat(8,minmax(0,46px));gap:8px}.seat-button{border:1px solid #e5e7eb;border-radius:6px;padding:10px 0;font-size:12px;cursor:pointer;transition:opacity .2s ease}.seat-button:hover:not(:disabled){opacity:.8}.seat-button:disabled{cursor:not-allowed;opacity:.6}.seat-available{background:#dcfce7}.seat-held{background:#fff7ed}.seat-sold{background:#fee2e2}.trip-instructions{color:#64748b;font-size:14px;margin:0}.bookings-container{max-width:1000px;margin:0 auto;padding:2rem;display:grid;gap:1rem}.bookings-title{font-size:2rem;color:#1f2937;margin:0 0 1.5rem;font-weight:700}.bookings-loading{text-align:center;padding:3rem;font-size:1.1rem;color:#6b7280}.booking-card{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border:1px solid #e5e7eb;border-radius:8px;background:#fff;box-shadow:0 1px 3px #0000001a;transition:box-shadow .2s ease,transform .2s ease}.booking-card:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-1px)}.booking-info{flex:1}.booking-route{font-weight:600;font-size:1.1rem;color:#1f2937;margin-bottom:.5rem}.booking-details{color:#64748b;font-size:.95rem;line-height:1.4}.booking-details .separator{margin:0 .5rem;color:#9ca3af}.download-btn{background-color:#3b82f6;color:#fff;border:none;border-radius:6px;padding:.75rem 1.25rem;font-size:.9rem;font-weight:500;cursor:pointer;transition:background-color .2s ease,transform .1s ease;white-space:nowrap;margin-left:1rem}.download-btn:hover{background-color:#2563eb}.download-btn:active{transform:scale(.98)}.download-btn:focus{outline:none;box-shadow:0 0 0 3px #3b82f64d}.no-bookings{text-align:center;padding:3rem;color:#6b7280;font-size:1.1rem;background:#f9fafb;border:2px dashed #d1d5db;border-radius:8px;margin-top:1rem}.booking-status{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;margin-left:.5rem}.booking-status.confirmed{background-color:#dcfce7;color:#166534}.booking-status.pending{background-color:#fef3c7;color:#92400e}.booking-status.cancelled{background-color:#fee2e2;color:#991b1b}.booking-price{font-weight:600;color:#059669}@media (max-width: 768px){.bookings-container{padding:1rem}.bookings-title{font-size:1.75rem}.booking-card{flex-direction:column;align-items:stretch;gap:1rem;padding:1.25rem}.download-btn{margin-left:0;align-self:stretch;text-align:center}.booking-details{font-size:.9rem}}@media (max-width: 480px){.bookings-title{font-size:1.5rem}.booking-card{padding:1rem}.booking-route{font-size:1rem}.booking-details{font-size:.85rem}.download-btn{padding:.625rem 1rem;font-size:.85rem}}.bookings-loading:after{content:"";display:inline-block;width:20px;height:20px;border:2px solid #e5e7eb;border-radius:50%;border-top:2px solid #3b82f6;animation:spin 1s linear infinite;margin-left:.5rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.trip-new-form{display:grid;gap:10px;max-width:520px}.trip-new-title{margin:0 0 10px;font-size:24px;font-weight:600;color:#1f2937}.error-message{color:#dc2626;background-color:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:12px;font-size:14px}.form-input{padding:12px 16px;border:1px solid #d1d5db;border-radius:6px;font-size:16px;transition:border-color .2s ease,box-shadow .2s ease}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input::placeholder{color:#9ca3af}.form-input:invalid{border-color:#ef4444}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.submit-button{padding:12px 24px;background-color:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s ease,opacity .2s ease;margin-top:8px}.submit-button:hover:not(:disabled){background-color:#2563eb}.submit-button:disabled{background-color:#9ca3af;cursor:not-allowed;opacity:.7}.submit-button:focus{outline:none;box-shadow:0 0 0 3px #3b82f64d}@media (max-width: 600px){.trip-new-form{max-width:100%;padding:16px}.form-row{grid-template-columns:1fr}}
