:root{--primary-color: #83dbff;--primary-gradient: linear-gradient(135deg, #83dbff 0%, #5ac8fa 100%);--accent-color: #4fd1c5;--text-main: #1e293b;--text-sub: #475569;--bg-color: #f8fafc;--glass-bg: rgba(255, 255, 255, .9);--glass-border: 1px solid rgba(255, 255, 255, .5);--shadow-sm: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--radius-lg: 24px;--radius-md: 16px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Noto Sans JP,sans-serif;color:var(--text-main);background:var(--bg-color);overflow:hidden;-webkit-tap-highlight-color:transparent}.landing-page{height:100vh;overflow-y:auto;padding:2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(circle at top right,#e0f2fe,#fdf4ff,#fff);padding-top:max(2rem,env(safe-area-inset-top));padding-bottom:max(2rem,env(safe-area-inset-bottom));padding-left:max(2rem,env(safe-area-inset-left));padding-right:max(2rem,env(safe-area-inset-right))}.landing-header{margin-bottom:3rem;text-align:center;animation:fadeInDown .8s ease-out}.landing-header h1{font-size:2.5rem;font-weight:800;background:var(--primary-gradient);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:1rem;letter-spacing:-.05em}.landing-header p{font-size:1.1rem;color:var(--text-sub)}.area-selection{display:flex;flex-direction:column;gap:2rem;width:100%;max-width:900px}@media (min-width: 768px){.area-selection{flex-direction:row}}.area-card{flex:1;background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xl);text-decoration:none;color:inherit;transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s;position:relative;isolation:isolate}.area-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 30px 60px -12px #83dbff59}.card-image{height:240px;background-color:#eee;background-size:cover;background-position:center;position:relative}.card-image:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,.2) 100%)}.yuzawa-bg{background:linear-gradient(45deg,#60a5fa,#3b82f6)}.myoko-bg{background:linear-gradient(45deg,#34d399,#10b981)}.card-content{padding:2rem;background:#fff}.card-content h2{font-size:1.8rem;font-weight:700;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.card-content p{color:var(--text-sub);line-height:1.6}#map-container{position:relative;width:100vw;height:100vh;height:100dvh;height:100svh;background:#cbd5e1;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}#map{width:100%;height:100%;z-index:1;background-color:#f1f5f9;background-image:radial-gradient(#cbd5e1 1px,transparent 1px);background-size:20px 20px;touch-action:pan-x pan-y}.back-button{position:absolute;bottom:calc(6em + env(safe-area-inset-bottom));left:calc(10px + env(safe-area-inset-left));z-index:1000;background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:10px 20px;text-decoration:none;font-weight:700;font-size:.9rem;color:var(--text-main);box-shadow:var(--shadow-sm);border:2px solid #168ab9;transition:transform .2s}.leaflet-marker-icon{filter:drop-shadow(0 4px 6px rgba(0,0,0,.3));transition:filter .2s}.custom-pin-icon{object-fit:contain;background:transparent}.leaflet-marker-icon:hover{filter:drop-shadow(0 8px 12px rgba(0,0,0,.4)) brightness(1.1);z-index:1000!important}.bottom-sheet{position:absolute;bottom:0;left:0;width:100%;max-height:85vh;background:#fff;border-radius:32px 32px 0 0;box-shadow:0 -10px 40px #0000001a;z-index:2000;transform:translateY(110%);transition:transform .4s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom)}@media (min-width: 768px){.bottom-sheet{width:500px;left:calc(40px + env(safe-area-inset-left));bottom:calc(40px + env(safe-area-inset-bottom));border-radius:32px;transform:translateY(40px);opacity:0;pointer-events:none;transition:all .4s cubic-bezier(.16,1,.3,1)}.bottom-sheet.active{opacity:1;transform:translateY(0);pointer-events:auto}}.bottom-sheet.active{transform:translateY(0)}.sheet-handle{width:48px;height:6px;background:#e2e8f0;border-radius:100px;margin:16px auto;flex-shrink:0}.sheet-content{padding:0 32px 40px;overflow-y:auto}.sheet-image{width:100%;aspect-ratio:4 / 3;border-radius:20px;background-size:cover;background-position:center;margin-bottom:24px;box-shadow:var(--shadow-sm)}.sheet-meta{display:flex;align-items:center;gap:12px;margin-bottom:12px}.badge{background:#eff6ff;color:#168ab9;padding:6px 12px;border-radius:8px;font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.sheet-content h2{font-size:1.8rem;font-weight:800;margin-bottom:12px;line-height:1.2}.sheet-content p{color:var(--text-sub);line-height:1.7;font-size:1.05rem;margin-bottom:2rem}.action-btn{display:block;width:100%;padding:16px;background:var(--primary-gradient);color:#fff;text-align:center;border-radius:16px;text-decoration:none;font-weight:700;font-size:1.1rem;box-shadow:0 8px 20px -4px #83dbff80;transition:transform .2s,box-shadow .2s}.action-btn:active{transform:scale(.98)}.close-btn{position:absolute;top:20px;right:20px;width:36px;height:36px;background:#f1f5f9;border-radius:50%;border:none;font-size:1.2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-sub);transition:background .2s}.close-btn:hover{background:#e2e8f0}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1500;opacity:0;pointer-events:none;transition:opacity .4s}.overlay.active{opacity:1;pointer-events:auto}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.facility-name-popup .leaflet-popup-content-wrapper{background:#fffffffa;padding:12px 16px;border-radius:12px;font-weight:600;box-shadow:0 4px 12px #00000026;border:2px solid var(--primary-color)}.facility-name-popup .leaflet-popup-tip{background:#fffffffa;border:2px solid var(--primary-color);border-top:none;border-right:none}.leaflet-control-container .leaflet-bottom{bottom:11em}.category-filter-wrapper{position:absolute;top:10px;left:20px;z-index:1000;display:flex;gap:8px;align-items:center;max-width:calc(100vw - 70px)}.filter-all-container{flex-shrink:0}.filter-scroll-container{position:relative;flex:1;overflow:hidden}.category-filter{display:flex;gap:8px;padding:5px;overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.category-filter::-webkit-scrollbar{display:none}.filter-scroll-container{padding:5px 5px 5px 0}.category-filter{-ms-overflow-style:none;scrollbar-width:none}.scroll-indicator{position:absolute;top:0;bottom:0;width:30px;pointer-events:none;opacity:0;transition:opacity .3s;z-index:10}.filter-scroll-container.scrollable-left .scroll-indicator-left,.filter-scroll-container.scrollable-right .scroll-indicator-right{opacity:1}.filter-btn{background:#fff;border:none;height:36px;padding:.5em 1em;border-radius:999px;font-family:Noto Sans JP,sans-serif;font-weight:600;font-size:.75rem;color:var(--text-sub);cursor:pointer;transition:all .3s;flex-shrink:0;box-shadow:0 0 5px #168ab9;display:flex;align-items:center;gap:5px}.filter-btn.active{background:var(--primary-gradient);color:#fff;box-shadow:0 4px 12px #83dbff66}.filter-btn img{width:20px;height:25px;object-fit:contain}@media (max-width: 768px){.category-filter-wrapper{top:auto;bottom:calc(20px + env(safe-area-inset-bottom));left:calc(10px + env(safe-area-inset-left));width:calc(100vw - env(safe-area-inset-left) - env(safe-area-inset-right));padding-right:5px;max-width:unset;gap:6px}.filter-scroll-container{flex:1}.scroll-indicator{width:20px}}.facility-header{font-size:1.1rem;font-weight:700;color:#168ab9;margin:0 0 1rem;text-align:center;border-bottom:2px solid #168ab9;padding-bottom:.5rem;padding-right:1.5rem}.event-navigation{display:flex;align-items:center;justify-content:center;gap:1rem;padding:0 0 1rem}.event-nav-btn{background:linear-gradient(135deg,#83dbff,#5ab9ff);border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;color:#fff;box-shadow:0 2px 8px #83dbff4d}.event-nav-btn:hover:not(:disabled){transform:scale(1.1);box-shadow:0 4px 12px #83dbff80}.event-nav-btn:active:not(:disabled){transform:scale(.95)}.event-nav-btn:disabled{opacity:.3;cursor:not-allowed}.event-indicator{display:flex;gap:.5rem;align-items:center}.event-dot{width:10px;height:10px;border-radius:50%;background-color:#83dbff4d;transition:all .3s ease}.event-dot.active{background-color:#83dbff;transform:scale(1.3);box-shadow:0 0 8px #83dbff99}@media (max-width: 768px){.event-nav-btn{width:36px;height:36px}.event-dot{width:8px;height:8px}.facility-header{font-size:1rem}}.direct-confirm-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;z-index:3000;display:none;align-items:center;justify-content:center}.direct-confirm-overlay.active{display:flex}.direct-confirm-dialog{background:#fff;border-radius:16px;padding:32px;max-width:450px;width:90%;box-shadow:0 20px 60px #0000004d;text-align:center;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.direct-confirm-title{font-size:1.3rem;font-weight:700;color:var(--text-main);margin-bottom:12px}.direct-confirm-message{font-size:1rem;color:var(--text-sub);margin-bottom:28px;line-height:1.6}.direct-confirm-buttons{display:flex;gap:12px;justify-content:center}.direct-confirm-btn{padding:14px 32px;border:none;border-radius:8px;font-family:Noto Sans JP,sans-serif;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s}.direct-confirm-btn-primary{background:var(--primary-gradient);color:#fff;box-shadow:0 4px 12px #83dbff66}.direct-confirm-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #83dbff80}.direct-confirm-btn-secondary{background:#f1f5f9;color:var(--text-main);border:2px solid #e2e8f0}.direct-confirm-btn-secondary:hover{background:#e2e8f0}@media (max-width: 768px){.direct-confirm-dialog{padding:24px;max-width:90%}.direct-confirm-title{font-size:1.1rem}.direct-confirm-message{font-size:.95rem}.direct-confirm-buttons{flex-direction:column}.direct-confirm-btn{width:100%}}.filter-btn{display:flex;align-items:center;justify-content:space-between}.filter-icon{width:32px;height:32px;object-fit:contain;margin-left:auto}.sheet-title-icon{width:40px;height:40px;object-fit:contain}@media (max-width: 768px){.filter-icon,.sheet-title-icon{width:40px;height:40px}}.draggable-pins-panel{position:fixed;bottom:20px;left:20px;background:#fffffff2;border-radius:12px;padding:16px 20px;box-shadow:0 4px 12px #00000026;z-index:9998;font-family:Noto Sans JP,sans-serif;min-width:280px}.draggable-pins-panel h3{margin:0 0 12px;font-size:16px;font-weight:700;color:#333;display:flex;align-items:center;gap:8px}.draggable-pins-counter{background:#4caf50;color:#fff;padding:4px 12px;border-radius:12px;font-size:14px;font-weight:700;margin-bottom:12px;text-align:center}.draggable-pins-counter.has-changes{background:#ff9800}.draggable-pins-buttons{display:flex;gap:8px;flex-direction:column}.draggable-pins-btn{padding:10px 16px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;font-family:Noto Sans JP,sans-serif}.draggable-pins-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.draggable-pins-btn:active{transform:translateY(0)}.draggable-pins-btn-primary{background:#2196f3;color:#fff}.draggable-pins-btn-primary:hover{background:#1976d2}.draggable-pins-btn-primary:disabled{background:#ccc;cursor:not-allowed}.draggable-pins-btn-secondary{background:#ff5722;color:#fff}.draggable-pins-btn-secondary:hover{background:#e64a19}.draggable-pins-btn-secondary:disabled{background:#ccc;cursor:not-allowed}.draggable-pins-btn-download{background:#4caf50;color:#fff}.draggable-pins-btn-download:hover{background:#45a049}.draggable-pins-message{margin-top:12px;padding:8px 12px;border-radius:6px;font-size:13px;text-align:center}.draggable-pins-message.success{background:#e8f5e9;color:#2e7d32;border:1px solid #A5D6A7}.draggable-pins-message.info{background:#e3f2fd;color:#1565c0;border:1px solid #90CAF9}.draggable-pins-message.warning{background:#fff3e0;color:#e65100;border:1px solid #FFCC80}.leaflet-marker-icon.draggable-pin{cursor:move!important}.leaflet-marker-icon.draggable-pin.changed{filter:drop-shadow(0 0 8px #FF9800)}.leaflet-marker-icon.dragging{opacity:.7;cursor:grabbing!important}@media (max-width: 768px){.draggable-pins-panel{left:10px;bottom:10px;min-width:250px;padding:12px 16px}.draggable-pins-panel h3{font-size:14px}.draggable-pins-btn{padding:8px 12px;font-size:13px}}
