html,body,#container{margin:0;width:100%;height:100%;overflow:hidden}#bottom-menu{display:flex;justify-content:space-around;align-items:center;position:fixed;bottom:0;left:0;width:100%;background-color:#fff;padding:10px 0;border-top:1px solid #ccc;box-shadow:0 -2px 5px #0000000d;z-index:1000}.menu-item{background:none;border:none;outline:none;padding:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease;border-radius:50%;width:48px;height:48px}.menu-item:hover{background-color:#0000000d}.menu-item svg{width:24px;height:24px;color:#333}.buttonRoot{width:32px;box-shadow:0 1px 3px #26262680;border-radius:1px;display:flex;flex-direction:column;overflow:hidden;background:#fff}.button{padding:0;outline:0;border:none;cursor:pointer;background:#fff;width:32px;height:32px;color:#262626;box-sizing:border-box}.button:hover{opacity:.7}.button:active{color:#028eff}#custom-bar{position:absolute;inset:auto 0 0;margin:10px;padding:20px;border-radius:4px;background-color:#fff;box-shadow:0 0 10px #00000080;text-align:center}#bottom-menu{position:absolute;bottom:0;left:0;right:0;background-color:#fff;display:flex;justify-content:space-around;align-items:center;padding:12px 0;box-shadow:0 -2px 10px #0000001a;border-top-left-radius:12px;border-top-right-radius:12px}.menu-item{display:flex;flex-direction:column;align-items:center;font-size:12px;color:#000;cursor:pointer;user-select:none}.menu-item svg{margin-bottom:4px}button{background:none;border:none;padding:8px;font-size:14px;color:#333}button svg{width:24px;height:24px;display:block;margin:0 auto}.modal{position:absolute;top:10%;left:50%;transform:translate(-50%);width:90%;max-width:500px;background:#fff;border-radius:12px;padding:16px;box-shadow:0 4px 20px #0003;z-index:1000}.hidden{display:none}#address-suggestions{list-style:none;margin:4px 0 0;padding:0;border-radius:8px;box-shadow:0 4px 10px #0000001a;background:#fff;font-family:sans-serif;overflow:hidden;border:1px solid #ddd}#address-suggestions li{padding:10px 16px;cursor:pointer;transition:background .2s;font-size:14px;color:#333}#address-suggestions li:hover{background-color:#f0f0f0}.moder-btn{width:100%}.preview-container{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px}.preview-image{position:relative;width:90px;height:90px;border-radius:10px;overflow:hidden;border:1px solid #ccc;flex-shrink:0}.preview-image img{width:100%;height:100%;object-fit:cover;display:block}.remove-btn{position:relative;top:-83%;right:-83%;width:20px;height:20px;background-color:#ff4d4d;color:#fff;font-size:14px;border:none;border-radius:50%;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;line-height:1}.remove-btn:hover{background-color:#ff1a1a}.category-filter-overlay{position:fixed;inset:0;background:#0006;display:flex;justify-content:center;align-items:center;z-index:999}.category-filter-overlay.hidden{display:none}.category-filter-modal{position:fixed;top:10%;left:50%;transform:translate(-50%);background:#fff;padding:20px;border-radius:12px;box-shadow:0 0 10px #00000040;z-index:2000;width:80%;max-width:400px}#apply-filters,#close-filter-modal,#select-all{margin-top:3vw;background-color:#00796b;border:none;border-radius:2.5vw;color:#fff;font-size:4vw}#close-filter-modal{background-color:#ff1a1a}#select-all{background-color:#1f78d6}.radius-slider-wrapper{margin:10px 0}.radius-slider-wrapper input[type=range]{width:100%}#radius-value{display:inline-block;margin-top:5px;font-weight:700}.location-card{background:#fff;padding:10px;border-radius:10px;font-family:sans-serif;position:relative}.centered-popup{position:fixed;top:50%;left:50%;width:80%;transform:translate(-50%,-50%);max-height:90vh;max-width:90vw;overflow-y:auto;z-index:9999;background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;padding:20px}.card-header{display:flex;justify-content:space-between;align-items:start}.location-title{font-size:1.1em}.presence-buttons{display:flex;flex-direction:column;gap:5px}.presence-buttons.presence-bottom{margin-top:12px;flex-direction:row;justify-content:space-between}.presence-btn{margin-top:3vw;background-color:#00796b;border:none;border-radius:2.5vw;color:#fff;font-size:4vw}.presence-buttons.presence-bottom .presence-btn:first-child{margin-left:0}.presence-buttons.presence-bottom .presence-btn:last-child{margin-right:0}#minus{background-color:#ff1a1a}.location-category,.location-tags{margin:5px 0}.tag{background:#d0ebff;padding:2px 6px;margin:2px;display:inline-block;border-radius:3px;font-size:.87em}.photo-slider{display:flex;overflow-x:auto;margin:10px 0;gap:5px}.photo-slide{width:100px;height:80px;object-fit:cover;border-radius:5px;flex-shrink:0}.photo-placeholder{color:gray;font-size:14px;padding:10px;text-align:center}.location-description,.location-rating{margin-top:10px}.rating-summary{display:flex;justify-content:space-between;align-items:center}.rating-modal{background:#0000004d;position:fixed;inset:0;display:flex;align-items:center;justify-content:center}.rating-modal.hidden{display:none}.modal-content{background:#fff;padding:20px;border-radius:10px}.report-button,.route-button{margin-top:10px;width:100%;padding:8px;background-color:#fdd;border:none;border-radius:5px;cursor:pointer}.route-button{background-color:#83eccb}.location-photos-scroll{display:flex;gap:8px;overflow-x:auto;padding:8px 0}.photo-slide{height:120px;border-radius:6px;flex-shrink:0;object-fit:cover}.review-form-wrapper{margin-top:20px}#review-form.hidden{display:none}.photo-preview{height:60px;margin-right:10px;border-radius:6px}.rating-modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;z-index:999;display:flex;align-items:flex-start;justify-content:center;overflow-y:auto}.modal-content.enhanced-reviews{background-color:#fff;border-radius:10px;width:80vw;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 4px 20px #0003}.modal-content .close-modal.top-right{position:absolute;top:1rem;right:1rem;font-size:1.5rem;background:none;border:none;cursor:pointer}.modal-content .user-reviews{margin-top:2rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.modal-content .user-reviews li,.rating-summary-breakdown ul{list-style:none;padding:1rem 1.5rem;border-radius:8px;background-color:#efefef;box-shadow:0 2px 5px #0000000d;border-bottom:none;text-align:center}.modal-content .user-reviews li,.rating-summary-breakdown li{font-size:1.1rem;margin-bottom:.5rem;text-align:center}.modal-content .user-reviews span,.modal-content .user-reviews p,.rating-summary-breakdown li{text-align:center;margin-top:.5rem}.modal-content .user-reviews a{color:#116a48;font-size:1.3rem;text-decoration:none;cursor:pointer}.modal-content .user-reviews a:hover{text-decoration:underline}html,body{margin:0;padding:0;width:100%;height:100%;font-family:sans-serif;background:#f5f5f5}#location-modal{width:100%;height:calc(100% - 60px);position:absolute;top:0;left:0;background:#fff;z-index:100;overflow-y:auto;padding:4vw 5vw 6vw;display:none;box-sizing:border-box}#location-modal.active{display:block}#add-location-form{max-width:100%;margin:0 auto;display:flex;flex-direction:column;gap:3vw}label{font-weight:600;margin-bottom:1vw;font-size:3.8vw}input[type=text],select,textarea{width:100%;padding:2.5vw;border:.3vw solid #ccc;border-radius:2.5vw;font-size:4vw;box-sizing:border-box}textarea{resize:vertical;min-height:14vw}.photo-upload,.location-input,.select-wrapper,.filters-wrapper,.rating-wrapper{display:flex;flex-direction:column;gap:1.5vw}#photo-preview img{max-width:24vw;border-radius:3vw;margin-top:2vw}.custom-file-input{display:inline-block;padding:2.5vw 4vw;background-color:#00796b;color:#fff;border:none;border-radius:3vw;font-size:4vw;cursor:pointer;text-align:center}.custom-file-input:hover{background-color:#005f56}input[type=file]{display:none}.filter-chip{display:inline-block;background:#f0f0f0;padding:2vw 3vw;margin:1vw;border-radius:6vw;font-size:3.5vw}.rating-wrapper div{display:flex;align-items:center;gap:2vw;justify-content:space-between;flex-wrap:wrap}.stars{direction:rtl;display:flex;gap:1vw}.stars input[type=radio]{display:none}.stars label{font-size:5vw;color:#ccc;cursor:pointer}.stars input[type=radio]:checked~label{color:gold}.stars label:hover,.stars label:hover~label{color:gold}button[type=submit]{background:#00796b;color:#fff;padding:3vw;font-size:4vw;border:none;border-radius:3vw;cursor:pointer}
