:root{--c-black: #222;--c-white: #FFF;--c-gray-100: #F9F9F9;--c-gray-200: #efefef;--c-gray-300: #D8D8DB;--c-gray-400: #949497;--c-gray-500: #626264;--c-cyan-100: #C5F5F5;--c-cyan-200: #5DD5D5;--c-cyan-300: #3AAFAF;--c-magenta-100: #F5C5F5;--c-magenta-200: #D555D5;--c-magenta-300: #AF3AAF;--c-gold: #F5A623;--c-neon-blue: #00D9FF;--c-pink: #FF6B9D;--c-green-100: var(--c-cyan-100);--c-green-200: var(--c-cyan-200);--c-green-300: var(--c-cyan-300);--c-yellow: var(--c-gold);--c-red: #EC0000;--c-text: var(--c-black);--c-link: var(--c-cyan-200);--c-link-hover: var(--c-cyan-300);--c-link-current: var(--c-gray-500);--c-focus: var(--c-magenta-200);--c-hairline: var(--c-gray-300);--z-fixed: 1030;--z-modal: 1050;--f-default: YakuHanJPs_Noto, "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif}*{box-sizing:border-box}body{margin:0;padding:0;width:100vw;height:100vh;overflow:hidden;font-family:var(--f-default);color:var(--c-text)}.page-loader{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--c-white);z-index:9999;display:flex;align-items:center;justify-content:center;opacity:1;transition:opacity .5s ease,visibility .5s ease}.page-loader.loaded{opacity:0;visibility:hidden}.loader-content{display:flex;flex-direction:column;align-items:center;gap:20px}.loader-spinner{width:50px;height:50px;border:4px solid var(--c-gray-200);border-top:4px solid var(--c-green-200);border-radius:50%;animation:spin 1s linear infinite}.loader-text{font-size:16px;font-weight:500;color:var(--c-gray-500);margin:0;letter-spacing:.5px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}#map{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;transition:left .3s cubic-bezier(.4,0,.2,1),width .3s cubic-bezier(.4,0,.2,1)}@media(min-width:601px){#map{height:calc(100% - 180px)}}@media(max-width:600px){#map{height:calc(100% - 60px)}}.map-logo{position:absolute;bottom:80px;left:20px;z-index:10;pointer-events:none}.map-logo img{height:48px;width:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));opacity:.9}@media(max-width:600px){.map-logo{bottom:80px;left:16px}.map-logo img{height:36px}}@media(min-width:601px){.map-logo{bottom:200px}}.poi-panel{position:fixed;left:0;right:0;bottom:0;background:var(--c-white);border-radius:16px 16px 0 0;box-shadow:0 -4px 20px #00000026;z-index:var(--z-modal);transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);max-height:85vh;display:flex;flex-direction:column}.poi-panel.visible{transform:translateY(0)}@media(min-width:768px){.poi-panel{inset:0 auto 0 0;width:400px;height:100%;max-height:none;border-radius:0;box-shadow:4px 0 20px #00000026;transform:translate(-100%)}.poi-panel.visible{transform:translate(0)}.poi-panel-handle{display:none}}.poi-panel.hidden{display:none}.poi-panel.dragging{transition:none}.poi-panel-handle{width:40px;height:4px;background:var(--c-gray-300);border-radius:2px;margin:12px auto 8px;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.poi-panel-handle:active{cursor:grabbing}.poi-panel-content{overflow-y:auto;padding:0 20px 20px;flex:1}.poi-cover-image{display:none;width:calc(100% + 40px);margin:0 -20px;height:200px;background-size:cover;background-position:center;flex-shrink:0}@media(min-width:768px){.poi-cover-image{display:block}}.poi-header{position:relative;padding:8px 0 16px}.poi-close-btn{position:absolute;top:0;right:0;background:var(--c-gray-200);border:none;border-radius:50%;width:32px;height:32px;font-size:24px;line-height:1;cursor:pointer;color:var(--c-gray-500);display:flex;align-items:center;justify-content:center;transition:background .2s}.poi-close-btn:hover{background:var(--c-gray-300)}.poi-title{font-size:24px;font-weight:700;margin:0 40px 8px 0;color:var(--c-black)}.poi-rating{display:flex;align-items:center;gap:8px;margin-bottom:8px}.rating-number{font-size:16px;font-weight:700;color:var(--c-black)}.rating-stars{color:var(--c-yellow);font-size:18px;letter-spacing:2px}.poi-category{display:inline-block;padding:4px 12px;background:var(--c-green-100);color:var(--c-green-300);border-radius:12px;font-size:13px;font-weight:500}.poi-share-btn{position:absolute;top:0;right:44px;background:var(--c-gray-200);border:none;border-radius:50%;width:32px;height:32px;cursor:pointer;color:var(--c-gray-500);display:flex;align-items:center;justify-content:center;transition:background .2s}.poi-share-btn:hover{background:var(--c-gray-300)}.share-menu{position:absolute;top:40px;right:44px;background:var(--c-white);border:1px solid var(--c-hairline);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:100;overflow:hidden;min-width:160px}.share-menu.hidden{display:none}.share-menu-item{display:block;width:100%;padding:12px 16px;background:none;border:none;text-align:left;font-size:14px;font-family:var(--f-default);color:var(--c-text);cursor:pointer;transition:background .2s;border-bottom:1px solid var(--c-gray-200)}.share-menu-item:last-child{border-bottom:none}.share-menu-item:hover{background:var(--c-gray-100)}.poi-photos{margin:16px -20px;overflow:hidden}.photos-scroll{display:flex;gap:8px;padding:0 20px;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none}.photos-scroll::-webkit-scrollbar{display:none}.photo-item{flex-shrink:0;width:200px;height:150px;border-radius:8px;overflow:hidden;scroll-snap-align:start;background:var(--c-gray-200)}.photo-item img{width:100%;height:100%;object-fit:cover}.poi-tabs{display:flex;gap:4px;border-bottom:1px solid var(--c-hairline);margin:20px 0 16px}.poi-tab{flex:1;padding:12px 16px;background:none;border:none;border-bottom:3px solid transparent;font-size:14px;font-weight:500;color:var(--c-gray-500);cursor:pointer;transition:all .2s;font-family:var(--f-default)}.poi-tab:hover{color:var(--c-green-200)}.poi-tab.active{color:var(--c-green-200);border-bottom-color:var(--c-green-200)}.poi-tab-content{min-height:200px}.tab-pane{display:none;animation:fadeIn .3s}.tab-pane.active{display:block}.tab-content-text{font-size:15px;line-height:1.6;color:var(--c-text);margin:0}.reviews-list{display:flex;flex-direction:column;gap:20px}.review-card{display:flex;gap:12px;padding-bottom:20px;border-bottom:1px solid var(--c-gray-200)}.review-card:last-child{border-bottom:none;padding-bottom:0}.review-avatar{flex-shrink:0;width:40px;height:40px;border-radius:50%;background:var(--c-gray-300);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--c-white);font-size:16px;overflow:hidden}.review-avatar img{width:100%;height:100%;object-fit:cover}.review-content{flex:1;min-width:0}.review-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.review-user-name{font-weight:600;font-size:14px;color:var(--c-black)}.review-stars{display:flex;gap:2px;margin-bottom:8px}.review-star{color:var(--c-gray-300);font-size:14px}.review-star.filled{color:var(--c-yellow)}.review-text{font-size:14px;line-height:1.5;color:var(--c-text);margin:0 0 12px;word-wrap:break-word}.review-actions{display:flex;align-items:center;gap:16px;position:relative}.review-share-btn{display:flex;align-items:center;gap:6px;background:none;border:none;padding:6px 12px;border-radius:16px;cursor:pointer;font-size:13px;color:var(--c-gray-500);transition:all .2s}.review-share-btn:hover{background:var(--c-gray-100)}.review-share-menu{position:absolute;bottom:40px;left:0;background:var(--c-white);border:1px solid var(--c-hairline);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:100;overflow:hidden;min-width:160px}.review-share-menu.hidden{display:none}.review-like-btn{display:flex;align-items:center;gap:6px;background:none;border:none;padding:6px 12px;border-radius:16px;cursor:pointer;font-size:13px;color:var(--c-gray-500);transition:all .2s;font-family:var(--f-default)}.review-like-btn:hover{background:var(--c-gray-100)}.review-like-btn.liked{color:var(--c-red)}.review-like-icon{font-size:16px}.review-like-btn.liked .review-like-icon{animation:heartBeat .3s ease}.review-like-count{font-weight:500}@keyframes heartBeat{0%,to{transform:scale(1)}25%{transform:scale(1.3)}50%{transform:scale(.9)}75%{transform:scale(1.1)}}.review-post-button{width:100%;padding:14px 20px;background:var(--c-green-200);color:var(--c-white);border:none;border-radius:8px;font-size:15px;font-weight:600;font-family:var(--f-default);cursor:pointer;margin-bottom:20px;transition:background .2s}.review-post-button:hover{background:var(--c-green-300)}.review-post-modal{position:fixed;inset:0;background:#0009;z-index:calc(var(--z-modal) + 20);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;padding:20px}.review-post-modal.visible{opacity:1}.review-post-modal.hidden{display:none}.review-post-content{background:var(--c-white);border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.review-post-header{padding:20px;border-bottom:1px solid var(--c-hairline);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--c-white);z-index:1}.review-post-header h3{margin:0;font-size:20px;color:var(--c-black)}.review-post-close{background:var(--c-gray-200);border:none;border-radius:50%;width:32px;height:32px;font-size:24px;line-height:1;cursor:pointer;color:var(--c-gray-500);display:flex;align-items:center;justify-content:center;transition:background .2s}.review-post-close:hover{background:var(--c-gray-300)}.review-post-body{padding:20px}.review-post-info{background:var(--c-gray-100);padding:16px;border-radius:8px;margin-bottom:24px}.review-post-info p{margin:0 0 8px;font-size:14px;line-height:1.5;color:var(--c-text)}.review-post-info p:last-child{margin-bottom:0}.review-post-rule{font-size:13px!important;color:var(--c-gray-500)!important}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:600;color:var(--c-text);margin-bottom:8px}.required{color:var(--c-red);font-size:12px;font-weight:400}.form-group input[type=text],.form-group textarea{width:100%;padding:12px;border:1px solid var(--c-hairline);border-radius:8px;font-size:14px;font-family:var(--f-default);color:var(--c-text);transition:border-color .2s}.form-group input[type=text]:focus,.form-group textarea:focus{outline:none;border-color:var(--c-green-200)}.form-group textarea{resize:vertical;min-height:100px}.star-rating-input{display:flex;gap:8px;font-size:32px}.star-input{cursor:pointer;color:var(--c-gray-300);transition:all .2s;-webkit-user-select:none;user-select:none}.star-input:hover{transform:scale(1.1)}.star-input.filled{color:var(--c-yellow)}.char-count{text-align:right;font-size:12px;color:var(--c-gray-500);margin-top:4px}.form-actions{display:flex;gap:12px;margin-top:24px}.btn-cancel,.btn-submit{flex:1;padding:12px 24px;border:none;border-radius:8px;font-size:15px;font-weight:600;font-family:var(--f-default);cursor:pointer;transition:all .2s}.btn-cancel{background:var(--c-gray-200);color:var(--c-gray-500)}.btn-cancel:hover{background:var(--c-gray-300)}.btn-submit{background:var(--c-green-200);color:var(--c-white)}.btn-submit:hover{background:var(--c-green-300)}.btn-submit:disabled{background:var(--c-gray-300);cursor:not-allowed;opacity:.6}.image-upload-container{margin-top:8px}.image-upload-btn{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--c-gray-100);border:2px dashed var(--c-gray-300);border-radius:8px;cursor:pointer;transition:all .2s;font-size:14px;color:var(--c-text);width:100%;justify-content:center}.image-upload-btn:hover{background:var(--c-gray-200);border-color:var(--c-green-200)}.image-upload-btn span:first-child{font-size:20px}.image-preview-container{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px}.image-preview-item{position:relative;width:80px;height:80px;border-radius:8px;overflow:hidden;border:1px solid var(--c-hairline)}.image-preview-item img,.image-preview-item video{width:100%;height:100%;object-fit:cover}.image-remove-btn{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;background:#0009;color:var(--c-white);border:none;cursor:pointer;font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .2s}.image-remove-btn:hover{background:#000c}.review-photos{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}.review-photo{width:100px;height:100px;object-fit:cover;border-radius:8px;cursor:pointer;transition:transform .2s;border:1px solid var(--c-hairline)}.review-photo:hover{transform:scale(1.05)}.photo-modal{position:fixed;inset:0;background:#000000f2;z-index:calc(var(--z-modal) + 10);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;touch-action:pan-y}.photo-modal.visible{opacity:1}.photo-modal.hidden{display:none}.photo-modal-content{max-width:90vw;max-height:90vh;display:flex;align-items:center;justify-content:center;position:relative}.photo-modal-content img,.photo-modal-content video{max-width:100%;max-height:90vh;object-fit:contain;user-select:none;-webkit-user-select:none}.photo-modal-content video.hidden{display:none}.photo-modal-close{position:absolute;top:20px;right:20px;background:#fff3;border:none;border-radius:50%;width:44px;height:44px;font-size:32px;line-height:1;color:var(--c-white);cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;transition:background .2s}.photo-modal-close:hover{background:#ffffff4d}.photo-modal-prev,.photo-modal-next{position:absolute;top:50%;transform:translateY(-50%);background:#fff3;border:none;border-radius:50%;width:44px;height:44px;font-size:40px;line-height:1;color:var(--c-white);cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;transition:background .2s}.photo-modal-prev{left:20px}.photo-modal-next{right:20px}.photo-modal-prev:hover,.photo-modal-next:hover{background:#ffffff4d}.photo-modal-prev:disabled,.photo-modal-next:disabled{opacity:.3;cursor:not-allowed}.photo-modal-counter{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:#0009;color:var(--c-white);padding:8px 16px;border-radius:20px;font-size:14px;z-index:10}@media(max-width:768px){.photo-modal-prev,.photo-modal-next{width:36px;height:36px;font-size:32px}.photo-modal-prev{left:10px}.photo-modal-next{right:10px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.elevation-toggle-btn{background:none;border:none;cursor:pointer;padding:8px;width:29px;height:29px;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.elevation-toggle-btn:hover{background-color:#0000000d}.elevation-toggle-btn.active{background-color:#02863233}.elevation-icon{font-size:16px;line-height:1}.prediction-modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;z-index:var(--z-modal);display:flex;justify-content:center;align-items:center;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.prediction-modal.visible{opacity:1;visibility:visible}.prediction-modal-content{background-color:var(--c-white);width:95%;max-width:800px;height:90vh;max-height:800px;border-radius:12px;display:flex;flex-direction:column;box-shadow:0 4px 20px #0003;overflow:hidden}.prediction-header{padding:16px;border-bottom:1px solid var(--c-gray-200);display:flex;justify-content:space-between;align-items:center}.prediction-header h2{font-size:1.25rem;margin:0;color:var(--c-text)}.prediction-close-btn{background:none;border:none;font-size:2rem;line-height:1;color:var(--c-gray-500);cursor:pointer;padding:0 8px}.prediction-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.prediction-description{font-size:.9rem;color:var(--c-gray-500);margin:0;line-height:1.5}.prediction-controls{display:flex;flex-direction:column;gap:12px;background-color:var(--c-gray-100);padding:12px;border-radius:8px}.control-row{display:flex;gap:16px;flex-wrap:wrap}.control-group{display:flex;flex-direction:column;gap:6px}.control-group.full-width{width:100%}.control-group label{font-size:.8rem;font-weight:700;color:var(--c-gray-500)}.annotation{font-weight:400;font-size:.75rem;color:var(--c-red);margin-left:4px}.toggle-group{display:flex;background-color:var(--c-white);border:1px solid var(--c-gray-300);border-radius:4px;overflow:hidden}.toggle-btn{padding:6px 12px;border:none;background:none;font-size:.85rem;cursor:pointer;flex:1;white-space:nowrap;transition:background-color .2s,color .2s;color:var(--c-text)}.toggle-btn.active{background-color:var(--c-green-200);color:var(--c-white)}.toggle-btn:not(:last-child){border-right:1px solid var(--c-gray-300)}.control-description{margin:-4px 0 12px;font-size:.8rem;color:var(--c-gray-500);line-height:1.4}.scenario-toggles{display:flex;flex-wrap:wrap;gap:8px}.scenario-btn{padding:8px 12px;border:1px solid var(--c-gray-400);background-color:var(--c-white);border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.scenario-btn.active{background-color:var(--c-green-200);color:var(--c-white);border-color:var(--c-green-200)}.scenario-details-accordion{margin-top:12px}.accordion-toggle{width:100%;padding:10px 12px;background-color:var(--c-gray-100);border:1px solid var(--c-gray-300);border-radius:6px;font-size:.85rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all .2s;font-family:var(--f-default);color:var(--c-text)}.accordion-toggle:hover{background-color:var(--c-gray-200)}.accordion-icon{font-size:.7rem;transition:transform .2s}.accordion-content{max-height:0;overflow:hidden;transition:max-height .3s ease-out}.accordion-content.open{max-height:800px;transition:max-height .3s ease-in}.scenario-detail-item{padding:12px;border-bottom:1px solid var(--c-gray-200)}.scenario-detail-item:last-child{border-bottom:none}.scenario-detail-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.scenario-detail-name{font-size:.85rem;color:var(--c-black)}.scenario-detail-description{font-size:.8rem;line-height:1.5;color:var(--c-gray-500)}.chart-container{flex:1;min-height:300px;position:relative;width:100%}#ipcc-chart{width:100%;height:100%;min-height:300px}.prediction-footer{margin-top:auto;border-top:1px solid var(--c-gray-200);padding-top:12px;font-size:.75rem;color:var(--c-gray-500);display:flex;flex-direction:column;gap:4px}.footer-item{display:flex;gap:6px}.footer-item .label{font-weight:700;min-width:60px}.maplibregl-ctrl-prediction{background-color:var(--c-white);border-radius:4px;box-shadow:0 0 0 2px #0000001a;margin:10px;cursor:pointer;overflow:hidden}.prediction-open-btn{width:30px;height:30px;border:none;background:none;display:flex;justify-content:center;align-items:center;cursor:pointer;color:var(--c-black)}.prediction-open-btn svg{width:20px;height:20px}@media(max-width:600px){.prediction-modal-content{width:100%;height:100%;max-height:100%;border-radius:0}.control-row{flex-direction:column;gap:12px}}.elevation-legend{position:absolute;bottom:30px;right:10px;background:var(--c-white);padding:12px;border-radius:8px;box-shadow:0 2px 8px #00000026;z-index:100;font-size:12px;min-width:100px}.elevation-legend-title{font-weight:700;margin-bottom:8px;color:var(--c-black);font-size:13px;text-align:center}.elevation-legend-item{display:flex;align-items:center;gap:8px;margin-bottom:4px}.elevation-legend-item:last-child{margin-bottom:0}.elevation-legend-color{width:24px;height:16px;border-radius:3px;border:1px solid var(--c-gray-300);flex-shrink:0}.elevation-legend-label{color:var(--c-text);font-size:12px;white-space:nowrap}@media(min-width:768px){.elevation-legend{bottom:40px;right:20px}}.poi-list-container{position:fixed;bottom:0;left:0;width:100%;height:180px;background:var(--c-white);border-top:1px solid var(--c-hairline);box-shadow:0 -2px 8px #0000001a;z-index:var(--z-fixed);overflow:hidden;display:flex;flex-direction:column;transition:left .3s cubic-bezier(.4,0,.2,1),width .3s cubic-bezier(.4,0,.2,1)}.poi-list-header{padding:12px 16px 8px;border-bottom:1px solid var(--c-hairline);flex-shrink:0}.poi-list-title{margin:0;font-size:16px;font-weight:600;color:var(--c-text);font-family:var(--f-default)}.poi-list-scroll{display:flex;gap:12px;padding:12px 16px;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x proximity;scrollbar-width:thin;scrollbar-color:var(--c-gray-300) var(--c-gray-100);flex:1;align-items:center}.poi-list-scroll::-webkit-scrollbar{height:6px}.poi-list-scroll::-webkit-scrollbar-track{background:var(--c-gray-100);border-radius:3px}.poi-list-scroll::-webkit-scrollbar-thumb{background:var(--c-gray-300);border-radius:3px}.poi-list-scroll::-webkit-scrollbar-thumb:hover{background:var(--c-gray-400)}.poi-thumbnail{flex-shrink:0;width:100px;height:116px;background:var(--c-gray-100);border-radius:8px;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s;scroll-snap-align:start;border:2px solid transparent}.poi-thumbnail:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000026;border-color:var(--c-green-200)}.poi-thumbnail.active{border-color:var(--c-green-200);box-shadow:0 4px 12px #0286324d}.poi-thumbnail-image{width:100%;height:70px;object-fit:cover;background:var(--c-gray-200);display:flex;align-items:center;justify-content:center;color:var(--c-gray-400);font-size:24px}.poi-thumbnail-image img{width:100%;height:100%;object-fit:cover}.poi-thumbnail-info{padding:8px;height:46px;display:flex;flex-direction:column;justify-content:center}.poi-thumbnail-name{font-size:12px;font-weight:600;color:var(--c-text);line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:2px}.poi-thumbnail-category{font-size:10px;color:var(--c-gray-500);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.poi-panel.visible~.poi-list-container{bottom:0}.mobile-footer{display:none}@media(min-width:768px){.mobile-footer{display:flex;position:fixed;bottom:0;left:0;right:0;height:60px;background:var(--c-white);border-top:1px solid var(--c-hairline);box-shadow:0 -2px 8px #0000001a;z-index:var(--z-fixed);align-items:center;justify-content:center;padding:0 20px;transition:left .3s cubic-bezier(.4,0,.2,1),width .3s cubic-bezier(.4,0,.2,1)}body:has(.poi-panel.visible) #map{left:400px;width:calc(100% - 400px)}body:has(.poi-panel.visible) .mobile-footer{left:400px;width:calc(100% - 400px)}body:has(.poi-panel.visible) .poi-list-container{left:400px;width:calc(100% - 400px)}}@media(max-width:600px){.mobile-footer{display:flex;position:fixed;bottom:0;left:0;right:0;height:60px;background:var(--c-white);border-top:1px solid var(--c-hairline);box-shadow:0 -2px 8px #0000001a;z-index:var(--z-fixed);align-items:center;justify-content:center;padding:0 20px}.footer-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:none;border:none;padding:8px 16px;cursor:pointer;transition:opacity .2s}.footer-btn:active{opacity:.7}.footer-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px}.footer-icon svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}.footer-label{font-size:12px;color:var(--c-text);font-weight:500}.poi-list-container{display:none}}.poi-list-panel{display:none}@media(max-width:600px){.poi-list-panel{display:flex;position:fixed;left:0;right:0;bottom:0;background:var(--c-white);border-radius:16px 16px 0 0;box-shadow:0 -4px 20px #00000026;z-index:calc(var(--z-modal) - 1);transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);max-height:85vh;flex-direction:column}.poi-list-panel.visible{transform:translateY(0)}.poi-list-panel.hidden{display:none}.poi-list-panel.dragging{transition:none}.poi-list-panel-handle{width:40px;height:4px;background:var(--c-gray-300);border-radius:2px;margin:12px auto 8px;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;flex-shrink:0}.poi-list-panel-handle:active{cursor:grabbing}.poi-list-panel-content{display:flex;flex-direction:column;flex:1;overflow:hidden}.poi-list-panel-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px 12px;border-bottom:1px solid var(--c-hairline);flex-shrink:0}.poi-list-panel-title{margin:0;font-size:18px;font-weight:600;color:var(--c-text);font-family:var(--f-default)}.poi-list-panel-close{background:var(--c-gray-200);border:none;border-radius:50%;width:32px;height:32px;font-size:24px;line-height:1;cursor:pointer;color:var(--c-gray-500);display:flex;align-items:center;justify-content:center;transition:background .2s}.poi-list-panel-close:active{background:var(--c-gray-300)}.poi-list-panel-scroll{overflow-y:auto;padding:16px;flex:1;display:grid;grid-template-columns:repeat(2,1fr);gap:16px;-webkit-overflow-scrolling:touch}.poi-list-panel-scroll .poi-thumbnail{width:100%;height:180px;margin:0}.poi-list-panel-scroll .poi-thumbnail-image{height:120px;font-size:32px}.poi-list-panel-scroll .poi-thumbnail-info{padding:12px;height:60px}.poi-list-panel-scroll .poi-thumbnail-name{font-size:14px;font-weight:600;margin-bottom:4px}.poi-list-panel-scroll .poi-thumbnail-category{font-size:12px}}.layer-panel{display:none;position:fixed;left:0;right:0;bottom:0;background:var(--c-white);border-radius:16px 16px 0 0;box-shadow:0 -4px 20px #00000026;z-index:var(--z-modal);transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);max-height:85vh;flex-direction:column}.layer-panel.visible{transform:translateY(0);display:flex}.layer-panel.hidden{display:none}.layer-panel-handle{width:40px;height:4px;background:var(--c-gray-300);border-radius:2px;margin:12px auto 8px;flex-shrink:0}.layer-panel-content{display:flex;flex-direction:column;flex:1;padding:0 20px 20px}.layer-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-shrink:0}.layer-panel-title{margin:0;font-size:18px;font-weight:600;color:var(--c-text);font-family:var(--f-default)}.layer-panel-close{background:var(--c-gray-200);border:none;border-radius:50%;width:32px;height:32px;font-size:24px;line-height:1;cursor:pointer;color:var(--c-gray-500);display:flex;align-items:center;justify-content:center;transition:background .2s}.layer-panel-close:hover{background:var(--c-gray-300)}.layer-list{display:flex;flex-direction:column;gap:16px}.layer-item{display:flex;align-items:center;gap:16px;padding:8px 0;border-bottom:1px solid var(--c-gray-100)}.layer-item:last-child{border-bottom:none}.layer-name{font-size:16px;font-weight:500;color:var(--c-text)}.layer-switch{position:relative;display:inline-block;width:50px;height:28px;flex-shrink:0}.layer-switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:var(--c-gray-300);transition:.4s;border-radius:34px}.slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%;box-shadow:0 2px 4px #0003}input:checked+.slider{background-color:var(--c-green-200)}input:focus+.slider{box-shadow:0 0 1px var(--c-green-200)}input:checked+.slider:before{transform:translate(22px)}@media(min-width:768px){.layer-panel{left:auto;right:20px;bottom:80px;width:320px;border-radius:12px;transform:translateY(20px);opacity:0;transition:opacity .3s,transform .3s;box-shadow:0 4px 20px #0003}.layer-panel.visible{transform:translateY(0);opacity:1}.layer-panel-handle{display:none}}.photo-modal-info{position:absolute;bottom:0;left:0;right:0;background:#0009;padding:16px 20px 40px;color:var(--c-white);z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:opacity .3s}.photo-modal-info.hidden{display:none}.photo-modal-counter{bottom:20px;transition:bottom .3s}.photo-modal:has(.photo-modal-info:not(.hidden)) .photo-modal-counter{bottom:auto;top:20px;left:50%;transform:translate(-50%)}.photo-info-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.photo-user-name{font-weight:700;font-size:15px;text-shadow:0 1px 2px rgba(0,0,0,.8)}.photo-rating{display:flex;gap:2px;color:var(--c-yellow);font-size:14px}.photo-comment-wrapper{position:relative}.photo-comment{font-size:14px;line-height:1.5;margin:0;text-shadow:0 1px 2px rgba(0,0,0,.8);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.photo-comment.expanded{-webkit-line-clamp:unset;overflow:visible}.photo-comment-more{background:none;border:none;color:var(--c-white);font-size:12px;padding:4px 0;margin-top:4px;cursor:pointer;text-decoration:underline;opacity:.8}.photo-comment-more:hover{opacity:1}.photo-comment-more.hidden{display:none}@media(min-width:768px){.photo-modal-info{padding:20px 40px;max-width:600px;left:50%;transform:translate(-50%);bottom:20px;border-radius:12px}.photo-modal:has(.photo-modal-info:not(.hidden)) .photo-modal-counter{top:20px}}.layer-toggle-control{background:#fff;padding:8px 10px;min-width:150px;box-shadow:0 0 0 2px #0000001a;border-radius:4px}.layer-toggle-title{font-weight:700;font-size:12px;color:var(--c-gray-500);margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--c-gray-300)}.layer-toggle-item{display:flex;align-items:center;padding:4px 0;gap:8px}.layer-toggle-item input[type=checkbox]{cursor:pointer;width:16px;height:16px;margin:0;accent-color:var(--c-cyan-200)}.layer-toggle-item label{cursor:pointer;font-size:13px;color:var(--c-text);margin:0;-webkit-user-select:none;user-select:none}.layer-toggle-item:hover label{color:var(--c-cyan-200)}body.plain-mode #map{height:100%!important;width:100%!important;left:0!important;top:0!important}body.plain-mode .page-loader,body.plain-mode .map-logo,body.plain-mode .mobile-footer,body.plain-mode .poi-list-container,body.plain-mode .poi-list-panel,body.plain-mode .poi-panel,body.plain-mode .layer-panel,body.plain-mode .photo-modal,body.plain-mode .review-post-modal,body.plain-mode .prediction-modal,body.plain-mode .weather-panel,body.plain-mode .maplibregl-ctrl-top-left,body.plain-mode .maplibregl-ctrl-top-right,body.plain-mode .maplibregl-ctrl-bottom-left,body.plain-mode .maplibregl-ctrl-bottom-right{display:none!important}.weather-panel{position:fixed;left:0;right:0;bottom:0;background:var(--c-white);border-radius:16px 16px 0 0;box-shadow:0 -4px 20px #00000026;z-index:var(--z-modal);transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);max-height:85vh;display:flex;flex-direction:column}.weather-panel.visible{transform:translateY(0)}.weather-panel.hidden{display:none}@media(min-width:768px){.weather-panel{inset:0 0 0 auto;width:400px;height:100%;max-height:none;border-radius:0;box-shadow:-4px 0 20px #00000026;transform:translate(100%)}.weather-panel.visible{transform:translate(0)}.weather-panel-handle{display:none}}.weather-panel-handle{width:40px;height:4px;background:var(--c-gray-300);border-radius:2px;margin:12px auto 8px;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;flex-shrink:0}.weather-panel-content{overflow-y:auto;padding:0 20px 20px;flex:1}.weather-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-top:8px}.weather-title{font-size:20px;font-weight:700;margin:0;color:var(--c-text)}.weather-close-btn{background:var(--c-gray-200);border:none;border-radius:50%;width:32px;height:32px;font-size:24px;line-height:1;cursor:pointer;color:var(--c-gray-500);display:flex;align-items:center;justify-content:center;transition:background .2s}.weather-close-btn:hover{background:var(--c-gray-300)}.weather-current{text-align:center;margin-bottom:30px;padding:20px;background:linear-gradient(135deg,var(--c-cyan-100),var(--c-white));border-radius:12px}.weather-icon-large{font-size:64px;margin-bottom:10px;color:var(--c-gold)}.weather-temp{margin-bottom:8px}.temp-val{font-size:48px;font-weight:700;color:var(--c-text)}.temp-unit{font-size:24px;color:var(--c-gray-500);margin-left:4px}.weather-desc{font-size:16px;color:var(--c-gray-500)}.weather-forecast{margin-bottom:30px}.weather-forecast h3,.weather-radar h3{font-size:16px;font-weight:700;margin-bottom:12px;color:var(--c-text);border-left:4px solid var(--c-green-200);padding-left:8px}.forecast-list{display:flex;justify-content:space-between;gap:8px}.forecast-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px;background:var(--c-gray-100);border-radius:8px;flex:1}.forecast-day{font-size:12px;font-weight:700;color:var(--c-gray-500)}.forecast-icon{font-size:24px}.forecast-temp{font-size:12px;color:var(--c-text)}.weather-radar{margin-bottom:30px}.radar-placeholder{width:100%;height:200px;background:var(--c-gray-200);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--c-gray-500);font-size:14px;border:2px dashed var(--c-gray-300)}.weather-footer{font-size:11px;color:var(--c-gray-400);text-align:center;margin-top:auto}.weather-control{background-color:var(--c-white);border-radius:4px;box-shadow:0 0 0 2px #0000001a;margin:10px;cursor:pointer;overflow:hidden}.weather-toggle-btn{width:30px;height:30px;border:none;background:none;display:flex;justify-content:center;align-items:center;cursor:pointer;color:var(--c-black);padding:0}.weather-icon{font-size:20px;color:var(--c-gold)}
