.experience-booking-modal{background:#fff;border-radius:16px;flex-direction:column;width:90vw;max-width:900px;max-height:90vh;display:flex;position:relative;overflow:hidden}.experience-booking-modal .modal-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.experience-booking-modal .modal-header h2{color:#111827;margin:0;font-size:24px;font-weight:700}.experience-booking-modal .close-btn{cursor:pointer;color:#6b7280;background:0 0;border:none;border-radius:8px;padding:8px;transition:background-color .2s}.experience-booking-modal .close-btn:hover{background-color:#f3f4f6}.progress-steps{background:#f9fafb;border-bottom:1px solid #e5e7eb;justify-content:space-between;padding:24px;display:flex}.progress-steps .step{color:#9ca3af;flex-direction:column;flex:1;align-items:center;gap:8px;display:flex;position:relative}.progress-steps .step:after{content:"";z-index:0;background:#e5e7eb;width:100%;height:2px;position:absolute;top:16px;left:50%}.progress-steps .step:last-child:after{display:none}.progress-steps .step.active{color:#3b82f6}.progress-steps .step.completed{color:#10b981}.progress-steps .step-number{z-index:1;background:#fff;border:2px solid #e5e7eb;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:600;display:flex}.progress-steps .step.active .step-number{color:#fff;background:#3b82f6;border-color:#3b82f6}.progress-steps .step.completed .step-number{color:#fff;background:#10b981;border-color:#10b981}.progress-steps .step span{font-size:13px;font-weight:500}.experience-summary{background:#f9fafb;border-bottom:1px solid #e5e7eb;gap:16px;padding:20px 24px;display:flex}.experience-summary img{object-fit:cover;border-radius:8px;width:80px;height:80px}.experience-summary .summary-details h3{color:#111827;margin:0 0 8px;font-size:16px;font-weight:600}.experience-summary .summary-details p{color:#6b7280;margin:4px 0;font-size:14px}.experience-booking-modal .modal-content{scroll-behavior:smooth;flex:1;padding:24px;overflow-y:auto}.form-step h3{color:#111827;align-items:center;gap:8px;margin-bottom:16px;font-size:18px;font-weight:600;display:flex}.step-description{color:#6b7280;margin-bottom:20px;font-size:14px}.form-group{margin-bottom:20px}.form-group label{color:#374151;margin-bottom:6px;font-size:14px;font-weight:500;display:block}.form-group input,.form-group select{border:1px solid #d1d5db;border-radius:8px;width:100%;padding:10px 12px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus{border-color:#3b82f6;outline:none}.form-group input.error{border-color:#ef4444}.error-message{color:#ef4444;margin-top:4px;font-size:13px;display:block}.form-hint{color:#9ca3af;margin-top:4px;font-size:12px;display:block}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.travelers-section{background:#f9fafb;border-radius:8px;margin-top:24px;padding:20px}.travelers-section h4{color:#111827;align-items:center;gap:8px;margin-bottom:16px;font-size:16px;font-weight:600;display:flex}.traveler-counter{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:12px 0;display:flex}.traveler-counter:last-child{border-bottom:none}.counter-label span{color:#111827;font-size:14px;font-weight:500;display:block}.counter-label small{color:#6b7280;margin-top:2px;font-size:12px;display:block}.counter-controls{align-items:center;gap:16px;display:flex}.counter-controls button{cursor:pointer;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:50%;width:32px;height:32px;font-size:18px;font-weight:600;transition:all .2s}.counter-controls button:hover{color:#3b82f6;border-color:#3b82f6}.counter-controls span{color:#111827;text-align:center;min-width:24px;font-size:16px;font-weight:600}.payment-notice{background:#dbeafe;border-radius:8px;align-items:flex-start;gap:12px;margin-bottom:20px;padding:12px 16px;display:flex}.payment-notice p{color:#1e40af;margin:0;font-size:13px}.stripe-placeholder{text-align:center;background:#f9fafb;border:2px dashed #d1d5db;border-radius:8px;margin-bottom:24px;padding:40px}.placeholder-text{color:#6b7280;margin-bottom:8px;font-size:16px;font-weight:600}.placeholder-hint{color:#9ca3af;margin:0;font-size:13px}.agreements{border-top:1px solid #e5e7eb;margin-top:24px;padding-top:20px}.checkbox-label{cursor:pointer;align-items:flex-start;gap:10px;margin-bottom:12px;display:flex}.checkbox-label input[type=checkbox]{cursor:pointer;margin-top:2px}.checkbox-label span{color:#374151;font-size:14px}.checkbox-label a{color:#3b82f6;text-decoration:none}.checkbox-label a:hover{text-decoration:underline}.submit-error{background:#fee2e2;border-radius:8px;align-items:center;gap:12px;margin-top:16px;padding:12px 16px;display:flex}.submit-error span{color:#991b1b;font-size:14px}.price-summary{background:#f9fafb;border-top:1px solid #e5e7eb;padding:20px 24px}.price-summary h4{color:#111827;margin-bottom:16px;font-size:16px;font-weight:600}.summary-row.estimate{color:#9ca3af;font-size:13px}.summary-meta{color:#4b5563;margin:8px 0 0;font-size:13px}.availability-notice{color:#1e3a8a;background:#dbeafe;border-radius:6px;align-items:flex-start;gap:8px;margin-top:12px;padding:10px 12px;display:flex}.availability-notice.warning{color:#92400e;background:#fef3c7}.availability-notice span{font-size:13px;line-height:1.5}.cancellation-notice{background:#d1fae5;border-radius:6px;align-items:center;gap:8px;margin-top:12px;padding:10px 12px;display:flex}.cancellation-notice span{color:#065f46;font-size:13px}.product-options-panel{background:#f0f9ff;border:1px solid #bae6fd;border-radius:10px;margin-top:20px;padding:16px}.product-options-panel h4{color:#0c4a6e;margin-bottom:4px;font-size:15px;font-weight:600}.product-options-panel .step-description{color:#0369a1;margin-bottom:12px;font-size:13px}.options-list{flex-direction:column;gap:8px;display:flex}.option-card{cursor:pointer;text-align:left;background:#fff;border:2px solid #e5e7eb;border-radius:8px;align-items:center;gap:12px;padding:12px 16px;font-size:14px;transition:border-color .2s,box-shadow .2s;display:flex}.option-card:hover{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.option-card.selected{background:#f0fdf4;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.option-time{color:#111827;flex:1;font-weight:600}.option-code{color:#6b7280;background:#f3f4f6;border-radius:4px;padding:2px 8px;font-size:12px}.option-price{color:#059669;font-weight:600}.option-price small{color:#6b7280;font-weight:400}.option-selected-mark{color:#10b981;margin-left:auto;font-size:12px;font-weight:600}.selected-option-badge{color:#065f46;background:#d1fae5;border-radius:8px;align-items:center;gap:8px;margin-top:16px;padding:10px 14px;font-size:13px;font-weight:500;display:flex}.spin-icon{vertical-align:middle;margin-right:4px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.experience-booking-modal .modal-footer{background:#fff;border-top:1px solid #e5e7eb;justify-content:space-between;gap:12px;padding:16px 24px;display:flex}.btn-primary,.btn-secondary{cursor:pointer;border:none;border-radius:8px;padding:12px 24px;font-size:15px;font-weight:600;transition:all .2s}.btn-primary{color:#fff;background:#3b82f6;flex:1}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-primary:disabled{cursor:not-allowed;background:#9ca3af}.btn-secondary{color:#374151;background:#fff;border:1px solid #d1d5db}.btn-secondary:hover:not(:disabled){background:#f3f4f6}@media (width<=768px){.experience-booking-modal{border-radius:0;width:100vw;max-width:100vw;height:-webkit-fill-available;max-height:-webkit-fill-available}.form-row{grid-template-columns:1fr}.progress-steps{padding:16px}.progress-steps .step span{font-size:11px}.experience-summary{flex-direction:column}.experience-summary img{width:100%;height:150px}}.experience-confirmation-modal{background:#fff;border-radius:16px;width:90vw;max-width:700px;max-height:90vh;position:relative;overflow-y:auto}.experience-confirmation-modal .success-header{text-align:center;color:#fff;background:linear-gradient(135deg,#10b981 0%,#059669 100%);padding:40px 24px 24px;position:relative}.experience-confirmation-modal .success-icon{background:#fff3;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:16px;display:inline-flex}.experience-confirmation-modal .success-icon svg{color:#fff}.experience-confirmation-modal .success-header h2{margin:0 0 12px;font-size:28px;font-weight:700}.experience-confirmation-modal .success-message{opacity:.95;max-width:500px;margin:0 auto;font-size:15px}.experience-confirmation-modal .close-btn{cursor:pointer;color:#fff;background:#fff3;border:none;border-radius:8px;padding:8px;transition:background-color .2s;position:absolute;top:16px;right:16px}.experience-confirmation-modal .close-btn:hover{background:#ffffff4d}.booking-reference{text-align:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:24px}.reference-box{background:#fff;border:2px dashed #10b981;border-radius:12px;flex-direction:column;align-items:center;gap:8px;margin-bottom:12px;padding:16px 32px;display:inline-flex}.reference-label{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:500}.reference-number{color:#111827;font-family:Courier New,monospace;font-size:24px;font-weight:700}.confirmation-time{color:#6b7280;font-size:13px}.booking-details{padding:24px}.booking-details h3{color:#111827;margin-bottom:16px;font-size:18px;font-weight:600}.detail-card{background:#f9fafb;border-radius:12px;margin-bottom:20px;padding:20px}.detail-header{border-bottom:1px solid #e5e7eb;gap:16px;margin-bottom:20px;padding-bottom:16px;display:flex}.experience-thumb{object-fit:cover;border-radius:8px;width:80px;height:80px}.detail-header h4{color:#111827;margin:0 0 8px;font-size:16px;font-weight:600}.detail-header p{color:#6b7280;align-items:center;gap:4px;margin:0;font-size:14px;display:flex}.detail-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;display:grid}.detail-item{gap:12px;display:flex}.detail-item svg{color:#10b981;flex-shrink:0;margin-top:2px}.detail-item>div{flex-direction:column;gap:2px;display:flex}.detail-label{color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:500}.detail-value{color:#111827;font-size:14px;font-weight:600}.detail-time{color:#6b7280;font-size:13px}.traveler-info{border-radius:8px;padding:16px}.traveler-info h4{color:#111827;margin-bottom:8px;font-size:14px;font-weight:600}.traveler-info p{color:#374151;margin:4px 0;font-size:14px}.payment-summary{background:#f9fafb;border-radius:8px;margin-bottom:20px;padding:16px}.summary-row{color:#6b7280;justify-content:space-between;align-items:center;padding:8px 0;font-size:14px;display:flex}.summary-row.total{color:#111827;border-top:2px solid #e5e7eb;margin-top:8px;padding-top:12px;font-size:18px;font-weight:700}.action-buttons{gap:12px;padding:0 24px 20px;display:flex}.btn-download,.btn-email{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px 16px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.btn-download:hover,.btn-email:hover{color:#10b981;background:#f9fafb;border-color:#10b981}.primary-actions{gap:12px;padding:0 24px 24px;display:flex}.btn-add-to-planner,.btn-view-booking{cursor:pointer;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:8px;padding:14px 20px;font-size:15px;font-weight:600;transition:all .2s;display:flex}.btn-add-to-planner{color:#fff;background:#10b981}.btn-add-to-planner:hover{background:#059669}.btn-view-booking{color:#fff;background:#3b82f6}.btn-view-booking:hover{background:#2563eb}.important-notice{background:#fef3c7;border-top:1px solid #fbbf24;border-bottom:1px solid #fbbf24;padding:20px 24px}.important-notice h4{color:#92400e;margin-bottom:12px;font-size:14px;font-weight:600}.important-notice ul{margin:0;padding-left:20px}.important-notice li{color:#78350f;margin-bottom:6px;font-size:13px}.confirmation-footer{text-align:center;background:#f9fafb;padding:20px 24px}.confirmation-footer p{color:#6b7280;margin:0;font-size:13px}.confirmation-footer a{color:#3b82f6;font-weight:500;text-decoration:none}.confirmation-footer a:hover{text-decoration:underline}.manage-booking-section{border:1px solid #e5e7eb;border-radius:10px;margin:0 24px 12px;overflow:hidden}.manage-booking-section.cancel-section{border-color:#fecaca}.manage-section-toggle{cursor:pointer;color:#374151;text-align:left;background:#f9fafb;border:none;align-items:center;gap:8px;width:100%;padding:14px 16px;font-size:14px;font-weight:600;transition:background-color .2s;display:flex}.manage-section-toggle:hover{background:#f3f4f6}.manage-section-toggle.danger{color:#b91c1c;background:#fff5f5}.manage-section-toggle.danger:hover{background:#fee2e2}.manage-section-toggle span{flex:1}.manage-section-body{background:#fff;border-top:1px solid #e5e7eb;padding:16px}.amendment-body p{color:#374151;margin-bottom:12px;font-size:14px;line-height:1.6}.amendment-actions{gap:8px;display:flex}.btn-amend-email{color:#fff;background:#3b82f6;border-radius:8px;align-items:center;gap:6px;padding:10px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:background-color .2s;display:inline-flex}.btn-amend-email:hover{background:#2563eb}.cancel-loading{color:#6b7280;align-items:center;gap:10px;font-size:14px;display:flex}.cancel-error{color:#b91c1c;background:#fee2e2;border-radius:8px;align-items:flex-start;gap:8px;padding:10px 12px;font-size:14px;display:flex}.cancel-quote h4{color:#111827;margin-bottom:12px;font-size:15px;font-weight:600}.quote-row{color:#374151;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;margin-bottom:10px;padding:10px 0;font-size:15px;display:flex}.quote-row strong{color:#10b981;font-size:18px}.cancel-policy-note{color:#6b7280;margin-bottom:10px;font-size:13px;line-height:1.5}.cancel-warning{color:#b91c1c;margin-bottom:14px;font-size:13px;font-weight:500}.cancel-actions{flex-wrap:wrap;gap:10px;display:flex}.btn-cancel-confirm{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:8px;align-items:center;gap:6px;padding:10px 18px;font-size:14px;font-weight:600;transition:background-color .2s;display:inline-flex}.btn-cancel-confirm:hover:not(:disabled){background:#b91c1c}.btn-cancel-confirm:disabled{opacity:.7;cursor:not-allowed}.btn-cancel-abort{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:10px 18px;font-size:14px;font-weight:500;transition:background-color .2s}.btn-cancel-abort:hover{background:#f3f4f6}.cancel-success-banner{color:#065f46;background:#d1fae5;border-radius:10px;align-items:center;gap:10px;margin:0 24px 16px;padding:14px 16px;font-size:14px;font-weight:500;display:flex}.spin-icon{vertical-align:middle;animation:.8s linear infinite spin;display:inline-block}@media (width<=768px){.experience-confirmation-modal{border-radius:0;width:100vw;max-width:100vw;height:-webkit-fill-available;max-height:-webkit-fill-available}.detail-grid{grid-template-columns:1fr}.action-buttons,.primary-actions{flex-direction:column}.btn-download,.btn-email,.btn-add-to-planner,.btn-view-booking{width:100%}}.error-modal{background:#fff;border-radius:16px;width:90vw;max-width:600px;max-height:90vh;position:relative;overflow-y:auto}.error-modal .error-header{text-align:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:40px 24px 24px;position:relative}.error-modal .error-icon{background:#ef44441a;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:16px;display:inline-flex}.error-modal .error-header h2{color:#111827;margin:0 0 12px;font-size:24px;font-weight:700}.error-modal .error-message{color:#6b7280;max-width:500px;margin:0 auto;font-size:15px;line-height:1.5}.error-modal .close-btn{cursor:pointer;color:#6b7280;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:8px;transition:all .2s;position:absolute;top:16px;right:16px}.error-modal .close-btn:hover{color:#111827;background:#f9fafb;border-color:#d1d5db}.error-details{background:#fef2f2;border-bottom:1px solid #fecaca;padding:20px 24px}.details-label{color:#991b1b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:12px;font-weight:600}.details-text{color:#7f1d1d;background:#fff;border:1px solid #fecaca;border-radius:6px;margin:0;padding:12px;font-family:Courier New,monospace;font-size:14px}.error-suggestions{padding:24px}.error-suggestions h3{color:#111827;margin-bottom:16px;font-size:16px;font-weight:600}.error-suggestions ul{margin:0;padding-left:20px}.error-suggestions li{color:#374151;margin-bottom:10px;font-size:14px;line-height:1.5}.error-suggestions li:last-child{margin-bottom:0}.error-actions{gap:12px;padding:0 24px 24px;display:flex}.error-actions button{cursor:pointer;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px 20px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.btn-retry{color:#fff;background:#3b82f6}.btn-retry:hover{background:#2563eb}.btn-support{color:#fff;background:#10b981}.btn-support:hover{background:#059669}.btn-close{color:#374151;background:#fff;border:1px solid #d1d5db}.btn-close:hover{background:#f9fafb;border-color:#9ca3af}.error-reference{text-align:center;background:#f9fafb;border-top:1px solid #e5e7eb;padding:20px 24px}.error-reference p{color:#6b7280;margin:0 0 4px;font-size:13px}.error-reference code{color:#111827;background:#fff;border:1px solid #e5e7eb;border-radius:4px;padding:4px 8px;font-family:Courier New,monospace;font-weight:600}.reference-hint{color:#9ca3af;margin-top:4px;font-size:12px}@media (width<=768px){.error-modal{border-radius:0;width:100vw;max-width:100vw;height:-webkit-fill-available;max-height:-webkit-fill-available}.error-actions{flex-direction:column}.error-actions button{width:100%}}
