.globe-container{width:100%;height:100%;position:relative;background:radial-gradient(ellipse at center,#0a1520,#000 70%)}.zoom-indicator{position:absolute;bottom:80px;right:20px;display:flex;flex-direction:column;gap:4px;background:#000000b3;padding:8px 12px;border-radius:6px;font-size:.75rem;color:var(--text-secondary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.zoom-level,.resolution-level{font-family:SF Mono,Monaco,Inconsolata,monospace}.hex-tooltip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#001428e6;color:var(--accent-glow);padding:12px 20px;border-radius:8px;font-size:1.1rem;text-align:center;pointer-events:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--accent-glow);box-shadow:0 0 20px #00d4ff4d;animation:tooltipPulse 2s ease-in-out infinite}.hex-tooltip small{display:block;margin-top:4px;font-size:.75rem;color:var(--text-secondary)}@keyframes tooltipPulse{0%,to{box-shadow:0 0 20px #00d4ff4d}50%{box-shadow:0 0 30px #00d4ff80}}.globe-instructions{position:absolute;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:1rem 1.5rem;background:linear-gradient(to bottom,rgba(0,0,0,.8) 0%,transparent 100%);pointer-events:none;font-size:.8rem;color:var(--text-secondary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);white-space:nowrap}.globe-controls{position:absolute;bottom:20px;left:20px;z-index:10}.unified-controls{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(5,1fr);gap:3px;width:99px;height:165px}.control-button{width:30px;height:30px;background:#ffffff1a;border:none;border-radius:4.5px;color:var(--text-primary);font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;-webkit-user-select:none;user-select:none}.control-button:hover{background:#fff3;transform:scale(1.05)}.control-button:active{transform:scale(.95);background:#ffffff26}.control-button.zoom-in{grid-column:2;grid-row:1;font-weight:700;font-size:1.125rem}.control-button.zoom-out{grid-column:2;grid-row:2;font-weight:700;font-size:1.125rem}.control-button.rotate-up{grid-column:2;grid-row:3;font-size:.975rem}.control-button.rotate-left{grid-column:1;grid-row:4;font-size:.975rem}.control-button.rotate-down{grid-column:2;grid-row:5;font-size:.975rem}.control-button.rotate-right{grid-column:3;grid-row:4;font-size:.975rem}@media (max-width: 600px){.zoom-indicator,.globe-instructions{display:none}.hex-tooltip{font-size:.95rem;padding:10px 16px}.globe-controls{display:none}.unified-controls{gap:2.25px;width:89px;height:148px}.control-button{width:27px;height:27px;font-size:.75rem}.control-button.zoom-in,.control-button.zoom-out{font-size:.975rem}}.thumbnail-strip-container{flex-shrink:0;padding:12px 20px 20px;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,transparent 100%)}.thumbnail-strip{display:flex;gap:8px;overflow-x:auto;overflow-y:hidden;padding:8px 0;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.thumbnail-strip::-webkit-scrollbar{height:4px}.thumbnail-strip::-webkit-scrollbar-track{background:transparent}.thumbnail-strip::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.thumbnail{flex-shrink:0;width:60px;height:60px;border:2px solid transparent;border-radius:6px;overflow:hidden;cursor:pointer;background:#ffffff0d;padding:0;position:relative;transition:border-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.thumbnail:hover{border-color:#fff6;transform:scale(1.05)}.thumbnail.active{border-color:var(--accent-glow);box-shadow:0 0 12px #00d4ff66;transform:scale(1.08)}.thumbnail img{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .3s ease}.thumbnail.loaded img{opacity:1}.thumbnail-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#ffffff0d,#ffffff05);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{opacity:.5}50%{opacity:1}to{opacity:.5}}@media (max-width: 768px){.thumbnail-strip-container{padding:8px 12px 16px}.thumbnail{width:50px;height:50px}.thumbnail-strip{gap:6px}}.gallery-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000000f2;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.gallery-close{position:absolute;top:16px;right:16px;z-index:1010;width:44px;height:44px;border:none;background:#ffffff1a;color:#fff;font-size:1.5rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),transform var(--transition-fast)}.gallery-close:hover{background:#fff3;transform:scale(1.1)}.gallery-header{padding:16px 70px;display:flex;align-items:center;justify-content:center;gap:20px;flex-shrink:0}.location-name{font-size:1.1rem;font-weight:400;color:var(--text-primary);letter-spacing:.02em}.photo-counter{color:var(--text-secondary);font-size:.9rem;font-family:SF Mono,monospace}.gallery-main{flex:1;display:flex;align-items:center;justify-content:center;min-height:0;position:relative;padding:0 60px}.nav-button{position:absolute;top:50%;transform:translateY(-50%);width:50px;height:80px;border:none;background:#ffffff0d;color:#fff;font-size:3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast);z-index:10}.nav-button:hover{background:#ffffff26}.nav-prev{left:0;border-radius:0 8px 8px 0}.nav-next{right:0;border-radius:8px 0 0 8px}.image-container{position:relative;max-width:100%;max-height:100%;display:flex;align-items:center;justify-content:center}.gallery-image{max-width:100%;max-height:calc(100vh - 200px);object-fit:contain;border-radius:4px;box-shadow:0 10px 40px #00000080;transition:opacity .3s ease}.gallery-image.loading{opacity:0}.gallery-image.loaded{opacity:1}.image-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.loading-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--accent-glow);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.photo-info{padding:12px 20px;display:flex;align-items:center;justify-content:center;gap:16px;flex-shrink:0}.photo-filename{color:var(--text-secondary);font-size:.85rem;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.photo-date{color:var(--text-secondary);font-size:.85rem}@media (max-width: 768px){.gallery-main{padding:0}.nav-button{width:40px;height:60px;font-size:2rem;background:transparent}.nav-prev{left:5px;border-radius:4px}.nav-next{right:5px;border-radius:4px}.gallery-image{max-height:calc(100vh - 180px)}.gallery-header{padding:12px 60px;flex-direction:column;gap:4px}.location-name{font-size:1rem}.photo-info{flex-direction:column;gap:4px;padding:8px 16px}}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:#000000e6;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.loading-content{display:flex;flex-direction:column;align-items:center;gap:24px}.globe-loader{position:relative;width:80px;height:80px}.globe-ring{position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid transparent;border-top-color:var(--accent-glow);border-radius:50%;animation:globeSpin 1.5s linear infinite}.globe-ring:nth-child(1){animation-delay:0s;opacity:1}.globe-ring:nth-child(2){top:8px;right:8px;bottom:8px;left:8px;border-top-color:#00d4ff99;animation-delay:.2s;animation-direction:reverse}.globe-ring:nth-child(3){top:16px;right:16px;bottom:16px;left:16px;border-top-color:#00d4ff4d;animation-delay:.4s}@keyframes globeSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text{color:var(--text-secondary);font-size:.9rem;letter-spacing:.05em;animation:textPulse 2s ease-in-out infinite}@keyframes textPulse{0%,to{opacity:.6}50%{opacity:1}}.app{width:100%;height:100%;position:relative;background:var(--bg-primary);overflow:hidden}.error-banner{position:absolute;top:80px;left:50%;transform:translate(-50%);z-index:200;background:#b43232e6;color:#fff;padding:.75rem 1.5rem;border-radius:8px;display:flex;align-items:center;gap:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.error-banner button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.4rem 1rem;border-radius:4px;cursor:pointer;transition:background var(--transition-fast)}.error-banner button:hover{background:#ffffff4d}:root{--bg-primary: #000000;--bg-secondary: #0a0a0a;--bg-overlay: rgba(0, 0, 0, .85);--text-primary: #ffffff;--text-secondary: #888888;--accent-glow: #00d4ff;--accent-warm: #ff6b35;--hex-base: #1a3a4a;--hex-active: #00d4ff;--transition-fast: .15s ease;--transition-normal: .3s ease}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow:hidden;background-color:var(--bg-primary);font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--text-secondary);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-primary)}button:focus-visible,a:focus-visible{outline:2px solid var(--accent-glow);outline-offset:2px}
