:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#050a14;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;padding:0;min-width:320px;min-height:100vh;overflow:hidden}#root{width:100vw;height:100vh}.app-layout{display:flex;width:100vw;height:100vh;overflow:hidden;background:#050a14;color:#e8eaf0;font-family:system-ui,sans-serif}.controls-panel{width:260px;min-width:220px;flex-shrink:0;background:#0a1223eb;border-right:1px solid rgba(80,140,220,.2);padding:20px 16px;display:flex;flex-direction:column;gap:20px;overflow-y:auto;z-index:10}.app-title{font-size:1.25rem;font-weight:700;margin:0;color:#7ec8f5;letter-spacing:.01em}.app-subtitle{font-size:.78rem;color:#7a8ca0;margin:-14px 0 0}.control-section{display:flex;flex-direction:column;gap:8px}.section-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#5a7a9a;margin:0}.category-buttons{display:flex;flex-direction:column;gap:6px}.category-btn{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#c8d8e8;padding:8px 12px;font-size:.875rem;cursor:pointer;text-align:left;transition:background .18s,border-color .18s,color .18s}.category-btn:hover{background:#ffffff1a;border-color:#ffffff40;color:#fff}.category-btn.active{background:color-mix(in srgb,var(--cat-color) 25%,transparent);border-color:var(--cat-color);color:#fff;font-weight:600}.upload-btn{display:inline-block;background:#64b4ff1a;border:1px solid rgba(100,180,255,.35);border-radius:6px;color:#7ec8f5;padding:7px 12px;font-size:.85rem;cursor:pointer;text-align:center;transition:background .18s}.upload-btn:hover{background:#64b4ff33}.hint-text{font-size:.72rem;color:#5a7a9a;line-height:1.5;margin:0}.hint-text code{background:#ffffff12;border-radius:3px;padding:1px 4px;font-size:.68rem;color:#90bfdf}.stats-text{font-size:.9rem;color:#c8d8e8;margin:0}.stat-number{font-size:1.3rem;font-weight:700;color:#7ec8f5}.globe-container{flex:1;position:relative;overflow:hidden}.loading-screen,.error-screen{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#7ec8f5;font-size:1rem}.spinner{width:40px;height:40px;border:3px solid rgba(126,200,245,.2);border-top-color:#7ec8f5;border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.legend-panel{width:200px;min-width:180px;flex-shrink:0;background:#0a1223eb;border-left:1px solid rgba(80,140,220,.2);padding:20px 14px;display:flex;flex-direction:column;gap:10px;z-index:10}.legend-title{font-size:.95rem;font-weight:700;color:#e8eaf0;margin:0}.legend-description{font-size:.72rem;color:#7a8ca0;line-height:1.5;margin:0}.legend-gradient-wrap{display:flex;flex-direction:column;gap:4px;margin-top:8px}.legend-gradient{height:14px;border-radius:7px}.legend-labels{display:flex;justify-content:space-between;font-size:.62rem;color:#5a7a9a}.legend-source{font-size:.65rem;color:#3a5a7a;margin:0;font-style:italic;line-height:1.4}@media(max-width:700px){.app-layout{flex-direction:column}.controls-panel{width:100%;min-width:unset;border-right:none;border-bottom:1px solid rgba(80,140,220,.2);flex-direction:row;flex-wrap:wrap;padding:10px 12px;gap:10px}.globe-container{min-height:50vh}.legend-panel{width:100%;min-width:unset;border-left:none;border-top:1px solid rgba(80,140,220,.2);flex-direction:row;flex-wrap:wrap;padding:10px 12px;gap:10px}}@keyframes slideIn{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}
