: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}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}.app{height:100vh;display:flex;flex-direction:column;overflow:hidden}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 10px #0000001a;z-index:1000}.logo h1{font-size:1.5rem;font-weight:700;margin:0}.search-container{flex:1;max-width:400px;margin:0 1rem}.search-input{width:100%;padding:.75rem 1rem;border:none;border-radius:25px;font-size:.9rem;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.search-input:focus{outline:none;background:#fff;box-shadow:0 0 0 3px #ffffff4d}.nav{display:flex;gap:.5rem}.nav-btn{padding:.5rem 1rem;border:2px solid rgba(255,255,255,.3);border-radius:20px;background:transparent;color:#fff;font-size:.9rem;cursor:pointer;transition:all .3s ease}.nav-btn:hover{background:#ffffff1a;border-color:#ffffff80}.main-content{flex:1;display:flex;overflow:hidden}.sidebar{width:350px;background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;overflow:hidden;box-shadow:2px 0 10px #0000001a}.sidebar-header{padding:1.5rem;border-bottom:1px solid #e0e0e0;background:#fafafa}.sidebar-header h3{margin-bottom:1rem;color:#333;font-size:1.2rem}.filter-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.filter-btn{padding:.5rem 1rem;border:1px solid #ddd;border-radius:20px;background:#fff;color:#666;font-size:.8rem;cursor:pointer;transition:all .3s ease}.filter-btn:hover,.filter-btn.active{background:#667eea;color:#fff;border-color:#667eea}.places-list{flex:1;overflow-y:auto;padding:1rem}.place-item{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:1rem;margin-bottom:1rem;cursor:pointer;transition:all .3s ease;display:flex;justify-content:space-between;align-items:center}.place-item:hover{border-color:#667eea;box-shadow:0 4px 15px #667eea1a;transform:translateY(-2px)}.place-item.selected{border-color:#667eea;background:#f8f9ff;box-shadow:0 4px 15px #667eea33}.place-info h4{color:#333;margin-bottom:.5rem;font-size:1rem}.place-type{color:#666;font-size:.9rem;margin-bottom:.5rem}.rating{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.rating-text{color:#666;font-size:.9rem}.price{color:#28a745;font-weight:600;font-size:.9rem}.reserve-btn{padding:.5rem 1rem;background:#28a745;color:#fff;border:none;border-radius:20px;font-size:.8rem;cursor:pointer;transition:all .3s ease}.reserve-btn:hover{background:#218838;transform:scale(1.05)}.map-container{flex:1;position:relative;overflow:hidden}.map{width:100%;height:100%;background:#f0f0f0;display:flex;align-items:center;justify-content:center}.map-placeholder{text-align:center;color:#666;padding:2rem}.map-placeholder h3{margin-bottom:1rem;color:#333}.map-placeholder p{margin-bottom:.5rem;font-size:.9rem}.place-detail{position:absolute;bottom:0;left:0;right:0;background:#fff;border-radius:20px 20px 0 0;padding:1.5rem;box-shadow:0 -4px 20px #0000001a;transform:translateY(0);transition:transform .3s ease;max-height:60vh;overflow-y:auto}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.detail-header h3{color:#333;font-size:1.3rem}.close-btn{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:.5rem;border-radius:50%;transition:all .3s ease}.close-btn:hover{background:#f0f0f0;color:#333}.detail-content{color:#666}.detail-type{font-size:1.1rem;margin-bottom:.5rem}.detail-rating,.detail-price{margin-bottom:.5rem;font-size:1rem}.detail-actions{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}.action-btn{padding:.75rem 1.5rem;border:1px solid #ddd;border-radius:25px;background:#fff;color:#666;font-size:.9rem;cursor:pointer;transition:all .3s ease;flex:1;min-width:120px}.action-btn:hover{border-color:#667eea;color:#667eea}.action-btn.primary{background:#667eea;color:#fff;border-color:#667eea}.action-btn.primary:hover{background:#5a6fd8}@media (max-width: 768px){.header{flex-direction:column;gap:1rem;padding:1rem}.search-container{margin:0;max-width:100%}.nav{width:100%;justify-content:center}.main-content{flex-direction:column}.sidebar{width:100%;height:300px;border-right:none;border-bottom:1px solid #e0e0e0}.places-list{padding:.5rem}.place-item{padding:.75rem;margin-bottom:.75rem}.filter-buttons{justify-content:center}.detail-actions{flex-direction:column}.action-btn{flex:none;width:100%}}@media (max-width: 480px){.logo h1{font-size:1.2rem}.sidebar-header{padding:1rem}.place-detail{padding:1rem;max-height:70vh}.detail-header h3{font-size:1.1rem}}.places-list::-webkit-scrollbar,.place-detail::-webkit-scrollbar{width:6px}.places-list::-webkit-scrollbar-track,.place-detail::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.places-list::-webkit-scrollbar-thumb,.place-detail::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.places-list::-webkit-scrollbar-thumb:hover,.place-detail::-webkit-scrollbar-thumb:hover{background:#a8a8a8}
