*{box-sizing:border-box;margin:0;padding:0}:root{--background-color: #f1f5f9;--card-background: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--border-color: #e2e8f0;--primary-brand-color: #4f46e5;--primary-brand-hover: #4338ca;--primary-gradient: linear-gradient(135deg, #6366f1 0%, #818cf8 100%);--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1)}.auth-container{display:flex;justify-content:center;align-items:center;flex-direction:column;min-height:100vh;background:#f5f5f8;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;padding:20px}.render-free-tier-note{color:#dc2626;font-size:14px;margin-bottom:12px;font-weight:500;text-align:center}.auth-content{display:flex;background:#fff;border-radius:16px;box-shadow:0 8px 24px #0000001a;overflow:hidden;max-width:900px;width:100%}.auth-left{flex:1;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:40px 30px;text-align:center}.auth-left h1{font-size:36px;font-weight:700;margin-bottom:10px}.auth-left p{font-size:18px;font-weight:500}.auth-separator{width:1px;background:#ddd}.auth-right{flex:1;display:flex;justify-content:center;align-items:center;padding:40px 30px}.auth-card{width:100%;max-width:420px;padding:30px 25px;border-radius:16px;box-shadow:0 8px 24px #0000001a;text-align:center;background:#fff}.auth-card h2{font-size:28px;font-weight:700;color:#222;margin-bottom:25px}.auth-card form{display:flex;flex-direction:column;gap:18px}.auth-card input,.auth-card select{padding:14px 16px;border:1px solid #ccc;border-radius:10px;font-size:15px;outline:none;transition:all .2s ease-in-out;background:#f9f9f9}.auth-card input:focus,.auth-card select:focus{border-color:#667eea;box-shadow:0 0 6px #667eea66}.auth-card button{margin-top:10px;padding:14px 16px;border:none;border-radius:10px;font-size:16px;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer;transition:background .3s ease}.auth-card button:hover{background:linear-gradient(135deg,#764ba2,#667eea)}.success-msg{margin-top:15px;font-size:14px;font-weight:500;color:#2e7d32}.error-msg{margin-top:15px;font-size:14px;font-weight:500;color:#d32f2f}.redirect-text{margin-top:20px;font-size:14px;color:#444}.redirect-text span{color:#667eea;font-weight:600;cursor:pointer;transition:color .2s ease-in-out}.redirect-text span:hover{color:#764ba2}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.auth-content{flex-direction:column}.auth-separator{display:none}.auth-left{padding:30px 20px;border-radius:16px 16px 0 0}.auth-right{padding:30px 20px}}.navbar{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 20px #0000001a;position:sticky;top:0;z-index:1000}.navbar-container{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;align-items:center;justify-content:space-between;height:70px}.navbar-brand{display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:transform .2s ease}.navbar-brand:hover{transform:scale(1.05)}.brand-icon{color:#fff;width:32px;height:32px}.brand-text{color:#fff;font-size:1.5rem;font-weight:700;letter-spacing:-.5px}.navbar-menu{display:flex;align-items:center;gap:2rem}.navbar-item{background:none;border:none;color:#fff;font-size:1rem;font-weight:500;padding:.5rem 1rem;border-radius:8px;cursor:pointer;transition:all .2s ease}.navbar-item:hover{background:#ffffff1a;transform:translateY(-1px)}.navbar-user{display:flex;align-items:center;gap:1rem}.user-profile{display:flex;align-items:center;gap:.5rem;background:#ffffff1a;border:none;color:#fff;padding:.5rem 1rem;border-radius:25px;cursor:pointer;transition:all .2s ease;font-size:.9rem}.user-profile:hover{background:#fff3}.logout-btn{background:#ffffff1a;border:none;color:#fff;padding:.5rem;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center}.logout-btn:hover{background:#ff575733;transform:translateY(-1px)}.mobile-menu-toggle{display:none;background:none;border:none;color:#fff;cursor:pointer}@media (max-width: 768px){.mobile-menu-toggle{display:block;z-index:1100;position:relative}.navbar-menu{position:absolute;top:70px;left:0;right:0;background:linear-gradient(135deg,#667eea,#764ba2);flex-direction:column;padding:2rem;gap:1rem;height:0;overflow:hidden;opacity:0;transition:height .3s ease,opacity .3s ease;z-index:1000}.navbar-menu.active{height:auto;opacity:1}.navbar-user{flex-direction:column;width:100%;gap:1rem}.user-profile{justify-content:center;width:100%;width:fit-content}}.dashboard-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.dashboard-content{max-width:1200px;margin:0 auto;padding:2rem 1rem}.dashboard-header{text-align:center;margin-bottom:3rem}.header-content h1{font-size:2.5rem;font-weight:700;color:#2d3748;margin-bottom:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-content p{font-size:1.1rem;color:#718096;margin-bottom:2rem}.search-filters{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;max-width:600px;margin:0 auto}.search-box,.filter-box{position:relative;display:flex;align-items:center}.search-box{flex:1;min-width:300px}.search-box input{width:100%;padding:1rem 1rem 1rem 3rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;transition:all .2s ease;background:#fff}.search-box input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.search-icon{position:absolute;left:1rem;color:#a0aec0;z-index:1}.filter-box select{padding:1rem 1rem 1rem 3rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;background:#fff;cursor:pointer;transition:all .2s ease}.filter-box select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.filter-icon{position:absolute;left:1rem;color:#a0aec0;z-index:1}.trips-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem}.trip-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 20px #00000014;cursor:pointer;transition:all .3s ease;border:1px solid #f7fafc}.trip-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #0000001f;border-color:#667eea}.trip-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.trip-route h3{font-size:1.25rem;font-weight:600;color:#2d3748;margin-bottom:.5rem}.bus-type-badge{display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.8rem;font-weight:500}.bus-icon{width:16px;height:16px}.trip-timing{margin-bottom:1rem}.time-info{display:flex;align-items:center;gap:.75rem}.time-icon{width:18px;height:18px;color:#667eea}.departure-time{font-weight:600;color:#2d3748;margin-right:.5rem}.arrival-time{color:#718096}.trip-details{display:flex;margin-bottom:1.5rem;padding-top:1rem;border-top:1px solid #f7fafc}.seats-info{display:flex;align-items:center;gap:.5rem;color:#718096;font-size:.9rem}.seats-icon{width:16px;height:16px}.price-range .price{font-size:1.25rem;font-weight:700;color:#38a169}.trip-actions{text-align:center}.view-seats-btn{width:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.view-seats-btn:hover{transform:translateY(-1px);box-shadow:0 4px 15px #667eea4d}.no-trips{grid-column:1 / -1;text-align:center;padding:4rem 2rem;color:#718096}.no-trips-icon{width:64px;height:64px;margin:0 auto 1rem;opacity:.5}.no-trips h3{font-size:1.5rem;margin-bottom:.5rem;color:#4a5568}@media (max-width: 768px){.dashboard-content{padding:1rem}.header-content h1{font-size:2rem}.search-filters{flex-direction:column;align-items:stretch}.search-box{min-width:auto}.trips-grid{grid-template-columns:1fr}.trip-header{flex-direction:column;gap:1rem}.bus-type-badge{align-self:flex-start}}.dashboard-container{min-height:100vh;background-color:var(--background-color);font-family:system-ui}.organiser-dashboard-container{display:flex;flex-direction:row;gap:2rem;max-width:1400px;margin:0 auto;padding:2rem}.trips-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.trips-header h2{font-size:2.25rem;font-weight:800;color:var(--text-primary);margin:0}.trips-section{flex:3;min-width:0}.create-trip-section{flex:2;background:var(--card-background);padding:2rem;border-radius:1rem;box-shadow:var(--shadow-md);height:fit-content;max-height:calc(100vh - 4rem);overflow-y:auto;position:sticky;top:2rem}.create-trip-section h2{margin-top:0;font-size:1.5rem;color:var(--text-primary)}.trip-list{display:flex;flex-direction:column;gap:1.5rem}.trip-card{background:var(--card-background);padding:1.5rem;border-radius:1rem;border:1px solid var(--border-color);box-shadow:var(--shadow-md);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.trip-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.trip-card.selected{border-color:var(--primary-brand-color);box-shadow:var(--shadow-lg),0 0 0 1px var(--primary-brand-color)}.trip-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.trip-card-header h3{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.trip-price-range{background-color:#e0e7ff;color:var(--primary-brand-hover);padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:600;white-space:nowrap}.trip-details{display:grid;gap:.5rem;margin-bottom:1rem}.trip-detail-item{font-size:.9rem;color:var(--text-secondary);margin:0}.trip-detail-item strong{color:var(--text-primary);font-weight:600}.trip-card-actions{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--border-color);margin-top:1rem}.btn-view-seats{display:inline-flex;align-items:center;gap:.5rem;background-color:var(--card-background);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:.5rem;padding:.5rem 1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-view-seats:hover{background-color:#f9fafb;color:var(--text-primary);border-color:#d1d5db}.btn-view-seats svg{width:1.25rem;height:1.25rem}.trip-card.selected .btn-view-seats{background-color:#eef2ff;color:var(--primary-brand-color);border-color:var(--primary-brand-color)}.expanded-details{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.expanded-details h4{margin:0 0 1rem;color:var(--text-primary);font-weight:600}.bus-layout-vertical{display:flex;flex-direction:column;overflow:scroll;gap:.5rem;margin-top:.5rem}.seat-row{display:flex;align-items:center;gap:.25rem}.driver{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.7rem;color:#000}.driver-placeholder{width:24px;height:24px}.aisle{margin:0 4px;font-weight:700;font-size:.8rem;color:#374151}.seat-item{display:flex;flex-direction:column;align-items:center}.seat{width:24px;height:24px;border-radius:4px;background-color:#e5e7eb;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:#000;box-shadow:0 1px 2px #0000001a}.seat-price{font-size:.6rem;font-weight:600;color:#374151}.seat.booked{background-color:#ef4444;color:#fff;cursor:not-allowed}.seat-legend{display:flex;gap:1rem;margin-top:1rem;align-items:center}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#000}.seat-legend .seat{width:20px;height:20px;border-radius:.375rem;display:flex;justify-content:center;align-items:center;font-size:.7rem}.trip-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group label{font-weight:600;color:var(--text-primary);font-size:.875rem}.form-group input,.form-group select{padding:.75rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease;background:#fff;color:var(--text-primary)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary-brand-color);box-shadow:0 0 0 3px #4f46e51a}.btn-submit,.btn-generate,.btn-create{background:var(--primary-gradient);color:#fff;border:none;border-radius:.5rem;padding:.75rem 1.5rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:1rem;box-shadow:var(--shadow-sm)}.btn-submit:hover,.btn-generate:hover,.btn-create:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-create{display:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px)}to{transform:translateY(0)}}.create-trip-modal{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .3s ease}.modal-content{background:#fff;border-radius:1rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;animation:slideUp .3s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);position:sticky;top:0;background:#fff;z-index:10}.modal-header h2{font-size:1.25rem;color:var(--text-primary);margin:0}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer}.modal-content .trip-form{padding:1.5rem}@media (max-width: 1024px){.organiser-dashboard-container{flex-direction:column;gap:2rem}.create-trip-section{position:static;width:100%;max-height:none}}@media (max-width: 768px){.organiser-dashboard-container{padding:1rem}.trips-header{flex-direction:column;align-items:stretch;gap:1rem}.trips-header h2{text-align:center}.btn-create{display:block}.desktop-form{display:none}.form-row{grid-template-columns:1fr}.trip-card-actions{flex-direction:column;align-items:flex-start;gap:1rem}}.trip-details-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.trip-details-content{max-width:1400px;margin:0 auto;padding:2rem 1rem;display:grid;grid-template-columns:1fr 350px;gap:2rem}.trip-info-section{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px #00000014}.seat.available{background-color:#4caf50}.seat.selected{background-color:#2196f3}.hold-warning{background-color:#fff3cd;color:#856404;border:1px solid #ffeeba;padding:10px;margin-bottom:15px;border-radius:5px;text-align:center;font-weight:500}.purchase-success{background:#e6ffed;border:1px solid #34d399;text-align:center;color:#065f46;padding:12px 16px;border-radius:8px;margin-top:12px;font-size:15px;font-weight:500;box-shadow:0 2px 6px #00000014}.seat.booked{background-color:red;pointer-events:none}.trip-header h1{font-size:2rem;font-weight:700;color:#2d3748;margin-bottom:1rem}.trip-meta{display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:2rem}.meta-item{display:flex;align-items:center;gap:.5rem;color:#718096}.meta-icon{width:18px;height:18px;color:#667eea}.seat-map-section{margin-top:2rem}.seat-map-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.seat-map-header h2{font-size:1.5rem;font-weight:600;color:#2d3748}.seat-legend{display:flex;gap:1rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#718096}.seat-demo{width:20px;height:20px;border-radius:6px;border:2px solid #e2e8f0}.seat-demo.available{background:#f7fafc;border-color:#e2e8f0}.seat-demo.selected{background:#667eea;border-color:#667eea}.seat-demo.held{background:#ed8936;border-color:#ed8936}.seat-demo.booked{background:#e53e3e;border-color:#e53e3e}.bus-layout{background:#f8fafc;border-radius:12px;padding:2rem;border:2px solid #e2e8f0}.driver-section{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e2e8f0}.steering-wheel{width:40px;height:40px;border:4px solid #4a5568;border-radius:50%;position:relative}.steering-wheel:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;border:2px solid #4a5568;border-radius:50%}.seats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;max-width:300px;margin:0 auto}.seat{width:80px;height:80px;border-radius:12px;border:2px solid #e2e8f0;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;background:#f7fafc;position:relative}.seat:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.seat.available{background:#f7fafc;border-color:#e2e8f0}.seat.available:hover{border-color:#667eea;background:#edf2f7}.seat.selected{background:#667eea;border-color:#667eea;color:#fff}.seat.held{background:#ed8936;border-color:#ed8936;color:#fff}.seat.booked{background:#e53e3e;border-color:#e53e3e;color:#fff;cursor:not-allowed}.seat-number{font-weight:600;font-size:.9rem}.seat-price{font-size:.7rem;opacity:.8}.booking-sidebar{display:flex;flex-direction:column;gap:1.5rem}.hold-timer{background:linear-gradient(135deg,#ed8936,#dd6b20);color:#fff;padding:1rem;border-radius:12px;display:flex;align-items:center;gap:.5rem;font-weight:600;animation:pulse 2s infinite}.timer-icon{width:20px;height:20px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.selected-seats-info{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 20px #00000014}.selected-seats-info h3{font-size:1.2rem;font-weight:600;color:#2d3748;margin-bottom:1rem}.no-selection{color:#718096;font-style:italic}.seats-list{display:flex;flex-direction:column;gap:.75rem}.selected-seat-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f7fafc;border-radius:8px;border:1px solid #e2e8f0}.seat-id{font-weight:600;color:#2d3748}.seat-price{font-weight:600;color:#38a169}.booking-summary{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 20px #00000014}.total-price{text-align:center;margin-bottom:1.5rem}.total-price span{font-size:1.5rem;font-weight:700;color:#2d3748}.hold-seats-btn,.purchase-btn{width:100%;padding:1rem;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.hold-seats-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.hold-seats-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 15px #667eea4d}.hold-seats-btn:disabled{opacity:.6;cursor:not-allowed}.checkout-section{display:flex;flex-direction:column;gap:1rem}.checkout-info{display:flex;align-items:center;gap:.5rem;color:#38a169;font-weight:500;padding:.75rem;background:#f0fff4;border-radius:8px;border:1px solid #9ae6b4}.check-icon{width:18px;height:18px}.purchase-btn{background:linear-gradient(135deg,#38a169,#2f855a);color:#fff}.purchase-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 15px #38a1694d}.purchase-btn:disabled{opacity:.6;cursor:not-allowed}.card-icon{width:18px;height:18px}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem}.error-container button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}@media (max-width: 1024px){.trip-details-content{grid-template-columns:1fr;gap:1rem}.booking-sidebar{order:-1}}@media (max-width: 768px){.trip-details-content{padding:1rem}.trip-info-section{padding:1.5rem}.trip-meta{flex-direction:column;gap:1rem}.seat-map-header{flex-direction:column;gap:1rem;align-items:flex-start}.seat-legend{flex-wrap:wrap}.seats-grid{max-width:250px}.seat{width:60px;height:60px}}.bookings-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.bookings-content{max-width:1000px;margin:0 auto;padding:2rem 1rem}.bookings-header{text-align:center;margin-bottom:3rem}.bookings-header h1{font-size:2.5rem;font-weight:700;color:#2d3748;margin-bottom:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.bookings-header p{font-size:1.1rem;color:#718096}.no-bookings{text-align:center;padding:4rem 2rem;background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014}.no-bookings-icon{width:64px;height:64px;margin:0 auto 1.5rem;color:#a0aec0}.no-bookings h3{font-size:1.5rem;font-weight:600;color:#4a5568;margin-bottom:.5rem}.no-bookings p{color:#718096;margin-bottom:2rem}.explore-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.explore-btn:hover{transform:translateY(-1px);box-shadow:0 4px 15px #667eea4d}.bookings-list{display:flex;flex-direction:column;gap:1.5rem}.booking-card{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px #00000014;border:1px solid #f7fafc;transition:all .3s ease}.booking-card:hover{transform:translateY(-2px);box-shadow:0 8px 30px #0000001f;border-color:#667eea}.booking-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #f7fafc}.trip-info h3{font-size:1.25rem;font-weight:600;color:#2d3748;margin-bottom:.5rem}.route-info{display:flex;align-items:center;gap:.5rem;color:#718096;font-size:.9rem}.route-icon{width:16px;height:16px}.booking-status{flex-shrink:0}.status-badge{display:flex;align-items:center;gap:.5rem;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.8rem;font-weight:600}.status-icon{width:16px;height:16px}.booking-details{margin-bottom:1.5rem}.detail-row{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:1rem}.detail-item{display:flex;align-items:center;gap:.75rem}.detail-icon{width:18px;height:18px;color:#667eea;flex-shrink:0}.detail-item div{display:flex;flex-direction:column}.detail-label{font-size:.8rem;color:#718096;margin-bottom:.25rem}.detail-value{font-weight:600;color:#2d3748}.detail-value.amount{color:#38a169;font-size:1.1rem}.seats-section{margin-bottom:1.5rem;padding-top:1rem;border-top:1px solid #f7fafc}.seats-section h4{font-size:1rem;font-weight:600;color:#2d3748;margin-bottom:.75rem}.seats-list{display:flex;flex-wrap:wrap;gap:.5rem;flex-direction:row}.seat-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;height:40px;width:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;font-weight:600;font-size:.9rem}.booking-actions{display:flex;gap:1rem;justify-content:flex-end}.action-btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.action-btn.secondary{background:#f7fafc;color:#4a5568;border:1px solid #e2e8f0}.action-btn.secondary:hover{background:#edf2f7;border-color:#cbd5e0}.action-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.action-btn.primary:hover{transform:translateY(-1px);box-shadow:0 4px 15px #667eea4d}@media (max-width: 768px){.bookings-content{padding:1rem}.bookings-header h1{font-size:2rem}.booking-card{padding:1.5rem}.booking-header{flex-direction:column;gap:1rem}.booking-status{align-self:flex-start}.detail-row{grid-template-columns:1fr;gap:1rem}.booking-actions{flex-direction:column}.action-btn{width:100%}}.profile-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.profile-content{max-width:800px;margin:0 auto;padding:2rem 1rem}.profile-header{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-bottom:2rem;text-align:center}.profile-avatar{width:100px;height:100px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 30px #667eea4d}.avatar-icon{width:50px;height:50px;color:#fff}.profile-title h1{font-size:2rem;font-weight:700;color:#2d3748;margin-bottom:.25rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.profile-title p{font-size:1rem;color:#718096}.profile-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 20px #00000014}.card-header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #f7fafc}.card-header h2{font-size:1.25rem;font-weight:600;color:#2d3748}.profile-fields{display:flex;flex-direction:column;gap:1.5rem}.field-group{display:flex;flex-direction:column;gap:.5rem}.field-label{display:flex;align-items:center;gap:.5rem;font-weight:600;color:#4a5568;font-size:.9rem}.field-icon{width:18px;height:18px;color:#667eea}.field-value{font-size:1rem;color:#2d3748;padding:.5rem 0}.field-note{font-size:.8rem;color:#a0aec0;font-style:italic}.role-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600}.role-badge.organizer{background:linear-gradient(135deg,#ed8936,#dd6b20);color:#fff}.role-badge.passenger{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.profile-content{padding:1rem}.profile-header{gap:.75rem}.profile-title h1{font-size:1.75rem}.profile-card{padding:1rem}}
