: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}}.input-container{position:relative;margin-bottom:0}.input-container label{font-weight:500;color:#333;font-size:.9rem;margin-bottom:.5rem;display:block}.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}.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;right:0;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}.hotel-stay-form{max-width:1000px;margin:2rem auto;padding:24px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0001}.hotel-stay-form h2{margin:0 0 1.5rem;color:#333;font-size:1.8rem;font-weight:600}.hotel-stay-row{display:flex;gap:24px;margin-bottom:1.5rem}.hotel-stay-selector{flex:2;min-width:240px}.hotel-input-wrapper{position:relative}.hotel-stay-selected{font-size:12px;color:#555;margin-top:4px}.hotel-stay-inputs{flex:1;min-width:180px;display:flex;flex-direction:column;gap:1rem}.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 input[type=number]{padding:.75rem;border:2px solid #e1e5e9;border-radius:6px;font-size:1rem;transition:all .3s ease;box-sizing:border-box}.hotel-stay-inputs input[type=date]:focus,.hotel-stay-inputs input[type=number]: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-form.loading{position:relative}.hotel-stay-form.loading:after{content:"";position:absolute;inset:0;background:#fffc;border-radius:8px;z-index:10}.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:row;flex-wrap:wrap;gap:1rem;margin-top:2rem}@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:box-shadow .2s ease-in-out}.hotel-result:hover{box-shadow:0 4px 8px #00000026}.hotel-name{margin:0 0 .5rem;color:#333;font-size:1.1rem;font-weight:600}.hotel-details{display:flex;flex-direction:column;gap:.25rem}.hotel-rating,.hotel-location{margin:0;color:#666;font-size:.9rem}.hotel-price{margin:.5rem 0 0;font-weight:700;color:#06c;font-size:1rem}.loading-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.loading-content{background:#fff;padding:2rem;border-radius:8px;text-align:center;box-shadow:0 4px 20px #00000026}.loading-content .loading-spinner{width:32px;height:32px;border:3px solid #f3f3f3;border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem;display:block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-message{color:#333;font-size:1.1rem;font-weight:500;margin:0}.loading-subtitle{color:#666;font-size:.9rem;margin:.5rem 0 0}.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:1rem 2rem;color:#fff;margin-bottom:2rem;display:flex;justify-content:flex-start;align-items:center;gap:2rem}.App-header img{max-width:200px;width:150px;height:auto;object-fit:contain}.App-header h1{margin:0 0 1rem;font-size:2.5rem;font-weight:700;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;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
