*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #2563eb;--primary-hover: #1d4ed8;--secondary: #64748b;--success: #22c55e;--error: #ef4444;--border: #e2e8f0;--bg: #f8fafc;--text: #0f172a;--text-light: #64748b}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;color:var(--text);background:var(--bg)}.info-icon{display:inline-block;margin-left:6px;cursor:help;font-size:14px;opacity:.7;transition:opacity .2s ease}.info-icon:hover{opacity:1}.whatsapp-float{position:fixed;bottom:30px;right:20px;display:flex;align-items:center;gap:10px;background:#25d366;padding:10px 16px;border-radius:50px;box-shadow:0 4px 12px #25d36666;cursor:pointer;transition:all .3s ease;z-index:1000;text-decoration:none;max-width:280px}.whatsapp-float:hover{transform:translateY(-2px);box-shadow:0 6px 16px #25d36680}.whatsapp-icon{width:36px;height:36px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.whatsapp-icon svg{width:22px;height:22px;fill:#25d366}.whatsapp-text{color:#fff;font-size:13px;font-weight:600;line-height:1.3}@media (max-width: 768px){.whatsapp-float{padding:10px;bottom:15px;right:15px;gap:0}.whatsapp-icon{width:50px;height:50px}.whatsapp-icon svg{width:28px;height:28px}.whatsapp-text{display:none}}.container{max-width:1400px;margin:0 auto;padding:2rem}header{margin-bottom:3rem}header .header-content{display:flex;align-items:center;justify-content:space-between;gap:2rem}header .header-content>div{display:flex;align-items:center;gap:1rem;flex-shrink:0}.main-nav{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.language-switcher{display:flex;gap:.5rem;margin-left:1rem;border-left:2px solid var(--border);padding-left:1rem;flex-shrink:0}.language-switcher button{padding:.5rem .75rem;border:2px solid var(--border);background:#fff;color:var(--text);border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.875rem;line-height:1;display:flex;align-items:center;justify-content:center}.language-switcher button:hover{border-color:var(--primary);transform:scale(1.1);box-shadow:0 2px 8px #2563eb33}.language-switcher button.active{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb33;transform:scale(1.05)}.main-nav a{padding:.75rem 1.5rem;text-decoration:none;color:var(--text);font-weight:600;font-size:1rem;border-radius:8px;transition:all .2s;white-space:nowrap}.main-nav a:hover{background:var(--bg);color:var(--primary)}.main-nav a.active{background:#fbbf24;color:#0f172a}.nav-links{display:flex;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid var(--border)}.nav-links a{padding:.5rem 1rem;border-radius:6px;text-decoration:none;color:var(--text);font-weight:500;transition:all .2s}.nav-links a:hover{background:var(--bg);color:var(--primary)}.nav-links a.active{background:var(--primary);color:#fff}.step-indicator{display:flex;align-items:center;justify-content:center;margin-top:2rem;padding-top:2rem;border-top:2px solid var(--border);gap:.5rem}.step{display:flex;flex-direction:column;align-items:center;gap:.5rem;flex-shrink:0}.step-number{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.125rem;background:#e2e8f0;color:#64748b;transition:all .3s}.step-label{font-size:.875rem;font-weight:500;color:var(--text-light);text-align:center;white-space:nowrap}.step.active .step-number{background:#eab308;color:#fff;box-shadow:0 0 0 4px #eab3081a}.step.active .step-label{color:#eab308;font-weight:600}.step.completed .step-number{background:#22c55e;color:#fff}.step.completed .step-label{color:var(--text)}.step-divider{width:60px;height:2px;background:#e2e8f0;margin-bottom:1.5rem}header .logo{max-width:150px;height:auto;flex-shrink:0}header .header-text{text-align:left}header h1{font-size:2.5rem;font-weight:700;color:var(--text);margin-bottom:.5rem}header p{font-size:1.125rem;color:var(--text-light)}.booking-layout{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}.booking-form{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 1px 3px #0000001a}.form-section{margin-bottom:2rem}.form-section h2{font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;color:var(--text)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:500;margin-bottom:.5rem;color:var(--text)}.field-hint{display:block;margin-top:.5rem;font-size:.875rem;color:var(--text-light)}.form-group select,.form-group input,.form-group textarea{width:100%;padding:.75rem;border:2px solid var(--border);border-radius:8px;font-size:1rem;transition:all .2s}.form-group select:focus,.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary)}.form-group select option:disabled{color:#cbd5e1;background:#f1f5f9}.form-group small{display:block;margin-top:.5rem;color:var(--text-light);font-size:.875rem}.form-group textarea{resize:vertical;font-family:inherit}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.radio-group{display:flex;gap:1rem}.radio-label{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:2px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s}.radio-label:hover{border-color:var(--primary);background:#f1f5f9}.radio-label input[type=radio]{width:auto;margin:0}.radio-label input[type=radio]:checked+span{font-weight:600;color:var(--primary)}.radio-label:has(input:checked){border-color:var(--primary);background:#eff6ff}.radio-label:has(input:disabled){opacity:.5;cursor:not-allowed}.radio-label:has(input:disabled) span{color:var(--text-light)}.day-trip-subtype{margin-left:2rem;margin-top:.75rem}.trip-type-notice{margin-top:1rem;padding:1rem;background:#fef3c7;border:1px solid #fbbf24;border-radius:8px;display:flex;gap:.75rem;align-items:flex-start;font-size:.875rem;line-height:1.5}.trip-type-notice .notice-icon{font-size:1.25rem;flex-shrink:0}.trip-type-notice .notice-text{color:#78350f}.trip-type-notice a{color:#78350f;font-weight:600;text-decoration:underline}.quantity-control{display:flex;align-items:center;gap:.5rem;margin-top:.5rem}.quantity-control .qty-btn{width:40px;height:40px;border:2px solid var(--border);background:#fff;border-radius:6px;font-size:1.25rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.quantity-control .qty-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.quantity-control .qty-btn:disabled{opacity:.4;cursor:not-allowed}.quantity-control input[type=number]{flex:1;text-align:center;font-weight:600;font-size:1rem}.duration-inputs{display:flex;gap:1rem;align-items:center;margin-top:.5rem}.duration-input-group{display:flex;align-items:center;gap:.5rem}.duration-input-group input{width:80px;padding:.75rem;border:2px solid var(--border);border-radius:8px;font-size:1rem;text-align:center}.duration-label{font-size:.9rem;color:var(--text-light);font-weight:500}.stop-wrapper{margin-bottom:1.5rem;padding:1rem;border:1px solid var(--border);border-radius:8px;background:#f9fafb}.intermediate-stop{display:flex;gap:.5rem;margin-bottom:1rem}.intermediate-stop input{flex:1}.stop-duration{padding-left:.5rem}.duration-label-small{display:block;font-size:.875rem;font-weight:600;color:var(--text);margin-bottom:.5rem}.btn-remove{width:2.5rem;height:2.5rem;border:none;background:var(--error);color:#fff;border-radius:8px;font-size:1.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.btn-remove:hover{background:#dc2626;transform:scale(1.05)}.btn-primary,.btn-secondary{width:100%;padding:1rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:1rem}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 4px 6px #2563eb33}.btn-primary:disabled{background:var(--secondary);cursor:not-allowed;opacity:.6}.btn-secondary{background:#fff;color:var(--primary);border:2px solid var(--primary)}.btn-secondary:hover{background:#eff6ff;transform:translateY(-2px)}.price-display{background:linear-gradient(135deg,#667eea,#764ba2);padding:1.5rem;border-radius:12px;margin-top:2rem;color:#fff}.price-details{display:flex;flex-direction:column;gap:1rem}.price-item{display:flex;justify-content:space-between;align-items:center;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.2)}.price-item span{font-size:1rem;opacity:.9}.price-item strong{font-size:1.125rem}.price-total{display:flex;justify-content:space-between;align-items:center;font-size:1.25rem;font-weight:600;padding-top:.75rem}.route-display{background:#f1f5f9;padding:1.5rem;border-radius:12px;margin-top:2rem;border:2px solid var(--border)}.route-details{display:flex;gap:2rem}.route-item{display:flex;flex-direction:column;gap:.5rem}.route-item span{font-size:.875rem;color:var(--text-light)}.route-item strong{font-size:1.25rem;color:var(--text)}.bus-options{display:grid;gap:1rem;margin-bottom:1.5rem}.bus-option{border:2px solid var(--border);border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .2s;background:#fff}.bus-option:hover{border-color:var(--primary);box-shadow:0 4px 12px #2563eb1a}.bus-option.selected{border-color:var(--primary);background:#eff6ff;box-shadow:0 4px 12px #2563eb33}.bus-option-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem}.bus-option-title{font-size:1.25rem;font-weight:600;color:var(--text);margin-bottom:.25rem}.bus-option-type{font-size:.875rem;color:var(--text-light);text-transform:capitalize}.bus-option-price{text-align:right}.bus-option-price-label{font-size:.75rem;color:var(--text-light);display:block;margin-bottom:.25rem}.bus-option-price-value{font-size:1.5rem;font-weight:700;color:var(--primary)}.bus-option-details{display:flex;gap:1.5rem;font-size:.875rem;color:var(--text-light);margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.bus-option-detail{display:flex;align-items:center;gap:.5rem}.price-total strong{font-size:1.75rem}.map-container{position:sticky;top:2rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden;height:600px}#map{width:100%;height:100%}.map-notice{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:var(--text-light);background:#fff;padding:2rem;border-radius:8px;width:80%;display:none}.map-legend{position:absolute;bottom:20px;left:20px;background:#fff;padding:12px 16px;border-radius:8px;box-shadow:0 2px 6px #00000026;z-index:1000}.legend-item{display:flex;align-items:center;gap:8px;margin-bottom:6px}.legend-item:last-child{margin-bottom:0}.legend-color{width:20px;height:4px;border-radius:2px}.legend-text{font-size:13px;color:var(--text);font-weight:500}@media (max-width: 1024px){.booking-layout{grid-template-columns:1fr}.map-container{position:relative;top:0;height:400px}header .header-content>div{flex-wrap:wrap}}@media (max-width: 640px){.container{padding:1rem}header .header-content{flex-direction:column;align-items:flex-start;gap:1rem}.main-nav{width:100%;flex-wrap:wrap;gap:.5rem}.main-nav a{padding:.5rem 1rem;font-size:.875rem;flex:1;text-align:center;min-width:fit-content}.language-switcher{margin-left:0;border-left:none;padding-left:0;margin-top:.5rem}header .logo{max-width:120px}header h1{font-size:2rem}.step-indicator{gap:.25rem}.step-label{font-size:.75rem}.step-number{width:32px;height:32px;font-size:.875rem}.step-divider{width:30px}.form-row{grid-template-columns:1fr}.radio-group{flex-direction:column}.booking-form{padding:1.5rem}}.selected-bus-info{margin-top:2rem;padding:2rem;background:#f1f5f9;border-radius:12px;border:2px solid var(--primary)}.selected-bus-info h3{margin:0 0 1rem;color:var(--text)}.selected-bus-info #selectedBusDetails{background:#fff;padding:1.5rem;border-radius:8px;margin-bottom:1rem}.selected-bus-info button{margin-top:.5rem}.phone-input-wrapper{display:flex;gap:.5rem}.phone-prefix{flex:0 0 120px;padding:.75rem;border:2px solid var(--border);border-radius:8px;background:#fff;color:var(--text);font-size:1rem;cursor:pointer;transition:all .2s}.phone-prefix:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.phone-number-input{flex:1}.trip-section{background:#f8f9fa;padding:1.5rem;border-radius:12px;margin-bottom:1.5rem}.trip-section-title{color:var(--primary);font-size:1.125rem;font-weight:600;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid var(--primary)}.error-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease;padding:20px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.error-modal-content{background:#fff;border-radius:24px;padding:40px;max-width:500px;width:100%;text-align:center;box-shadow:0 20px 60px #0000004d;animation:slideUp .4s ease;position:relative}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.error-icon{width:80px;height:80px;background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;animation:scaleIn .5s ease .2s both}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.error-icon:before{content:"✕";color:#fff;font-size:48px;font-weight:700}.error-modal h3{color:#1f2937;font-size:1.75rem;margin-bottom:16px;font-weight:700}.error-modal p{color:#6b7280;font-size:1.125rem;line-height:1.7;margin-bottom:32px;white-space:pre-line}.error-modal-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:14px 40px;border-radius:12px;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #667eea4d}.error-modal-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}@media (max-width: 768px){.error-modal-content{padding:30px 20px}.error-icon{width:64px;height:64px}.error-icon:before{font-size:36px}.error-modal h3{font-size:1.5rem}.error-modal p{font-size:1rem}}.user-account-widget{display:flex;align-items:center;gap:.75rem}.user-account-widget.logged-in,.user-dropdown{position:relative}.user-trigger{display:flex;align-items:center;gap:.5rem;background:#fff;border:1px solid var(--border);padding:.5rem .75rem;border-radius:8px;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #0000001a}.user-trigger:hover,.user-dropdown.open .user-trigger{border-color:var(--primary);box-shadow:0 2px 8px #2563eb26}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.user-name{font-size:.875rem;color:var(--text);font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-arrow{color:var(--text-light);transition:transform .2s;flex-shrink:0}.user-dropdown.open .dropdown-arrow{transform:rotate(180deg)}.user-dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:200px;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s;z-index:1000}.user-dropdown.open .user-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:var(--text);text-decoration:none;border:none;background:none;width:100%;text-align:left;cursor:pointer;transition:background .2s;font-size:.875rem;font-weight:500}.dropdown-item:first-child{border-radius:8px 8px 0 0}.dropdown-item:last-child{border-radius:0 0 8px 8px}.dropdown-item:hover{background:var(--bg)}.dropdown-item svg{flex-shrink:0;color:var(--text-light)}.dropdown-item:hover svg{color:var(--primary)}.btn-logout{background:transparent;border:1px solid var(--border);color:var(--text);padding:.375rem .75rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-logout:hover{background:var(--bg);border-color:var(--primary);color:var(--primary)}.btn-login{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600;transition:all .2s ease;box-shadow:0 2px 4px #2563eb33}.btn-login:hover{transform:translateY(-1px);box-shadow:0 4px 8px #2563eb4d}@media (max-width: 1024px){.user-email{display:none}}.permit-warning-container{margin:20px 0;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.permit-warning{display:flex;gap:16px;padding:16px;background:linear-gradient(135deg,#e0f2fe,#f0f9ff);border:2px solid #0284c7;border-radius:12px;box-shadow:0 4px 12px #0284c726}.permit-warning-icon{font-size:32px;line-height:1;flex-shrink:0}.permit-warning-content{flex:1}.permit-warning-title{font-size:18px;font-weight:700;color:#0c4a6e;margin-bottom:8px}.permit-warning-message{font-size:14px;color:#075985;line-height:1.6}.permit-list{margin:12px 0;padding-left:20px;list-style:disc}.permit-list li{margin:6px 0;color:#0c4a6e}.permit-total{margin-top:12px;padding:10px;background:#fff;border-radius:8px;font-size:16px;color:#0c4a6e}.permit-note{margin-top:8px;font-size:13px;color:#64748b;font-style:italic}.permit-tip{margin-top:12px;padding:12px;background:#fef9e7;border-left:4px solid #f59e0b;border-radius:6px;font-size:14px;color:#92400e;line-height:1.5}
