@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body{height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}#root{height:100%}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow-x:hidden}.app-nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;justify-content:space-between;align-items:center;padding:0 24px;height:56px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.06)}.nav-left{display:flex;align-items:center;gap:24px}.nav-logo{font-size:1.2rem;font-weight:700;color:#667eea;text-decoration:none}.nav-link{font-size:.9rem;font-weight:500;color:#4a5568;text-decoration:none;padding:6px 12px;border-radius:6px;transition:color .2s,background .2s}.nav-link:hover{color:#667eea;background:#f0f0ff}.nav-link.active{color:#667eea;background:#ebf4ff}.nav-right{display:flex;align-items:center;gap:16px}.nav-user{font-size:.85rem;color:#718096}.nav-signout{font-size:.85rem;font-weight:500;color:#667eea;background:none;border:1px solid #667eea;padding:5px 14px;border-radius:6px;cursor:pointer;transition:background .2s,color .2s}.nav-signout:hover{background:#667eea;color:#fff}.nav-signin-btn{font-size:.85rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;padding:6px 16px;border-radius:6px;cursor:pointer;transition:opacity .2s}.nav-signin-btn:hover{opacity:.9}.app-content{padding-top:56px}.dev-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.dev-login-card{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:400px;box-shadow:0 20px 60px #00000026}.dev-login-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.dev-login-logo{font-size:1.5rem;font-weight:700;color:#667eea}.dev-login-badge{font-size:.7rem;font-weight:600;color:#764ba2;background:#f0e6ff;padding:4px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}.dev-login-form{display:flex;flex-direction:column;gap:20px}.dev-login-field{display:flex;flex-direction:column;gap:6px}.dev-login-label{font-size:.8rem;font-weight:600;color:#4a5568;text-transform:uppercase;letter-spacing:.5px}.dev-login-input{padding:12px 14px;border:1px solid #e2e8f0;border-radius:8px;font-size:.95rem;color:#1a202c;background:#f7fafc;transition:border-color .2s,box-shadow .2s}.dev-login-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.dev-login-error{font-size:.85rem;color:#e53e3e;background:#fff5f5;padding:10px 14px;border-radius:8px}.dev-login-btn{padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s}.dev-login-btn:hover{opacity:.9}.dev-login-hint{margin-top:20px;text-align:center;font-size:.8rem;color:#a0aec0}.dev-login-hint strong{color:#718096}.dev-login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.dev-login-overlay .dev-login-card{position:relative}.dev-login-close{position:absolute;top:12px;right:16px;background:none;border:none;font-size:1.5rem;color:#a0aec0;cursor:pointer;line-height:1}.dev-login-close:hover{color:#4a5568}.price-signin{display:flex;flex-direction:column;align-items:center;gap:8px}.price-signin-text{font-size:.8rem;color:#718096;text-align:center}.price-signin-btn{padding:8px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .2s}.price-signin-btn:hover{opacity:.9}.typeahead{position:relative}.typeahead input{width:100%;padding:10px 12px;border:2px solid #e2e8f0;border-radius:8px;font-size:.95rem;color:#333;background:#f8fafc;transition:border-color .2s}.typeahead input:focus{outline:none;border-color:#667eea;background:#fff}.typeahead-dropdown{position:absolute;top:100%;left:0;right:0;margin:4px 0 0;padding:4px 0;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 8px 24px #0000001f;list-style:none;max-height:260px;overflow-y:auto;z-index:100}.typeahead-option{padding:10px 14px;cursor:pointer;display:flex;justify-content:space-between;align-items:baseline;gap:8px}.typeahead-option-active{background:#f0f4ff}.typeahead-name{font-size:.95rem;font-weight:500;color:#1a202c}.typeahead-detail{font-size:.8rem;color:#718096;white-space:nowrap}.typeahead-no-results{position:absolute;top:100%;left:0;right:0;margin:4px 0 0;padding:10px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 8px 24px #0000001f;font-size:.9rem;color:#a0aec0;z-index:100}.landing-page{min-height:100vh;background:#f5f7fa}.landing-hero{background:linear-gradient(135deg,#667eea,#764ba2);padding:80px 20px 60px;text-align:center;color:#fff}.test-banner{display:inline-block;background:#f6ad55;color:#744210;font-weight:700;font-size:.95rem;padding:10px 28px;border-radius:8px;margin-bottom:20px;letter-spacing:.3px}.landing-hero h1{font-size:2.8rem;font-weight:700;margin-bottom:10px}.landing-hero>p{font-size:1.1rem;opacity:.85;margin-bottom:36px}.value-props{max-width:1100px;margin:0 auto;padding:60px 20px;text-align:center}.value-props h2{font-size:1.8rem;font-weight:700;color:#1a202c;margin-bottom:36px}.value-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.value-card{background:#fff;border-radius:12px;padding:32px 24px;box-shadow:0 2px 8px #0000000f;transition:transform .2s,box-shadow .2s}.value-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0000001a}.value-icon{font-size:2.2rem;margin-bottom:14px}.value-card h3{font-size:1.15rem;font-weight:600;color:#1a202c;margin-bottom:8px}.value-card p{font-size:.95rem;color:#718096;line-height:1.6}.popular-destinations{max-width:1100px;margin:0 auto;padding:0 20px 60px;text-align:center}.popular-destinations h2{font-size:1.8rem;font-weight:700;color:#1a202c;margin-bottom:36px}.dest-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}.dest-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:28px 16px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;transition:border-color .2s,transform .2s,box-shadow .2s}.dest-card:hover{border-color:#667eea;transform:translateY(-3px);box-shadow:0 8px 24px #667eea26}.dest-name{font-size:1.1rem;font-weight:600;color:#1a202c}.dest-tagline{font-size:.8rem;color:#718096}.landing-footer{text-align:center;padding:30px 20px;border-top:1px solid #e2e8f0;background:#fff}.landing-footer p{font-size:.8rem;color:#a0aec0;margin-bottom:4px}@media (max-width: 768px){.landing-hero{padding:50px 15px 40px}.landing-hero h1{font-size:2rem}.value-props,.popular-destinations{padding-left:15px;padding-right:15px}.dest-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}}.gallery-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;z-index:1000;display:flex;align-items:center;justify-content:center}.gallery-header{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:16px 24px;color:#fff;z-index:1002}.gallery-hotel-name{font-size:1rem;font-weight:600;opacity:.9}.gallery-counter{font-size:.9rem;opacity:.7}.gallery-close{background:none;border:none;color:#fff;font-size:1.8rem;cursor:pointer;padding:4px 8px;line-height:1;opacity:.8;transition:opacity .2s}.gallery-close:hover{opacity:1}.gallery-main{display:flex;align-items:center;justify-content:center;width:100%;height:100%;padding:70px 80px}.gallery-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px;-webkit-user-select:none;user-select:none}.gallery-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff26;border:none;color:#fff;font-size:2rem;width:48px;height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:1001}.gallery-nav:hover{background:#ffffff4d}.gallery-prev{left:20px}.gallery-next{right:20px}@media (max-width: 768px){.gallery-main{padding:60px 16px}.gallery-nav{width:40px;height:40px;font-size:1.5rem}.gallery-prev{left:8px}.gallery-next{right:8px}.gallery-header{padding:12px 16px}}.hotel-search{min-height:100vh;background:#f5f7fa}.search-hero{background:linear-gradient(135deg,#667eea,#764ba2);padding:50px 20px 40px;text-align:center;color:#fff}.search-hero h1{font-size:2.2rem;font-weight:700;margin-bottom:8px}.search-hero>p{font-size:1rem;opacity:.85;margin-bottom:30px}.search-form{max-width:1100px;margin:0 auto;background:#fff;border-radius:16px;padding:24px;box-shadow:0 20px 60px #00000026}.form-row{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}.form-group{flex:1;min-width:150px;text-align:left}.form-group-small{flex:0 0 80px;min-width:80px}.form-group label{display:block;font-size:.75rem;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.form-group input,.form-group select{width:100%;padding:10px 12px;border:2px solid #e2e8f0;border-radius:8px;font-size:.95rem;color:#333;background:#f8fafc;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;background:#fff}.search-btn{padding:12px 28px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:transform .2s,box-shadow .2s;min-width:150px}.search-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #667eea66}.children-ages-row{display:flex;gap:12px;margin-top:12px;flex-wrap:wrap}.child-age-group{text-align:left}.child-age-group label{display:block;font-size:.75rem;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.child-age-group select{padding:10px 12px;border:2px solid #e2e8f0;border-radius:8px;font-size:.95rem;color:#333;background:#f8fafc;min-width:80px}.search-btn:disabled{opacity:.7;cursor:not-allowed}.results-section{max-width:1100px;margin:0 auto;padding:30px 20px}.results-header{display:flex;align-items:baseline;gap:16px;margin-bottom:24px;flex-wrap:wrap}.results-header h2{font-size:1.4rem;font-weight:700;color:#1a202c}.results-meta{font-size:.9rem;color:#718096}.filters-bar{display:flex;align-items:flex-start;gap:20px;flex-wrap:wrap;background:#fff;border-radius:10px;padding:14px 18px;margin-bottom:20px;box-shadow:0 1px 4px #0000000f}.filter-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.filter-label{font-size:.75rem;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.filter-options{display:flex;gap:6px;flex-wrap:wrap}.filter-chip{display:flex;align-items:center;gap:4px;font-size:.8rem;color:#4a5568;background:#f7fafc;border:1px solid #e2e8f0;border-radius:16px;padding:4px 10px;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s}.filter-chip:hover{background:#edf2f7}.filter-chip input{display:none}.filter-chip:has(input:checked){background:#667eea;color:#fff;border-color:#667eea}.sort-select{padding:5px 10px;border:1px solid #e2e8f0;border-radius:16px;font-size:.8rem;color:#4a5568;background:#f7fafc;cursor:pointer;outline:none;transition:border-color .15s}.sort-select:hover{background:#edf2f7}.sort-select:focus{border-color:#667eea}.filter-price-input{width:100px;padding:6px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem;color:#333}.filter-clear{font-size:.8rem;color:#667eea;background:none;border:none;cursor:pointer;padding:4px 8px;white-space:nowrap}.filter-clear:hover{text-decoration:underline}.loading-state,.empty-state,.error-state{text-align:center;padding:60px 20px}.spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}.loading-state p{color:#718096;font-size:1rem}.error-state p{color:#e53e3e;font-size:1rem}.empty-state p{color:#718096;font-size:1rem}.hotel-grid{display:flex;flex-direction:column;gap:16px}.hotel-card{background:#fff;border-radius:12px;overflow:hidden;display:flex;box-shadow:0 2px 8px #0000000f;transition:box-shadow .2s,transform .2s}.hotel-card:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-2px)}.hotel-card-image{width:200px;min-height:160px;background:linear-gradient(135deg,#a8c0ff,#d4a5ff);flex-shrink:0;display:flex;align-items:flex-end;justify-content:flex-start;padding:12px;position:relative}.hotel-card-image-clickable{cursor:pointer}.hotel-card-image-clickable:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#0000;transition:background .2s}.hotel-card-image-clickable:hover:after{background:#00000026}.hotel-category{background:#0000008c;color:#fff;font-size:.7rem;font-weight:600;padding:4px 8px;border-radius:4px;text-transform:uppercase;position:relative;z-index:1}.photo-count-badge{position:absolute;top:10px;right:10px;background:#0009;color:#fff;font-size:.7rem;font-weight:600;padding:3px 8px;border-radius:4px;z-index:1}.hotel-card-body{flex:1;padding:16px 20px;display:flex;justify-content:space-between;gap:16px}.hotel-card-info{flex:1}.hotel-name{font-size:1.1rem;font-weight:600;color:#1a202c;margin-bottom:4px;line-height:1.3}.hotel-stars{color:#ecc94b;font-size:.9rem;letter-spacing:1px;margin-bottom:6px}.hotel-location{font-size:.85rem;color:#718096;margin-bottom:4px}.hotel-room-type{font-size:.8rem;color:#4a5568;margin-bottom:8px}.hotel-board{display:inline-block;font-size:.7rem;font-weight:600;color:#667eea;background:#ebf4ff;padding:3px 8px;border-radius:4px;margin-right:6px}.hotel-cancellation{display:inline-block;font-size:.7rem;font-weight:600;color:#38a169;background:#f0fff4;padding:3px 8px;border-radius:4px}.hotel-offer,.hotel-promotion{display:inline-block;font-size:.7rem;font-weight:600;color:#d69e2e;background:#fefcbf;padding:3px 8px;border-radius:4px;margin-right:6px;margin-top:4px}.hotel-description{font-size:.8rem;color:#718096;margin-top:6px;line-height:1.4}.hotel-facilities{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.facility-tag{font-size:.7rem;color:#4a5568;background:#edf2f7;padding:2px 8px;border-radius:10px}.hotel-card-price{display:flex;flex-direction:column;align-items:flex-end;justify-content:center;min-width:100px;text-align:right}.price-label{font-size:.75rem;color:#a0aec0;margin-bottom:4px}.price-amount{font-size:1.6rem;font-weight:700;color:#1a202c;line-height:1;margin-bottom:4px}.price-per-night{font-size:.75rem;color:#718096}.book-btn{margin-top:8px;padding:8px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.book-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.book-btn-signin{background:linear-gradient(135deg,#a0aec0,#718096)}.book-btn-signin:hover{box-shadow:0 4px 12px #71809666}@media (max-width: 768px){.search-hero{padding:30px 15px 25px}.search-hero h1{font-size:1.6rem}.form-row{flex-direction:column}.form-group,.form-group-small{flex:1 1 100%;min-width:100%}.search-btn{width:100%}.hotel-card{flex-direction:column}.hotel-card-image{width:100%;min-height:120px}.hotel-card-body{flex-direction:column}.hotel-card-price{flex-direction:row;align-items:baseline;gap:8px;min-width:auto}}.load-more-container{text-align:center;padding:30px 0}.load-more-btn{padding:12px 36px;background:#fff;color:#667eea;border:2px solid #667eea;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.load-more-btn:hover:not(:disabled){background:#667eea;color:#fff}.load-more-btn:disabled{opacity:.6;cursor:not-allowed}.checkout-page{min-height:100vh;background:#f5f7fa}.checkout-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:36px 20px 28px;text-align:center;color:#fff}.checkout-header h1{font-size:1.8rem;font-weight:700;margin-bottom:16px}.step-indicator{display:flex;align-items:center;justify-content:center;gap:8px}.step-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600;background:#fff3;color:#fff9}.step-dot.active{background:#fff;color:#667eea}.step-dot.done{background:#ffffff80;color:#fff}.step-line{width:40px;height:2px;background:#ffffff4d}.checkout-body{max-width:1100px;margin:0 auto;padding:30px 20px;display:flex;gap:24px}.checkout-main{flex:2;min-width:0}.checkout-sidebar{flex:1;min-width:280px}.verify-loading{text-align:center;padding:60px 20px}.verify-loading .spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}.verify-loading p{color:#718096}.price-alert{background:ivory;border:1px solid #ecc94b;color:#744210;padding:12px 16px;border-radius:8px;font-size:.9rem;margin-bottom:24px}.guest-form{background:#fff;border-radius:12px;padding:28px;box-shadow:0 2px 8px #0000000f}.form-section-title{font-size:1.1rem;font-weight:600;color:#1a202c;margin-bottom:16px}.guest-heading{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.9rem;font-weight:500;color:#4a5568}.same-as-holder{display:flex;align-items:center;gap:6px;font-size:.8rem;color:#718096;cursor:pointer}.same-as-holder input{cursor:pointer}.guest-row{display:flex;gap:12px;margin-bottom:16px}.guest-field{flex:1}.guest-label{display:block;font-size:.75rem;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.guest-input{width:100%;padding:10px 12px;border:2px solid #e2e8f0;border-radius:8px;font-size:.95rem;color:#333;background:#f8fafc;transition:border-color .2s}.guest-input:focus{outline:none;border-color:#667eea;background:#fff}.guest-input:disabled{background:#edf2f7;color:#718096}.room-guest-section{padding-top:16px;margin-top:16px;border-top:2px solid #e2e8f0}.room-guest-section:first-of-type{border-top:none;margin-top:0;padding-top:0}.continue-btn{margin-top:12px;width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.continue-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #667eea66}.continue-btn:disabled{opacity:.5;cursor:not-allowed}.review-section{background:#fff;border-radius:12px;padding:28px;box-shadow:0 2px 8px #0000000f}.review-card{margin-bottom:24px}.review-row{display:flex;justify-content:space-between;padding:8px 0}.review-label{font-size:.85rem;color:#718096}.review-value{font-size:.85rem;font-weight:500;color:#1a202c;text-align:right;max-width:60%}.review-divider{height:1px;background:#e2e8f0;margin:12px 0}.review-total{font-size:1.1rem!important}.review-total .review-label{font-size:1rem;font-weight:600;color:#1a202c}.review-total .review-value{font-size:1.3rem;font-weight:700;color:#1a202c}.review-cancellation{background:#f0fff4;border-radius:6px;padding:10px 14px;margin-top:12px;font-size:.8rem;color:#38a169}.review-rate-comments{background:#fffbeb;border-radius:6px;padding:10px 14px;margin-top:12px;font-size:.8rem;color:#92400e;line-height:1.5}.rate-comments-label{font-weight:600;margin-bottom:4px}.review-actions{display:flex;gap:12px}.back-btn{flex:1;padding:14px;background:#fff;color:#4a5568;border:2px solid #e2e8f0;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:border-color .2s}.back-btn:hover{border-color:#667eea;color:#667eea}.confirm-btn{flex:2;padding:14px;background:linear-gradient(135deg,#38a169,#2b6cb0);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.confirm-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #38a16966}.booking-overlay{text-align:center;padding:80px 20px}.booking-overlay .spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 20px}.booking-overlay p{color:#4a5568;font-size:1.1rem;font-weight:500}.booking-note{color:#a0aec0!important;font-size:.85rem!important;font-weight:400!important;margin-top:4px}.checkout-error{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f}.checkout-error h2{font-size:1.3rem;color:#1a202c;margin-bottom:8px}.checkout-error p{color:#e53e3e;margin-bottom:24px}.error-actions{display:flex;gap:12px;justify-content:center}.error-actions .back-btn,.error-actions .continue-btn{flex:0;min-width:150px}.booking-summary{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000000f;position:sticky;top:80px}.summary-image{height:100px;background:linear-gradient(135deg,#a8c0ff,#d4a5ff);border-radius:8px;display:flex;align-items:flex-end;padding:8px;margin-bottom:12px}.summary-hotel-name{font-size:1rem;font-weight:600;color:#1a202c;margin-bottom:4px}.summary-stars{color:#ecc94b;font-size:.85rem;margin-bottom:4px}.summary-location{font-size:.8rem;color:#718096}.summary-divider{height:1px;background:#e2e8f0;margin:12px 0}.summary-detail{display:flex;justify-content:space-between;font-size:.8rem;padding:3px 0}.summary-detail span:first-child{color:#718096}.summary-detail span:last-child{color:#1a202c;font-weight:500}.summary-total{display:flex;justify-content:space-between;font-size:1.1rem;font-weight:700;color:#1a202c}@media (max-width: 768px){.checkout-body{flex-direction:column}.checkout-sidebar{order:-1;min-width:auto}.booking-summary{position:static}.guest-row{flex-direction:column;gap:8px}.review-actions{flex-direction:column}}.promo-section{padding:12px 0}.promo-input-row{display:flex;gap:8px;align-items:center}.promo-input{flex:1;padding:8px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem;text-transform:uppercase}.promo-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.promo-apply-btn{padding:8px 18px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap}.promo-apply-btn:disabled{opacity:.5;cursor:not-allowed}.promo-applied{display:flex;align-items:center;gap:12px}.promo-badge{background:#f0fff4;color:#38a169;font-weight:600;font-size:.85rem;padding:6px 14px;border-radius:20px}.promo-remove-btn{background:none;border:none;color:#e53e3e;font-size:.8rem;cursor:pointer;text-decoration:underline}.promo-error{color:#e53e3e;font-size:.8rem;margin-top:6px}.price-struck{text-decoration:line-through;color:#a0aec0;font-size:.9em}.summary-promo{text-align:center;font-size:.8rem;color:#38a169;font-weight:600;margin-top:4px}.voucher-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;overflow-y:auto;display:flex;justify-content:center;padding:20px}.voucher-container{max-width:800px;width:100%}.voucher-actions{display:flex;gap:12px;justify-content:flex-end;margin-bottom:12px}.voucher-print-btn{padding:10px 24px;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer}.voucher-close-btn{padding:10px 24px;background:#fff;color:#4a5568;border:1px solid #e2e8f0;border-radius:6px;font-size:.95rem;cursor:pointer}.voucher-page{background:#fff;border-radius:8px;padding:40px;box-shadow:0 4px 20px #00000026}.voucher-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:20px;border-bottom:2px solid #1a202c;margin-bottom:24px}.voucher-brand h1{font-size:1.6rem;font-weight:700;color:#667eea;margin:0}.voucher-brand p{font-size:.85rem;color:#718096;margin:2px 0 0}.voucher-title{text-align:right}.voucher-title h2{font-size:1.3rem;font-weight:700;color:#1a202c;margin:0;letter-spacing:1px}.voucher-status{font-size:.85rem;font-weight:600;color:#38a169;margin:4px 0 0}.voucher-refs{display:flex;gap:24px;flex-wrap:wrap;margin-bottom:28px;padding:14px 18px;background:#f7fafc;border-radius:6px}.voucher-ref-item{display:flex;flex-direction:column}.voucher-ref-label{font-size:.7rem;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px}.voucher-ref-value{font-size:1rem;font-weight:600;color:#1a202c}.voucher-section{margin-bottom:24px}.voucher-section h3{font-size:1rem;font-weight:600;color:#1a202c;margin:0 0 10px;padding-bottom:6px;border-bottom:1px solid #e2e8f0}.voucher-table{width:100%;border-collapse:collapse}.voucher-table td{padding:6px 0;font-size:.9rem;color:#1a202c;vertical-align:top}.vtd-label{width:160px;font-weight:500;color:#718096}.voucher-total{font-size:1.2rem;font-weight:700}.voucher-comments{margin-top:12px;padding:10px 14px;background:#fffbeb;border-radius:6px;font-size:.85rem;color:#92400e;line-height:1.5}.voucher-comments strong{display:block;margin-bottom:4px}.voucher-footer{margin-top:32px;padding-top:16px;border-top:1px solid #e2e8f0;text-align:center;font-size:.8rem;color:#a0aec0}.voucher-footer p{margin:2px 0}@media print{.no-print{display:none!important}.voucher-overlay{position:static;background:none;padding:0}.voucher-page{box-shadow:none;border-radius:0;padding:20px}body *{visibility:hidden}.voucher-overlay,.voucher-overlay *{visibility:visible}.voucher-overlay{position:absolute;left:0;top:0;width:100%}}.confirmation-page{min-height:100vh;background:#f5f7fa}.confirmation-header{background:linear-gradient(135deg,#38a169,#2b6cb0);padding:50px 20px 40px;text-align:center;color:#fff}.conf-check{width:56px;height:56px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:1.8rem}.confirmation-header h1{font-size:2rem;font-weight:700;margin-bottom:8px}.conf-reference{font-size:1rem;opacity:.9}.conf-reference strong{font-weight:700;letter-spacing:.5px}.confirmation-body{max-width:650px;margin:-20px auto 0;padding:0 20px 40px;position:relative;z-index:1}.confirmation-card{background:#fff;border-radius:12px;padding:28px;box-shadow:0 4px 16px #00000014;margin-bottom:16px}.conf-card-title{font-size:1rem;font-weight:700;color:#1a202c;margin-bottom:16px}.conf-card-subtitle{font-size:.85rem;font-weight:600;color:#4a5568;margin-bottom:8px}.conf-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.conf-label{font-size:.85rem;color:#718096}.conf-value{font-size:.85rem;font-weight:500;color:#1a202c;text-align:right;max-width:60%}.conf-stars{color:#d69e2e;font-size:1rem;letter-spacing:2px}.conf-status{font-size:.8rem;font-weight:600;padding:4px 12px;border-radius:20px}.status-pending{background:ivory;color:#d69e2e}.confirmation-header.cancelled{background:linear-gradient(135deg,#718096,#4a5568)}.conf-divider{height:1px;background:#e2e8f0;margin:12px 0}.conf-cancellation-item{font-size:.82rem;color:#4a5568;padding:4px 0}.conf-modification-note{font-size:.78rem;color:#718096;margin-top:6px}.conf-rate-comments{font-size:.82rem;color:#4a5568;line-height:1.5;background:#f7fafc;border-radius:8px;padding:12px;border-left:3px solid #667eea}.conf-total .conf-label{font-size:1rem;font-weight:600;color:#1a202c}.conf-total .conf-value{font-size:1.4rem;font-weight:700}.confirmation-actions{display:flex;gap:12px;justify-content:center;margin-top:8px}.conf-link-btn{padding:12px 28px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;border-radius:8px;font-size:.95rem;font-weight:600;transition:transform .2s,box-shadow .2s}.conf-link-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #667eea66}.conf-link-secondary{background:#fff;color:#4a5568;border:2px solid #e2e8f0}.conf-link-secondary:hover{border-color:#667eea;color:#667eea;box-shadow:none}.conf-voucher-section{text-align:center}.conf-voucher-btn{padding:12px 32px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.conf-voucher-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #667eea66}.conf-cancel-section{text-align:center}.conf-cancel-btn{padding:10px 28px;background:#fff;color:#e53e3e;border:2px solid #e53e3e;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s,color .2s}.conf-cancel-btn:hover{background:#e53e3e;color:#fff}.conf-cancel-confirm{border:2px solid #fed7d7}.conf-cancel-warning{font-size:.85rem;color:#718096;margin-bottom:16px}.conf-cancel-error{font-size:.85rem;color:#e53e3e;margin-bottom:12px}.conf-cancel-actions{display:flex;gap:12px;justify-content:center}.conf-cancel-back{padding:10px 24px;background:#fff;color:#4a5568;border:2px solid #e2e8f0;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer}.conf-cancel-back:hover{border-color:#667eea;color:#667eea}.conf-cancel-confirm-btn{padding:10px 24px;background:#e53e3e;color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s}.conf-cancel-confirm-btn:hover{background:#c53030}.conf-cancel-confirm-btn:disabled,.conf-cancel-back:disabled{opacity:.6;cursor:not-allowed}.conf-financial{border-left:4px solid #2d3748}.conf-financial .conf-card-title{color:#2d3748}.conf-margin{color:#38a169;font-weight:600}.conf-payment-badge{font-size:.75rem;font-weight:600;padding:3px 10px;border-radius:20px}.conf-pt-atweb{background:#ebf8ff;color:#2b6cb0}.conf-pt-athotel{background:#fefcbf;color:#975a16}.conf-pt-both{background:#e9d8fd;color:#6b46c1}.conf-daily-rates .conf-row{padding:3px 0}.conf-daily-rates .conf-label,.conf-daily-rates .conf-value{font-size:.8rem}.conf-promo-code{font-family:monospace;background:#f0fff4;padding:2px 8px;border-radius:4px;color:#38a169;font-weight:600}.confirmation-loading,.confirmation-error{text-align:center;padding:80px 20px}.confirmation-loading .spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}.confirmation-error h2{color:#1a202c;margin-bottom:8px}.confirmation-error p{color:#e53e3e;margin-bottom:24px}@media (max-width: 768px){.confirmation-actions{flex-direction:column}.conf-link-btn{text-align:center}}.bookings-page{min-height:100vh;background:#f5f7fa}.bookings-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:40px 20px 30px;text-align:center;color:#fff}.bookings-header h1{font-size:1.8rem;font-weight:700}.bookings-body{max-width:800px;margin:0 auto;padding:24px 20px 40px}.bookings-search{display:flex;gap:10px;align-items:center;background:#fff;border-radius:12px;padding:16px 20px;box-shadow:0 2px 8px #0000000f;margin-bottom:16px}.search-input{flex:1;padding:10px 14px;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;color:#1a202c;background:#f7fafc}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.search-input::placeholder{color:#a0aec0}.search-clear-btn{padding:8px 16px;background:#e2e8f0;color:#4a5568;border:none;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer}.search-clear-btn:hover{background:#cbd5e0}.search-results-section{margin-bottom:20px}.bookings-filters{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000000f;margin-bottom:20px}.filter-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:120px}.filter-label{font-size:.75rem;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px}.filter-input{padding:8px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem;color:#1a202c;background:#f7fafc}.filter-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.filter-btn{padding:8px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap}.filter-btn:hover{opacity:.9}.bookings-count{font-size:.85rem;color:#718096;margin-bottom:12px}.bookings-list{display:flex;flex-direction:column;gap:12px}.booking-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000000f;text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s;display:block}.booking-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.booking-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.booking-hotel-name{font-size:1rem;font-weight:600;color:#1a202c}.booking-status{font-size:.75rem;font-weight:600;padding:4px 10px;border-radius:20px}.status-confirmed{background:#f0fff4;color:#38a169}.status-cancelled,.status-error{background:#fff5f5;color:#e53e3e}.booking-card-details{display:grid;grid-template-columns:1fr 1fr;gap:8px 20px}.booking-detail{display:flex;justify-content:space-between;align-items:center}.booking-detail-label{font-size:.8rem;color:#718096}.booking-detail-value{font-size:.8rem;font-weight:500;color:#2d3748;text-align:right}.booking-card-bottom{margin-top:14px;padding-top:12px;border-top:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.booking-promo-badge{background:#f0fff4;color:#38a169;font-weight:600;font-size:.75rem;padding:3px 10px;border-radius:20px}.booking-card-total{text-align:right;font-size:1.2rem;font-weight:700;color:#1a202c;margin-left:auto}.bookings-loading,.bookings-empty,.bookings-error{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f}.bookings-loading .spinner{width:36px;height:36px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 12px}@keyframes spin{to{transform:rotate(360deg)}}.bookings-loading p,.bookings-empty p{color:#718096;font-size:.9rem}.bookings-error p{color:#e53e3e;font-size:.9rem;margin-bottom:16px}.bookings-search-btn{display:inline-block;margin-top:16px;padding:10px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;border-radius:8px;font-weight:600;font-size:.9rem}@media (max-width: 640px){.bookings-filters{flex-direction:column}.filter-group{width:100%}.booking-card-details{grid-template-columns:1fr}}
