.geography-viewer{position:fixed;right:20px;top:120px;width:380px;max-height:calc(100vh - 140px);background:linear-gradient(135deg,#1e3c72,#2a5298);border-radius:16px;box-shadow:0 20px 60px #00000080;overflow-y:auto;z-index:1000;animation:slideIn .4s cubic-bezier(.4,0,.2,1);color:#fff}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.viewer-header{position:sticky;top:0;background:#0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:20px;border-bottom:2px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;z-index:10}.viewer-header h2{margin:0;font-size:22px;font-weight:700;display:flex;align-items:center;gap:10px}.region-icon{font-size:28px}.close-btn{background:#fff3;border:none;color:#fff;width:36px;height:36px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.close-btn:hover{background:#ffffff4d;transform:scale(1.1)}.elevation-section{padding:20px;background:#ffffff0d}.elevation-section h3{margin:0 0 15px;font-size:18px;font-weight:600}.elevation-chart{background:#ffffff1a;border-radius:8px;padding:10px;margin-bottom:15px}.elevation-stats{display:flex;flex-direction:column;gap:10px}.stat-card{background:#ffffff1a;border-radius:10px;padding:12px 15px;display:flex;align-items:center;gap:12px;transition:all .3s ease;border-left:4px solid}.stat-card.highest{border-color:#ff6b6b}.stat-card.lowest{border-color:#4ecdc4}.stat-card.average{border-color:#ffe66d}.stat-card:hover{background:#ffffff26;transform:translate(5px)}.stat-icon{font-size:28px}.stat-label{margin:0;font-size:12px;opacity:.8;text-transform:uppercase;letter-spacing:.5px}.stat-value{margin:4px 0 0;font-size:14px;font-weight:600}.stat-number{margin:2px 0 0;font-size:20px;font-weight:700;color:gold}.info-section{padding:20px;display:flex;flex-direction:column;gap:12px}.info-card{background:#ffffff14;border-radius:10px;padding:15px;border:1px solid rgba(255,255,255,.1)}.info-card h4{margin:0 0 8px;font-size:14px;font-weight:600;opacity:.9}.info-card p{margin:0;font-size:14px;line-height:1.5}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:0 20px 20px}.mini-stat{background:#ffffff1a;border-radius:10px;padding:15px;display:flex;flex-direction:column;align-items:center;gap:6px;transition:all .3s ease}.mini-stat:hover{background:#ffffff26;transform:translateY(-3px)}.mini-icon{font-size:32px}.mini-value{font-size:24px;font-weight:700;color:gold}.mini-label{font-size:12px;opacity:.8}.features-section{padding:20px;background:#0003}.features-section h3{margin:0 0 15px;font-size:18px;font-weight:600}.features-list{display:flex;flex-direction:column;gap:10px}.feature-item{background:#ffffff14;border-radius:8px;padding:12px;display:flex;align-items:center;gap:12px;transition:all .3s ease;border:1px solid rgba(255,255,255,.1)}.feature-item.famous{background:linear-gradient(135deg,#ffd70033,#ffffff1a);border-color:gold}.feature-item:hover{background:#ffffff1f;transform:translate(5px)}.feature-icon{font-size:28px;min-width:28px}.feature-info{flex:1}.feature-name{margin:0 0 4px;font-size:15px;font-weight:600;display:flex;align-items:center;gap:6px}.famous-badge{font-size:16px;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}}.feature-details{margin:0;font-size:12px;opacity:.8;display:flex;align-items:center;gap:6px}.feature-type{text-transform:capitalize;background:#fff3;padding:2px 8px;border-radius:4px;font-size:11px}.separator{opacity:.5}.feature-height{font-weight:600;color:gold}.feature-status{padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}.feature-status.active{background:#ff6b6b4d;color:#ff6b6b}.feature-status.dormant{background:#4ecdc44d;color:#4ecdc4}.map-3d-section{padding:20px;background:#0006}.map-3d-section h3{margin:0 0 15px;font-size:18px;font-weight:600}.terrain-controls{display:flex;gap:15px;margin-bottom:15px;padding:15px;background:#ffffff0d;border-radius:8px;flex-wrap:wrap}.terrain-controls .control-group{display:flex;align-items:center;gap:8px}.terrain-controls label{font-size:13px;font-weight:600;opacity:.9;white-space:nowrap}.mode-selector,.season-selector{padding:6px 12px;background:#ffffff26;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.mode-selector:hover,.season-selector:hover{background:#ffffff40;border-color:#fff6}.mode-selector:focus,.season-selector:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 2px #4a90e24d}.mode-selector option,.season-selector option{background:#1e3c72;color:#fff}.map-3d-container{position:relative;width:100%;border-radius:12px;overflow:hidden;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:10px}.terrain-info{margin-top:15px;text-align:center}.terrain-stats{display:flex;justify-content:center;align-items:center;gap:10px;margin-bottom:8px;background:#ffffff1a;padding:10px 20px;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.peak-indicator{font-size:16px;font-weight:600;color:gold}.peak-height{font-size:18px;font-weight:700;color:#fff}.map-3d-viewer{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.map-layers{position:relative;width:200px;height:200px;transform-style:preserve-3d;animation:rotate3d 20s infinite linear;cursor:grab}.map-layers:active{cursor:grabbing;animation-play-state:paused}@keyframes rotate3d{0%{transform:rotateX(60deg) rotate(0)}to{transform:rotateX(60deg) rotate(360deg)}}.layer{position:absolute;width:100%;height:100%;border-radius:12px;border:2px solid rgba(255,255,255,.2);transform-style:preserve-3d;box-shadow:0 10px 30px #00000080}.base-layer{background:linear-gradient(135deg,#2d5a8c,#1e3a5f);transform:translateZ(0)}.elevation-layer{opacity:0;animation:layerRise .6s ease-out forwards;transition:transform .3s ease}@keyframes layerRise{0%{opacity:0;transform:translateZ(0) scale(1)}to{opacity:.9;transform:translateZ(var(--layer-height, 8px)) scale(var(--layer-scale, .95))}}.peak-layer{background:linear-gradient(135deg,#fff,#e0e0e0);transform:translateZ(48px) scale(.75);animation:peakGlow 2s ease-in-out infinite;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}@keyframes peakGlow{0%,to{box-shadow:0 0 20px #ffffff80,0 10px 30px #00000080}50%{box-shadow:0 0 40px #fffc,0 10px 30px #00000080}}.peak-marker{font-size:32px;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.peak-label{font-size:14px;font-weight:700;color:#333;background:#ffffffe6;padding:4px 12px;border-radius:12px;box-shadow:0 2px 8px #0003}.rotation-hint{position:absolute;bottom:20px;left:50%;transform:translate(-50%);font-size:12px;color:#fff9;background:#00000080;padding:6px 12px;border-radius:20px;pointer-events:none}.visual-3d{padding:20px;background:#0000004d}.terrain-visual{display:flex;align-items:flex-end;justify-content:space-around;height:120px;gap:2px;padding:10px;background:#ffffff0d;border-radius:10px;perspective:1000px}.terrain-bar{flex:1;min-width:8px;border-radius:4px 4px 0 0;opacity:0;animation:barRise .6s ease-out forwards;transform-style:preserve-3d;box-shadow:0 -4px 8px #0000004d;position:relative}.terrain-bar:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,#ffffff4d,#fff0);border-radius:4px 4px 0 0}@keyframes barRise{0%{opacity:0;transform:scaleY(0) rotateX(10deg)}to{opacity:1;transform:scaleY(1) rotateX(0)}}.no-data{padding:40px 20px;text-align:center}.no-data p{margin:0;font-size:16px;opacity:.7}.loading-content{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.loading-content p{margin-top:20px;font-size:16px;opacity:.8}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.2);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.geography-viewer::-webkit-scrollbar{width:8px}.geography-viewer::-webkit-scrollbar-track{background:#0003}.geography-viewer::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}.geography-viewer::-webkit-scrollbar-thumb:hover{background:#ffffff80}@media (max-width: 768px){.geography-viewer{right:10px;left:10px;width:auto;top:100px;max-height:calc(100vh - 120px)}.viewer-header h2{font-size:18px}.region-icon{font-size:24px}}.japan-map-container{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center;background:#f5f5f5}.japan-map-svg{background:#fff;border-radius:8px;box-shadow:0 4px 12px #0000001a}.zoom-background{cursor:grab;pointer-events:all}.zoom-background:active{cursor:grabbing}.prefecture{transition:opacity .2s cubic-bezier(.4,0,.2,1);stroke-linejoin:round;stroke-linecap:round;will-change:opacity}.prefecture:hover{opacity:.85;cursor:pointer;filter:brightness(1.1)}.prefecture:active{transform:scale(.98)}.prefecture-icon{font-size:24px;opacity:.95;text-shadow:0 1px 3px rgba(255,255,255,.9),0 0 6px rgba(255,255,255,.7),0 2px 4px rgba(0,0,0,.15);filter:drop-shadow(0 2px 3px rgba(0,0,0,.2));pointer-events:none!important;-webkit-user-select:none;user-select:none;will-change:transform,font-size;transform:translateZ(0);backface-visibility:hidden}.icons-group{pointer-events:none!important}.prefecture-tooltip h4{margin:0 0 4px;font-size:18px;font-weight:700;color:#4a90e2}.prefecture-tooltip .prefecture-ja{font-size:14px;color:#ccc;margin:0 0 8px;font-style:italic}.prefecture-tooltip p{margin:4px 0;font-size:13px}.prefecture-tooltip .no-data{color:#999;font-style:italic}@media (max-width: 1024px){.japan-map-svg{width:100%;height:auto}}.indonesia-map-container{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center;background:#f5f5f5}.indonesia-map-svg{background:#fff;border-radius:8px;box-shadow:0 4px 12px #0000001a;cursor:grab}.indonesia-map-svg:active{cursor:grabbing}.province{transition:all .3s cubic-bezier(.4,0,.2,1)}.province:hover{opacity:.9;cursor:pointer;transform:translateZ(10px)}.province:active{transform:scale(.98)}.city-marker{transition:r .2s ease;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.d3-tooltip{position:absolute;pointer-events:none;background:#000000e6;color:#fff;padding:12px 16px;border-radius:8px;font-size:14px;opacity:0;transition:opacity .2s ease;z-index:1000;box-shadow:0 4px 12px #0000004d;max-width:250px}.weather-tooltip h4{margin:0 0 8px;font-size:16px;font-weight:600;border-bottom:1px solid rgba(255,255,255,.3);padding-bottom:6px}.weather-tooltip p{margin:4px 0;font-size:13px;line-height:1.4}.province-tooltip h4{margin:0 0 4px;font-size:18px;font-weight:700;color:#4a90e2}.province-tooltip .province-id{font-size:14px;color:#ccc;margin:0 0 8px;font-style:italic}.province-tooltip p{margin:4px 0;font-size:13px}.province-tooltip .no-data{color:#999;font-style:italic}.reset-zoom-btn{position:absolute;bottom:90px;right:20px;padding:10px 16px;background:#4a90e2;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #4a90e266;z-index:100}.reset-zoom-btn:hover{background:#357abd;transform:translateY(-2px);box-shadow:0 4px 12px #4a90e299}.reset-zoom-btn:active{transform:translateY(0)}.temperature-legend{position:absolute;bottom:20px;right:20px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:15px;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:100}.temperature-legend h4{margin:0 0 10px;font-size:14px;font-weight:600;color:#333}.legend-gradient{display:flex;flex-direction:column;gap:6px}.legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:#666}.legend-color{width:30px;height:16px;border-radius:3px;border:1px solid rgba(0,0,0,.1)}.legend-item span{font-weight:500;min-width:45px}@media (max-width: 1200px){.indonesia-map-svg{width:100%;height:auto}}@media (max-width: 768px){.temperature-legend{bottom:10px;right:10px;padding:10px;font-size:12px}.temperature-legend h4{font-size:12px}.legend-item{font-size:11px}.legend-color{width:20px;height:12px}.reset-zoom-btn{bottom:180px;right:10px;padding:8px 12px;font-size:12px}}.d3-map-container{width:100%;height:100%;display:flex;flex-direction:column;background:#1a1a2e}.map-controls{display:flex;gap:20px;align-items:center;padding:15px 20px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.1);box-shadow:0 2px 8px #0000001a;flex-wrap:wrap}.control-group{display:flex;align-items:center;gap:10px}.control-group label{font-weight:600;color:#333;font-size:14px}.country-selector{padding:8px 12px;border:2px solid #e0e0e0;border-radius:6px;background:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:150px}.country-selector:hover{border-color:#4a90e2}.country-selector:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a}.toggle-label{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-checkbox{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:50px;height:26px;background:#ccc;border-radius:13px;position:relative;cursor:pointer;transition:background .3s ease}.toggle-checkbox:checked{background:#4a90e2}.toggle-checkbox:before{content:"";position:absolute;width:22px;height:22px;border-radius:50%;background:#fff;top:2px;left:2px;transition:transform .3s ease;box-shadow:0 2px 4px #0003}.toggle-checkbox:checked:before{transform:translate(24px)}.toggle-text{font-size:14px;font-weight:500;color:#333}.map-info{margin-left:auto}.info-text{font-size:14px;color:#666;font-weight:500}.map-canvas{flex:1;width:100%;position:relative;overflow:hidden;background:#f5f5f5}.map-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.map-placeholder p{color:#fff;font-size:24px;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.2)}@media (max-width: 768px){.map-controls{flex-direction:column;align-items:stretch;gap:12px}.control-group{width:100%;justify-content:space-between}.country-selector{flex:1;min-width:unset}.map-info{margin-left:0;text-align:center}}.App{width:100%;height:100vh;display:flex;flex-direction:column;overflow:hidden;background:#1a1a2e}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 30px;box-shadow:0 4px 12px #00000026;text-align:center}.app-header h1{margin:0;font-size:32px;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.2)}.app-header p{margin:8px 0 0;font-size:16px;opacity:.95;font-weight:400}.loading-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;color:#fff}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.2);border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container p{font-size:18px;font-weight:500;color:#ccc}.error-container{flex:1;display:flex;align-items:center;justify-content:center;padding:20px}.error-message{background:#ff4c4c33;color:#ff4c4c;padding:20px 30px;border-radius:8px;font-size:16px;font-weight:500;border:2px solid #ff4c4c}@media (max-width: 768px){.app-header h1{font-size:24px}.app-header p{font-size:14px}.app-header{padding:15px 20px}}*{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}#root{width:100vw;height:100vh;overflow:hidden}.leaflet-popup-content-wrapper{border-radius:8px;box-shadow:0 4px 12px #00000026}.leaflet-popup-content{margin:12px;min-width:200px}
