:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.hotel-selector-container{position:relative;margin-bottom:0}.hotel-selector-container label{font-weight:500;color:#333;font-size:.9rem;margin-bottom:.5rem;display:block}.loading-spinner{position:absolute;right:1rem;top:50%;transform:translateY(-50%)}.spinner{width:20px;height:20px;border:2px solid #f3f3f3;border-top:2px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.error-message{background:#fee;color:#c53030;padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;border:1px solid #feb2b2;font-size:.9rem}.suggestions-container{position:absolute;top:100%;left:0;width:600px;max-width:calc(100vw - 4rem);background:#fff;border:1px solid #e1e5e9;border-radius:8px;box-shadow:0 4px 20px #00000026;max-height:300px;overflow-y:auto;z-index:1000;margin-top:4px}.suggestion-item{padding:1rem 1.5rem;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid #f5f5f5}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover,.suggestion-item.selected{background-color:#f7fafc}.hotel-name{font-weight:600;color:#333;margin-bottom:.25rem}.hotel-location{font-size:.9rem;color:#666}.no-results{padding:1rem 1.5rem;color:#666;font-style:italic;text-align:center}.suggestions-container::-webkit-scrollbar{width:6px}.suggestions-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.suggestions-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.suggestions-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media(max-width:1000px){.suggestion-item{padding:.875rem 1.25rem}}.chosen-hotel-container{width:100%}.chosen-hotel-box{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border:2px solid #667eea;border-radius:6px;background:linear-gradient(135deg,#f8faff,#f0f4ff);box-shadow:0 2px 8px #667eea1a;transition:all .3s ease}.chosen-hotel-box:hover{box-shadow:0 4px 12px #667eea26;transform:translateY(-1px)}.chosen-hotel-content{flex:1;min-width:0}.chosen-hotel-name{font-weight:600;color:#2d3748;font-size:1rem;margin-bottom:.25rem;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.chosen-hotel-location{font-size:.875rem;color:#667eea;font-weight:500;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.chosen-hotel-edit-button{background:none;border:none;cursor:pointer;padding:.5rem;border-radius:4px;font-size:1.2rem;transition:all .2s ease;margin-left:.75rem;flex-shrink:0}.chosen-hotel-edit-button:hover{background:#667eea1a;transform:scale(1.1)}.chosen-hotel-edit-button:active{transform:scale(.95)}.autocomplete-input{width:100%;padding:.75rem;border:2px solid #e1e5e9;border-radius:6px;font-size:1rem;transition:all .3s ease;box-sizing:border-box}.autocomplete-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.autocomplete-input::placeholder{color:#999}.hotel-stay-container{display:flex;gap:2rem;max-width:1200px;margin:.5rem auto;padding:0 1rem}.hotel-stay-error-container{max-width:600px;margin:2rem auto;padding:2rem;text-align:center;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px}.hotel-stay-error-container h2{color:#dc3545;margin-bottom:1rem}.hotel-stay-error-container p{color:#6c757d;margin-bottom:1.5rem}.hotel-stay-error-container button{background-color:#007bff;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer}.hotel-stay-error-container button:hover{background-color:#0056b3}.hotel-results-error{padding:1rem;background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:4px;margin:1rem 0}.hotel-result-error{padding:1rem;background-color:#fff3cd;color:#856404;border:1px solid #ffeaa7;border-radius:4px;margin:.5rem 0}.hotel-result-pending{opacity:.7;background-color:#f8f9fa;border:1px solid #e9ecef}.pending-spinner{display:inline-block;width:16px;height:16px;border:2px solid #f3f3f3;border-top:2px solid #007bff;border-radius:50%;animation:spin 1s linear infinite;margin-right:8px}.pending-text,.pending-placeholder{color:#6c757d;font-style:italic}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hotel-stay-form-section{flex:0 0 auto;overflow:visible}.hotel-stay-results-section{flex:1;min-width:0}.hotel-stay-form{padding:18px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0001}.hotel-stay-form h2{margin:0 0 1rem;color:#333;font-size:1.8rem;font-weight:600}.hotel-input-wrapper{position:relative;overflow:visible;z-index:10}.hotel-stay-selected{font-size:12px;color:#555;margin-top:4px}.hotel-stay-inputs{width:320px;max-width:45vw;display:flex;flex-direction:column;gap:1rem;overflow:visible}.hotel-stay-inputs>div{display:flex;flex-direction:column;gap:.5rem}.hotel-stay-inputs label{font-weight:500;color:#333;font-size:.9rem}.help-icon{display:inline-block;margin-left:.5rem;color:#667eea;font-size:.9rem;transition:color .2s ease}.help-icon:hover{color:#5a67d8}.hotel-stay-inputs input[type=date],.hotel-stay-inputs select{padding:.5rem;border:2px solid #e1e5e9;border-radius:6px;font-size:.85rem;transition:all .3s ease;box-sizing:border-box}.hotel-stay-inputs input[type=date]:focus,.hotel-stay-inputs select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.hotel-stay-submit{width:100%;padding:12px;background:#667eea;color:#fff;border:none;border-radius:6px;font-weight:600;font-size:1rem;cursor:pointer;transition:background .2s}.hotel-stay-submit:hover{background:#5a67d8}.hotel-stay-submit:disabled{background:#a3bffa;cursor:not-allowed}.loading-spinner{display:inline-block;width:16px;height:16px;border:2px solid #ffffff;border-radius:50%;border-top-color:transparent;animation:spin 1s ease-in-out infinite;margin-right:8px}@keyframes spin{to{transform:rotate(360deg)}}.hotel-stay-error{margin-top:16px;color:#e53e3e;padding:.75rem;background:#fed7d7;border:1px solid #feb2b2;border-radius:6px}.hotel-stay-success{margin-top:16px;color:#38a169;padding:.75rem;background:#c6f6d5;border:1px solid #9ae6b4;border-radius:6px}.hotel-results-list{display:flex;flex-direction:column;gap:1rem;margin-top:2rem;margin-bottom:1rem}@media(max-width:700px){.hotel-stay-row{flex-direction:column;gap:1.5rem}.hotel-stay-inputs{flex-direction:row;gap:1rem}.hotel-stay-inputs>div{flex:1}}.hotel-result{background:#fff;border-radius:8px;padding:1rem;box-shadow:0 2px 4px #0000001a;transition:all .3s ease-in-out;cursor:pointer;min-height:60px}.hotel-result-cheapest{background:#f0f8f0;border:1px solid #d4edda}.hotel-basic-info{display:flex;justify-content:space-between;align-items:center;gap:1rem}.hotel-dates-top{margin:.5rem 0;text-align:center}.hotel-checkin-date{font-size:.9rem;color:#666;transition:opacity .2s ease}.hotel-dates{display:flex;flex-direction:column;gap:.25rem}.book-link{display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;color:#007bff;font-weight:500;transition:color .2s ease}.book-link:hover{color:#0056b3;text-decoration:underline}.book-logo{height:16px;width:auto;max-width:40px;object-fit:contain}.hotel-pricing-expanded{display:none;flex-direction:column;gap:.2rem;margin:.25rem 0}.hotel-result:hover .hotel-pricing-expanded{display:flex}.hotel-price-detail{margin:0;font-size:.8rem;color:#666;font-weight:500;text-align:right}.hotel-dates{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.date-info{display:flex;justify-content:space-between;align-items:center;padding:.4rem .6rem;background:#f8f9fa;border-radius:4px}.hotel-result-cheapest .date-info{background:#e8f5e8;border:1px solid #c3e6c3}.date-label{font-weight:500;color:#666;font-size:.85rem}.date-value{font-weight:600;color:#333;font-size:.85rem}.hotel-checkin-date{margin:0;color:#333;font-weight:500;font-size:1rem}.hotel-details{display:flex;flex-direction:column;gap:.25rem;align-items:flex-end}.hotel-price{margin:0;font-weight:700;color:#06c;font-size:1.1rem}.hotel-details a{color:#06c;text-decoration:none;font-size:.9rem;font-weight:500}.hotel-details a:hover{text-decoration:underline}.navigation{background-color:#1a1a1a;padding:.5rem 0;border-bottom:1px solid #333}.nav-list{list-style:none;margin:0;padding:0;display:flex;justify-content:center;gap:2rem}.nav-link{color:#fff;text-decoration:none;font-size:1rem;font-weight:500;padding:.5rem 1rem;border-radius:4px;transition:all .3s ease}.nav-link:hover{background-color:#333;color:#fff;text-decoration:none}.nav-link.active{background-color:#4a90e2;color:#fff}.App{text-align:center;min-height:100vh;background-color:#f5f5f5}.App-header{background-color:#282c34;padding:.5rem 2rem;color:#fff;margin-bottom:1rem;display:flex;justify-content:flex-start;align-items:center;gap:2rem}.App-header img{max-width:200px;width:70px;height:auto;object-fit:contain}.App-header h1{font-size:2rem;font-weight:700;text-align:left;color:#fff}.nav-tabs{display:flex;justify-content:center;gap:.5rem;margin-top:1rem}.nav-tab{background:transparent;border:2px solid #ffffff40;color:#fff;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .3s ease;text-decoration:none;display:inline-block}.nav-tab:hover{background:#ffffff20;border-color:#ffffff60;text-decoration:none;color:#fff}.nav-tab.active{background:#fff;color:#282c34;border-color:#fff;text-decoration:none}main{max-width:1600px;margin:0 auto;padding:0 1rem}#root{max-width:1600px;width:90%;margin:0 auto;text-align:center}.card{padding:2em}.read-the-docs{color:#888}
