:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#f5f7fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}button{font-family:inherit;cursor:pointer;transition:all .3s ease;-webkit-tap-highlight-color:transparent}button:disabled{cursor:not-allowed;opacity:.6}input,select{font-family:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#bdc3c7;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#95a5a6}*{box-sizing:border-box}.app{max-width:1200px;margin:0 auto;padding:2rem}.app-header{text-align:center;margin-bottom:3rem}.app-header h1{font-size:2.5rem;color:#2c3e50;margin-bottom:.5rem}.subtitle{font-size:1.1rem;color:#7f8c8d}.app-main{display:grid;gap:2rem}.search-form{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.form-group{margin-bottom:1.5rem}.search-form .form-group:last-of-type{margin-bottom:.25rem}.form-group label{display:block;font-weight:600;margin-bottom:.5rem;color:#2c3e50}.form-group input[type=text]{width:100%;padding:.75rem 2.5rem .75rem .75rem;font-size:1rem;border:2px solid #ddd;border-radius:4px;transition:border-color .3s}.form-group select{width:100%;padding:.75rem 2.5rem .75rem .75rem;font-size:1rem;background:#fff;color:#2c3e50;border:2px solid #3498db;border-radius:4px;cursor:pointer;transition:all .3s;font-weight:500;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%232c3e50' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px 8px}.form-group select:hover{background-color:#e3f2fd;border-color:#2980b9;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%232c3e50' d='M6 8L0 0h12z'/%3E%3C/svg%3E")}.form-group input[type=text]:focus,.form-group select:focus{outline:none;border-color:#3498db}.cities-list{max-height:300px;overflow-y:auto;border:1px solid #ddd;border-radius:4px;padding:.75rem;background:#fafbfc;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}.city-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem .75rem;border-radius:6px;background:#fff;border:2px solid #e9ecef;transition:all .2s ease;-webkit-user-select:none;user-select:none}.city-checkbox:hover{background:#f8f9fa;border-color:#bdc3c7}.city-checkbox:has(input[type=checkbox]:checked){background:#e3f2fd;border-color:#3498db;font-weight:600}.city-checkbox:has(input[type=checkbox]:checked):hover{background:#d1e7fd;border-color:#2980b9}.city-checkbox input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:#3498db}.search-button{width:100%;padding:1rem;font-size:1.1rem;font-weight:600;background:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .3s}.search-button:hover:not(:disabled){background:#2980b9}.search-button:disabled{background:#bdc3c7;cursor:not-allowed}.auto-search-note{margin-top:1rem;font-size:.95rem;color:#7f8c8d}.select-cities-button{width:100%;padding:.75rem;font-size:1rem;background:#fff;color:#2c3e50;border:2px solid #3498db;border-radius:4px;cursor:pointer;transition:all .3s;font-weight:500}.select-cities-button:hover{background:#e3f2fd;border-color:#2980b9}.selected-cities-preview{margin-top:.75rem;padding:.75rem;background:#f8f9fa;border-radius:4px;border:1px solid #e9ecef;color:#495057;font-size:.9rem;line-height:1.5}.modal-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:8px;width:100%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e9ecef}.modal-header h2{margin:0;font-size:1.5rem;color:#2c3e50}.close-button{background:none;border:none;font-size:2rem;cursor:pointer;color:#7f8c8d;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;transition:color .3s}.close-button:hover{color:#2c3e50}.modal-actions{display:flex;gap:1rem;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e9ecef;background:#f8f9fa}.action-button{padding:.5rem 1rem;font-size:.9rem;background:#fff;border:1px solid #dee2e6;border-radius:4px;cursor:pointer;transition:all .3s}.action-button:hover{background:#e9ecef;border-color:#adb5bd}.selected-count{margin-left:auto;font-weight:600;color:#3498db}.modal-body{flex:1;overflow-y:auto;padding:1.5rem}.cities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.city-checkbox-item{display:flex;align-items:center;gap:.5rem;padding:.75rem;border:2px solid #e9ecef;border-radius:6px;background:#fff;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.city-checkbox-item:hover{background:#f8f9fa;border-color:#bdc3c7}.city-checkbox-item:has(input[type=checkbox]:checked){background:#e3f2fd;border-color:#3498db}.city-checkbox-item:has(input[type=checkbox]:checked):hover{background:#d1e7fd;border-color:#2980b9}.city-checkbox-item input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#3498db}.city-checkbox-item span{flex:1;font-size:.95rem}.city-checkbox-item:has(input[type=checkbox]:checked) span{font-weight:600}.modal-footer{display:flex;gap:1rem;padding:1.5rem;border-top:1px solid #e9ecef;background:#f8f9fa}.cancel-button{flex:1;padding:.85rem;font-size:1rem;background:#fff;color:#6c757d;border:1px solid #dee2e6;border-radius:4px;cursor:pointer;transition:all .3s;font-weight:500}.cancel-button:hover{background:#e9ecef;border-color:#adb5bd}.confirm-button{flex:2;padding:.85rem;font-size:1rem;font-weight:600;background:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .3s}.confirm-button:hover:not(:disabled){background:#2980b9}.confirm-button:disabled{background:#bdc3c7;cursor:not-allowed}.search-results{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.results-header h2{margin:0;color:#2c3e50}.open-all-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;background:#27ae60;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .3s}.open-all-button:hover{background:#229954}.open-all-button:disabled{background:#bdc3c7;cursor:not-allowed}.results-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.result-item a{display:block;padding:1.25rem;background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;color:#3498db;text-decoration:none;font-size:1.1rem;font-weight:500;transition:all .3s}.result-item a:hover{background:#e9ecef;border-color:#3498db;transform:translate(4px)}.results-placeholder{margin:0;padding:1.25rem;background:#f6f8fa;border:1px dashed #cfd8e0;border-radius:4px;color:#7f8c8d;font-size:1rem}@media(max-width:1024px){.app{padding:1.5rem}.app-header h1{font-size:2.2rem}.cities-list{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}@media(max-width:768px){.app{padding:1rem}.app-header{margin-bottom:2rem}.app-header h1{font-size:1.8rem}.subtitle{font-size:1rem}.search-form,.search-results{padding:1.5rem}.cities-list{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));max-height:250px}.results-header{flex-direction:column;gap:1rem;align-items:stretch}.result-item a{font-size:1rem;padding:1rem}.modal-content{max-height:95vh}.modal-header h2{font-size:1.3rem}.cities-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}@media(max-width:480px){.app{padding:.75rem}.app-header{margin-bottom:1.5rem}.app-header h1{font-size:1.5rem}.subtitle{font-size:.9rem}.search-form,.search-results{padding:1rem;border-radius:6px}.form-group{margin-bottom:1.25rem}.form-group input[type=text],.form-group select{padding:.65rem;font-size:.95rem}.cities-list{grid-template-columns:1fr 1fr;max-height:200px;padding:.75rem;gap:.4rem}.city-checkbox{font-size:.9rem}.search-button{padding:.85rem;font-size:1rem}.results-header h2{font-size:1.3rem}.open-all-button{padding:.65rem 1.25rem;font-size:.95rem}.result-item a{font-size:.95rem;padding:.9rem}.modal-backdrop{padding:0}.modal-content{max-height:100vh;border-radius:0}.modal-header{padding:1rem}.modal-header h2{font-size:1.2rem}.modal-actions{padding:.75rem 1rem;flex-wrap:wrap}.modal-body{padding:1rem}.cities-grid{grid-template-columns:1fr 1fr;gap:.5rem}.city-checkbox-item{padding:.65rem;font-size:.9rem}.modal-footer{padding:1rem}}@media(max-width:360px){.app-header h1{font-size:1.3rem}.cities-list,.cities-grid{grid-template-columns:1fr}}@media(max-height:600px)and (orientation:landscape){.app-header{margin-bottom:1rem}.app-header h1{font-size:1.5rem}.subtitle{font-size:.85rem}.cities-list{max-height:150px}.search-form,.search-results{padding:1rem}}@media(hover:none)and (pointer:coarse){.search-button,.open-all-button{min-height:44px}.city-checkbox{min-height:44px;padding:.5rem .25rem}.city-checkbox input[type=checkbox]{width:20px;height:20px}.result-item a:active{transform:scale(.98)}}@media(-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.search-form,.search-results{box-shadow:0 2px 12px #00000014}}
