:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0;min-width:320px;min-height:100vh;width:100vw;height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.user-avatar-container{position:relative;display:flex;align-items:center;height:36px}.login-btn{background:#fff3;color:#24292e;border:1px solid rgba(255,255,255,.3);border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;height:36px;display:flex;align-items:center;justify-content:center}.login-btn:hover{background:#ffffff4d;border-color:#fff6}.avatar-btn{background:none;border:none;cursor:pointer;padding:0;border-radius:50%;overflow:hidden;transition:all .2s ease;display:flex;align-items:center;justify-content:center;height:36px;width:36px}.avatar-btn:hover{transform:scale(1.05);box-shadow:0 2px 8px #00000026}.avatar-img{width:32px;height:32px;border-radius:50%;object-fit:cover;display:block}.avatar-placeholder{width:32px;height:32px;border-radius:50%;background:#667eea;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.user-menu{position:absolute;top:100%;right:0;margin-top:8px;background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:8px;box-shadow:0 8px 24px #0000001f;min-width:200px;z-index:1001;overflow:hidden}.user-info{padding:16px;border-bottom:1px solid #f0f0f0}.user-name{font-weight:600;color:#24292e;font-size:14px;margin-bottom:2px}.user-username{color:#586069;font-size:12px}.menu-divider{height:1px;background:#e1e5e9}.menu-items{padding:8px 0}.menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 16px;border:none;background:none;color:#24292e;font-size:14px;text-decoration:none;cursor:pointer;transition:background-color .2s ease}.menu-item:hover{background:#f6f8fa}.logout-item{color:#d73a49}.logout-item:hover{background:#ffeef0}.menu-icon{flex-shrink:0;opacity:.7}@media (max-width: 768px){.user-menu{right:-8px;min-width:180px}.avatar-img,.avatar-placeholder{width:28px;height:28px}.avatar-placeholder{font-size:12px}}.search-box{position:relative;width:100%;max-width:400px}.search-input-container{position:relative;display:flex;align-items:center;background-color:#0000000d;border-radius:6px;padding:0 10px;height:36px;transition:all .2s ease}.search-input-container:focus-within{background-color:#0000001a}.search-icon{color:#666;margin-right:8px;flex-shrink:0}.search-input{width:100%;flex:1;border:none;outline:none;background:transparent;font-size:14px;color:#333;padding:0}.search-input::placeholder{color:#999}.clear-button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:none;color:#666;cursor:pointer;border-radius:50%;margin-left:8px;padding:0;transition:all .2s ease;flex-shrink:0}.clear-button:hover{background:#0000001a;color:#333}.loading-spinner{display:flex;align-items:center;justify-content:center;width:28px;height:28px;margin-left:8px;padding:0;flex-shrink:0}.spinner{color:#1976d2;animation:spin 1s linear infinite}.search-results{position:absolute;top:100%;left:0;right:0;margin-top:8px;background:#fffffff2;border:1px solid rgba(255,255,255,.2);border-radius:12px;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);max-height:400px;overflow-y:auto;z-index:1002}.search-error{display:flex;align-items:center;gap:8px;padding:16px;color:#d32f2f;font-size:14px}.no-results{display:flex;align-items:center;gap:12px;padding:20px;color:#666}.no-results svg,.no-results .lucide{opacity:.5;flex-shrink:0}.no-results-title{font-size:14px;font-weight:500;margin-bottom:2px}.no-results-subtitle{font-size:12px;opacity:.7}.results-list{padding:4px 0}.result-item{display:flex;align-items:flex-start;gap:12px;width:100%;padding:12px 16px;border:none;background:none;text-align:left;cursor:pointer;transition:background-color .2s ease;border-radius:0}.result-item:hover,.result-item.selected{background:#0000000d}.result-item.selected{background:#1976d21a}.result-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#00000014;border-radius:50%;flex-shrink:0;margin-top:2px;padding:0}.result-item.selected .result-icon{background:#1976d2;color:#fff}.result-content{flex:1;min-width:0}.result-name{font-size:14px;font-weight:500;color:#333;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-address{font-size:12px;color:#666;line-height:1.4;margin-bottom:2px;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.result-distance{font-size:11px;color:#1976d2;font-weight:500}.result-favorite-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:#bbb;cursor:pointer;border-radius:6px;flex-shrink:0;margin-top:2px;transition:all .15s ease}.result-favorite-btn:hover{background:#1976d214;color:#1976d2}@media (max-width: 768px){.search-box{max-width:none}.search-input-container{height:36px;padding:0 10px}.search-input{font-size:14px}.search-results{max-height:300px}.result-item{padding:10px 12px}.result-icon{width:28px;height:28px}}.search-results::-webkit-scrollbar{width:6px}.search-results::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.search-results::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.search-results::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.app-header{position:fixed;top:5px;left:10px;right:10px;height:60px;border-radius:12px;background:#fffc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:1000;box-shadow:0 2px 20px #0000001a}.header-content{display:flex;align-items:center;justify-content:space-between;height:100%;padding:0 16px;margin:0 auto;gap:20px}.header-left{display:flex;align-items:center;flex:1;max-width:400px}.app-title{font-size:18px;font-weight:600;color:#24292e;margin:0}.header-right{display:flex;flex:none;align-items:center;gap:16px}.background-selector{position:relative;display:inline-block}.background-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 12px;background:#0000000d;border-radius:6px;color:#24292e;font-size:14px;cursor:pointer;transition:all .2s ease;min-width:100px;height:36px}.background-btn:hover{background:#0000001a}.background-preview{font-size:16px;line-height:1}.background-text{font-weight:500}.dropdown-arrow{transition:transform .2s ease;opacity:.7}.dropdown-arrow.open{transform:rotate(180deg)}.background-menu{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border:1px solid #d1d9e0;border-radius:8px;box-shadow:0 8px 24px #0000001f;min-width:220px;max-width:280px;z-index:1001;overflow:hidden}.background-menu-header{padding:12px 16px;background:#f6f8fa;border-bottom:1px solid #e1e5e9;font-size:12px;font-weight:600;color:#586069;text-transform:uppercase;letter-spacing:.5px}.background-category{border-bottom:1px solid #f0f0f0}.background-category:last-child{border-bottom:none}.category-title{padding:8px 16px 4px;font-size:11px;font-weight:600;color:#586069;text-transform:uppercase;letter-spacing:.5px;background:#f8f9fa}.background-options{padding:0px 0 px}.background-option{display:flex;align-items:center;gap:12px;width:100%;padding:10px 16px;border:none;background:none;color:#24292e;font-size:14px;cursor:pointer;transition:background-color .2s ease;text-align:left;border-radius:0}.background-option:hover{background:#f6f8fa}.background-option.active{background:#e3f2fd;color:#1976d2}.option-preview{font-size:18px;line-height:1;flex-shrink:0}.option-name{flex:1;font-weight:500}.check-icon{flex-shrink:0;color:#1976d2}@media (max-width: 768px){.header-content{padding:0 16px}.app-title{font-size:16px}.background-btn{padding:6px 10px;min-width:80px}.background-menu{right:-8px;min-width:180px}.header-right{gap:12px}}@media (max-width: 480px){.header-content{padding:0 12px}.background-btn{padding:6px 8px;min-width:60px}.background-preview{font-size:14px}}.location-info-card{position:fixed;bottom:10px;left:10px;right:10px;border-radius:12px;background:#fffc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);z-index:1001;box-shadow:0 2px 20px #0000001a;overflow:hidden}@media (min-width: 768px){.location-info-card{width:380px;left:10px;right:auto}}.card-content{padding:12px;display:flex;flex-direction:column;gap:8px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.location-name{font-size:18px;font-weight:600;color:#24292e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2;margin:0;flex:1;padding-right:12px}.card-header-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.navigation-button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:#4caf5014;color:#4caf50;cursor:pointer;border-radius:6px;transition:all .15s ease;flex-shrink:0;padding:0;text-decoration:none}.navigation-button:hover{background:#4caf502e;transform:scale(1.05)}.navigation-button:active{transform:scale(.95)}.navigation-button svg{width:16px;height:16px;display:block}.favorite-button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:#1976d214;color:#1976d2;cursor:pointer;border-radius:6px;transition:all .15s ease;flex-shrink:0;padding:0}.favorite-button:hover{background:#1976d22e;transform:scale(1.05)}.favorite-button:active{transform:scale(.95)}.favorite-button.favorited{background:#4caf501f;color:#4caf50}.favorite-button.favorited:hover{background:#f443361f;color:#f44336}.favorite-button svg{width:16px;height:16px;display:block}.close-button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:#0000000d;color:#24292e;cursor:pointer;border-radius:6px;transition:all .2s ease;flex-shrink:0;padding:0}.close-button:hover{background:#0000001a}.close-button:active{transform:scale(.95)}.close-button svg{width:16px;height:16px;display:block}.tags-section{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:4px}.location-tag{display:inline-block;font-size:12px;font-weight:500;color:#1976d2;background:#1976d21a;padding:4px 8px;border-radius:6px;border:1px solid rgba(25,118,210,.2)}.coordinates-section{display:flex;flex-direction:row;align-items:center;gap:12px}.coordinates-header{display:flex;flex:none;flex-direction:row;justify-content:flex-start;align-items:center;gap:8px}.coordinates-title{font-size:13px;font-weight:600;color:#24292e;text-transform:uppercase;letter-spacing:.5px}.coordinate-system-badge{font-size:10px;font-weight:500;color:#059669;background:#0596691a;padding:2px 6px;border-radius:4px;border:1px solid rgba(5,150,105,.2);text-transform:uppercase;letter-spacing:.3px}.coordinates-values{display:flex;flex-direction:row;align-items:center;gap:10px}.coordinate-item{display:flex;flex-direction:row;align-items:center;gap:2px}.coordinate-label{flex:none;font-size:11px;font-weight:600;color:#586069;text-transform:uppercase;letter-spacing:.5px}.coordinate-value{flex:none;font-size:14px;font-weight:500;color:#24292e;font-family:Monaco,Menlo,Ubuntu Mono,monospace}@media (max-width: 768px){.card-content{padding:12px;gap:8px}.location-name{font-size:16px}}@media (max-width: 480px){.card-content{padding:12px}.location-name{font-size:15px}}.place-item{display:flex;align-items:flex-start;gap:8px;width:100%;padding:10px 12px;border:none;background:transparent;cursor:pointer;text-align:left;transition:background .15s ease;border-bottom:1px solid rgba(0,0,0,.06)}.place-item:hover{background:#0000000a}.place-item:last-child{border-bottom:none}.place-item-icon{flex-shrink:0;color:#1976d2;margin-top:2px}.place-item-content{flex:1;min-width:0}.place-item-name{font-size:13px;font-weight:500;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.place-item-address{font-size:11px;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.place-item-coords{font-size:10px;color:#aaa;font-family:Courier New,monospace}.place-item-delete{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;color:#bbb;cursor:pointer;border-radius:4px;transition:all .15s ease;margin-top:2px}.place-item-delete:hover{background:#f443361a;color:#f44336}.favorites-bookmark-bar{position:fixed;top:70px;left:10px;right:10px;z-index:999;display:flex;align-items:center;min-height:38px;border-radius:12px;background:#fffc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 2px 20px #0000001a;padding:4px 10px}.bookmark-bar-inner{display:flex;align-items:center;gap:2px;flex-wrap:wrap}.bookmark-bar-empty{font-size:12px;color:#999;padding:4px 0}.bookmark-dropdown-container{position:relative;display:inline-flex;align-items:center;gap:2px}.render-toggle{width:10px;height:10px;border-radius:50%;border:1.5px solid #c0c0c0;background:transparent;cursor:pointer;flex-shrink:0;padding:0;margin:0 3px;transition:all .18s ease;outline:none}.render-toggle:hover{border-color:#1976d2;transform:scale(1.25)}.render-toggle.active{border-color:#1976d2;background:#1976d2;box-shadow:0 0 0 2px #1976d233}.render-toggle.active:hover{border-color:#1565c0;background:#1565c0}.bookmark-trigger{display:inline-flex;align-items:center;gap:4px;padding:0 10px;height:28px;border:none;border-radius:6px;background:transparent;color:#555;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .15s ease;-webkit-user-select:none;user-select:none}.bookmark-trigger:hover{background:#0000000f;color:#24292e}.bookmark-trigger.active{background:#1976d21a;color:#1976d2}.bookmark-trigger-label{max-width:120px;overflow:hidden;text-overflow:ellipsis}.bookmark-arrow{flex-shrink:0;display:block;transition:transform .2s ease;opacity:.6;margin-top:1px}.bookmark-arrow.open{transform:rotate(180deg)}.bookmark-dropdown{position:absolute;top:100%;left:0;margin-top:6px;min-width:260px;max-width:320px;max-height:50vh;overflow-y:auto;background:#fffffff7;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(0,0,0,.08);border-radius:10px;box-shadow:0 8px 28px #00000024;z-index:1001;animation:bookmarkDropdownIn .18s ease-out}@keyframes bookmarkDropdownIn{0%{opacity:0;transform:translateY(-4px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.bookmark-dropdown-loading{display:flex;align-items:center;justify-content:center;padding:20px;font-size:13px;color:#999}.bookmark-dropdown-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:24px 16px;color:#bbb;font-size:13px}.bookmark-dropdown .place-item{border-bottom:1px solid rgba(0,0,0,.04)}.bookmark-dropdown .place-item:last-child{border-bottom:none}.bookmark-dropdown::-webkit-scrollbar{width:5px}.bookmark-dropdown::-webkit-scrollbar-track{background:transparent}.bookmark-dropdown::-webkit-scrollbar-thumb{background:#d1d1d1;border-radius:3px}.bookmark-dropdown::-webkit-scrollbar-thumb:hover{background:#b1b1b1}@media (max-width: 768px){.favorites-bookmark-bar{padding:3px 10px}.bookmark-trigger{padding:0 8px;height:26px;font-size:11px}.bookmark-trigger-label{max-width:80px}.bookmark-dropdown{min-width:200px;max-width:260px;max-height:40vh}}@media (max-width: 480px){.bookmark-trigger{padding:0 6px;height:24px;font-size:10px}.bookmark-trigger-label{max-width:64px}.bookmark-dropdown{min-width:180px;max-width:220px}}.add-dialog-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.add-dialog{position:relative;width:380px;max-width:90vw;background:#fff;border-radius:14px;box-shadow:0 8px 32px #0000002e;overflow:hidden;animation:dialogSlideUp .2s ease-out}@keyframes dialogSlideUp{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.add-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 8px}.add-dialog-header h3{margin:0;font-size:16px;font-weight:600;color:#1a1a1a}.add-dialog-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:#999;cursor:pointer;border-radius:6px;transition:all .1s ease}.add-dialog-close:hover{background:#0000000d;color:#333}.add-dialog-body{padding:12px 20px;display:flex;flex-direction:column;gap:14px}.add-dialog-field{display:flex;flex-direction:column;gap:4px}.add-dialog-field label{font-size:12px;font-weight:500;color:#666}.add-dialog-input{padding:8px 12px;border:1px solid rgba(0,0,0,.15);border-radius:8px;font-size:13px;outline:none;transition:border-color .15s ease;color:#1a1a1a;background:#fff}.add-dialog-input:focus{border-color:#1976d2;box-shadow:0 0 0 2px #1976d21a}.add-dialog-select{padding:8px 12px;border:1px solid rgba(0,0,0,.15);border-radius:8px;font-size:13px;background:#fff;color:#1a1a1a;outline:none;cursor:pointer}.add-dialog-select:focus{border-color:#1976d2}.add-dialog-readonly{padding:8px 12px;background:#00000008;border-radius:8px;font-size:12px;color:#777;word-break:break-all}.add-dialog-readonly.mono{font-family:Courier New,monospace;font-size:12px}.add-dialog-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:1px solid rgba(0,0,0,.06)}.add-dialog-cancel{padding:8px 18px;border:1px solid rgba(0,0,0,.12);border-radius:8px;background:#fff;font-size:13px;color:#666;cursor:pointer;transition:all .1s ease}.add-dialog-cancel:hover{background:#00000008}.add-dialog-submit{padding:8px 20px;border:none;border-radius:8px;background:#1976d2;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:all .1s ease}.add-dialog-submit:hover:not(:disabled){background:#1565c0}.add-dialog-submit:disabled{opacity:.5;cursor:not-allowed}.add-dialog-toast{position:absolute;bottom:80px;left:50%;transform:translate(-50%);padding:6px 20px;border-radius:20px;font-size:13px;font-weight:500;animation:toastIn .2s ease;white-space:nowrap}.add-dialog-toast.success{background:#4caf50;color:#fff}.add-dialog-toast.error{background:#f44336;color:#fff}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.map-context-menu{position:fixed;z-index:1500;min-width:180px;background:#fff;border-radius:10px;box-shadow:0 4px 24px #0000002e;overflow:hidden;animation:contextMenuFadeIn .12s ease-out}@keyframes contextMenuFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.map-context-menu-location{display:flex;align-items:flex-start;gap:8px;padding:10px 12px}.map-context-menu-location>svg{color:#1976d2;margin-top:2px;flex-shrink:0}.map-context-menu-coords{min-width:0}.map-context-menu-name{font-size:13px;font-weight:500;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.map-context-menu-lat-lng{font-size:10px;color:#999;font-family:Courier New,monospace;margin-top:2px}.map-context-menu-divider{height:1px;background:#0000000f;margin:0 12px}.map-context-menu-action{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;border:none;background:transparent;color:#1976d2;cursor:pointer;font-size:13px;transition:background .1s ease}.map-context-menu-action:hover{background:#1976d20f}.iv-overlay{position:fixed;inset:0;background:#000000eb;z-index:2000;display:flex;flex-direction:column;align-items:center;justify-content:center;animation:iv-fade-in .2s ease}@keyframes iv-fade-in{0%{opacity:0}to{opacity:1}}.iv-header{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:center;padding:12px 16px;gap:12px;background:linear-gradient(rgba(0,0,0,.6),transparent);z-index:10}.iv-counter{font-size:14px;color:#fffc;font-variant-numeric:tabular-nums}.iv-title{font-size:14px;color:#ffffffe6;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.iv-close-btn{position:absolute;right:12px;display:flex;align-items:center;justify-content:center;width:40px;height:40px;min-width:40px;min-height:40px;padding:0!important;border:none;background:#ffffff26;color:#fff;border-radius:50%;cursor:pointer;line-height:1;transition:background .15s}.iv-close-btn:hover{background:#ffffff4d}.iv-nav{position:absolute;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:48px;height:48px;min-width:48px;min-height:48px;padding:0!important;border:none;background:#ffffff1f;color:#fff;border-radius:50%;cursor:pointer;z-index:10;line-height:1;transition:background .15s}.iv-nav:hover{background:#ffffff40}.iv-nav-prev{left:16px}.iv-nav-next{right:16px}@media (max-width: 768px){.iv-nav{display:none}}.iv-image-container{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%;padding:60px 80px 80px;box-sizing:border-box}@media (max-width: 768px){.iv-image-container{padding:50px 16px 80px}}.iv-image{max-width:100%;max-height:100%;object-fit:contain;opacity:0;transition:opacity .3s;user-select:none;-webkit-user-select:none;-webkit-user-drag:none}.iv-image.iv-loaded{opacity:1}.iv-loading{position:absolute;display:flex;align-items:center;justify-content:center}.iv-spinner{color:#fff9;animation:iv-spin .8s linear infinite}@keyframes iv-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.iv-thumbnails{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;gap:8px;padding:6px 12px;background:#00000080;border-radius:10px;overflow-x:auto;max-width:90vw;z-index:10}.iv-thumbnail{width:48px;height:36px;border-radius:4px;overflow:hidden;cursor:pointer;opacity:.5;border:2px solid transparent;transition:opacity .15s,border-color .15s;flex-shrink:0}.iv-thumbnail img{width:100%;height:100%;object-fit:cover}.iv-thumbnail:hover{opacity:.8}.iv-thumbnail-active{opacity:1;border-color:#fff}.skypixel-drawer{position:fixed;bottom:10px;left:10px;right:10px;display:flex;flex-direction:column;max-height:70vh;border-radius:14px;background:#ffffffd1;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.3);box-shadow:0 4px 32px #0000001f,0 1px 4px #0000000f;z-index:1001;overflow:hidden;animation:skypixel-card-in .28s ease-out}@keyframes skypixel-card-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media (min-width: 769px){.skypixel-drawer{width:500px;right:auto;max-height:82vh}}@media (max-width: 480px){.skypixel-drawer{max-height:62vh;border-radius:14px}}.skypixel-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid rgba(0,0,0,.06);flex-shrink:0;gap:10px}.skypixel-drawer-title{font-size:17px;font-weight:600;color:#24292e;margin:0;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}.skypixel-drawer-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;min-width:32px;min-height:32px;padding:0!important;border:none;background:#0000000d;border-radius:8px;cursor:pointer;color:#555;flex-shrink:0;line-height:1;transition:background .15s,color .15s}.skypixel-drawer-close:hover{background:#0000001f;color:#111}.skypixel-drawer-close:active{transform:scale(.95)}.skypixel-drawer-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 14px 16px;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.12) transparent}.skypixel-drawer-content::-webkit-scrollbar{width:4px}.skypixel-drawer-content::-webkit-scrollbar-track{background:transparent}.skypixel-drawer-content::-webkit-scrollbar-thumb{background:#0000001f;border-radius:10px}.skypixel-drawer-content::-webkit-scrollbar-thumb:hover{background:#00000038}.skypixel-drawer-loading,.skypixel-drawer-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 0;color:#999;gap:12px}.skypixel-drawer-error button{padding:8px 16px;border:1px solid #ddd;border-radius:6px;background:#f9f9f9;color:#24292e;cursor:pointer;font-size:14px}.skypixel-spinner{animation:skypixel-spin 1s linear infinite;color:#1976d2}@keyframes skypixel-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.skypixel-cover{border-radius:10px;overflow:hidden;margin-bottom:12px;cursor:pointer}.skypixel-cover img{width:100%;height:180px;object-fit:cover;display:block;transition:transform .2s}.skypixel-cover img:hover{transform:scale(1.02)}.skypixel-info-section{margin-bottom:12px}.skypixel-info-row{display:flex;align-items:flex-start;gap:6px;font-size:13px;color:#666;margin-bottom:6px;line-height:1.4}.skypixel-info-row svg{flex-shrink:0;margin-top:1px;color:#999}.skypixel-stats{display:flex;gap:16px;flex-wrap:wrap}.skypixel-stat{display:flex;align-items:center;gap:4px;font-size:13px;color:#888}.skypixel-stat svg{color:#bbb}.skypixel-owner-section{display:flex;align-items:center;gap:10px;padding:10px 0;border-top:1px solid rgba(0,0,0,.05);border-bottom:1px solid rgba(0,0,0,.05);margin-bottom:12px}.skypixel-owner-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover}.skypixel-owner-name{font-size:14px;font-weight:500;color:#333}.skypixel-works-info{font-size:13px;color:#888;margin-bottom:10px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.skypixel-work-type-tag{font-size:12px}.skypixel-section-title{font-size:14px;font-weight:600;color:#24292e;margin:0 0 8px}.skypixel-works-section{margin-bottom:16px}.skypixel-works-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.skypixel-work-item{aspect-ratio:4 / 3;border-radius:8px;overflow:hidden;cursor:pointer;position:relative;background:#f0f0f0}.skypixel-work-item img{width:100%;height:100%;object-fit:cover;transition:transform .2s}.skypixel-work-item:hover img{transform:scale(1.05)}.skypixel-work-overlay{position:absolute;bottom:0;left:0;right:0;padding:4px 6px;background:linear-gradient(transparent,#0009);opacity:0;transition:opacity .2s}.skypixel-work-item:hover .skypixel-work-overlay,.skypixel-work-item:active .skypixel-work-overlay{opacity:1}.skypixel-work-stats{display:flex;gap:8px;color:#fff;font-size:11px}.skypixel-work-stats span{display:flex;align-items:center;gap:2px}.skypixel-load-more{display:block;width:100%;padding:10px;margin-top:10px;border:1px solid #e5e5e5;border-radius:8px;background:#fafafa;font-size:13px;color:#666;cursor:pointer;transition:background .15s}.skypixel-load-more:hover:not(:disabled){background:#f0f0f0}.skypixel-load-more:disabled{opacity:.5;cursor:not-allowed}.skypixel-evaluations-section{margin-bottom:8px}.skypixel-evaluation-item{padding:8px 0;border-bottom:1px solid rgba(0,0,0,.04)}.skypixel-evaluation-item:last-child{border-bottom:none}.skypixel-evaluation-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.skypixel-evaluation-avatar{width:22px;height:22px;border-radius:50%;object-fit:cover}.skypixel-evaluation-user{font-size:13px;font-weight:500;color:#333;flex:1}.skypixel-evaluation-score{display:flex;align-items:center;gap:2px;font-size:12px;color:#f59e0b;font-weight:600}.skypixel-evaluation-content{font-size:13px;color:#555;line-height:1.5;margin:4px 0 0;white-space:pre-line}.skypixel-evaluation-meta{display:flex;align-items:center;gap:8px}.skypixel-evaluation-likes{display:flex;align-items:center;gap:2px;font-size:12px;color:#e57373}.skypixel-evaluation-sp-title{font-size:14px;font-weight:600;color:#f57c00;margin:4px 0 2px}.skypixel-evaluation-images{display:flex;gap:6px;margin-top:8px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:2px}.skypixel-evaluation-images::-webkit-scrollbar{display:none}.skypixel-evaluation-thumb{width:72px;height:54px;border-radius:6px;object-fit:cover;cursor:pointer;flex-shrink:0;border:1px solid #eee;transition:transform .15s;align-self:flex-start}.skypixel-evaluation-thumb:hover{transform:scale(1.05)}.skypixel-evaluation-footer{margin-top:4px}.skypixel-evaluation-date{font-size:11px;color:#bbb}.home-page{width:100vw;height:100vh;margin:0;padding:0;overflow:hidden;position:relative;display:flex;flex-direction:column}.main-content{flex:1;position:relative}.map-container{width:100%;height:100%;position:relative}.map{width:100%;height:100%}.map-controls{position:absolute;top:10px;right:10px;z-index:1000;background:#fffffff2;padding:15px;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:200px;max-width:280px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.map-controls-header{font-size:16px;font-weight:700;color:#333;margin-bottom:12px;text-align:center;border-bottom:1px solid #e0e0e0;padding-bottom:8px}.map-category{margin-bottom:15px}.map-category:last-child{margin-bottom:0}.category-buttons{display:flex;flex-direction:column;gap:4px}.map-controls button{padding:8px 12px;border:none;border-radius:4px;background:#f5f5f5;color:#333;cursor:pointer;font-size:12px;transition:all .2s ease;text-align:left;border:1px solid transparent}.map-controls button:hover{background:#e8f4f8;border-color:#007cba;transform:translateY(-1px)}.map-controls button.active{background:#007cba;color:#fff;border-color:#005a87;box-shadow:0 2px 4px #007cba4d}.map-controls button.active:hover{background:#005a87;transform:translateY(-1px)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000001a;padding:40px;width:100%;max-width:400px;text-align:center}.login-header h1{color:#333;margin:0 0 8px;font-size:28px;font-weight:600}.login-header p{color:#666;margin:0 0 32px;font-size:16px}.login-content{margin-bottom:32px}.github-login-btn{width:100%;background:#24292e;color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:16px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;transition:all .2s ease}.github-login-btn:hover{background:#1a1e22;transform:translateY(-1px);box-shadow:0 4px 12px #24292e4d}.github-login-btn:active{transform:translateY(0)}.github-icon{flex-shrink:0}.login-footer p{color:#888;font-size:12px;line-height:1.4;margin:0}.loading{color:#666;font-size:16px;padding:20px}@media (max-width: 480px){.login-container{padding:16px}.login-card{padding:32px 24px}.login-header h1{font-size:24px}}.profile-container{min-height:100vh;background:#f8f9fa}.profile-card{max-width:800px;margin:0 auto;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.profile-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:40px;display:flex;align-items:center;gap:24px}.avatar-section{flex-shrink:0}.profile-avatar{width:80px;height:80px;border-radius:50%;border:3px solid rgba(255,255,255,.2);object-fit:cover}.profile-avatar-placeholder{width:80px;height:80px;border-radius:50%;border:3px solid rgba(255,255,255,.2);background:#fff3;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:600}.user-details{flex:1}.user-name{margin:0 0 8px;font-size:28px;font-weight:600}.user-username{margin:0 0 4px;font-size:16px;opacity:.9}.user-email{margin:0;font-size:14px;opacity:.8}.profile-content{padding:40px}.info-section{margin-bottom:40px}.info-section h2{margin:0 0 24px;font-size:20px;font-weight:600;color:#24292e}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.info-item{display:flex;flex-direction:column;gap:4px}.info-item label{font-size:12px;font-weight:600;color:#586069;text-transform:uppercase;letter-spacing:.5px}.info-item span{font-size:14px;color:#24292e;padding:8px 0;border-bottom:1px solid #e1e5e9}.actions-section h2{margin:0 0 20px;font-size:20px;font-weight:600;color:#24292e}.action-buttons{display:flex;gap:12px;flex-wrap:wrap}.action-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:6px;font-size:14px;font-weight:500;text-decoration:none;cursor:pointer;transition:all .2s ease;border:1px solid}.action-btn.primary{background:#24292e;color:#fff;border-color:#24292e}.action-btn.primary:hover{background:#1a1e22;border-color:#1a1e22}.action-btn.secondary{background:#fff;color:#24292e;border-color:#d0d7de}.action-btn.secondary:hover{background:#f6f8fa;border-color:#bbb}.btn-icon{flex-shrink:0}@media (max-width: 768px){.profile-container{padding:16px}.profile-header{padding:24px;flex-direction:column;text-align:center;gap:16px}.profile-avatar,.profile-avatar-placeholder{width:64px;height:64px}.profile-avatar-placeholder,.user-name{font-size:24px}.profile-content{padding:24px}.info-grid{grid-template-columns:1fr;gap:16px}.action-buttons{flex-direction:column}.action-btn{justify-content:center}}.auth-status{text-align:center;padding:2rem}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #0366d6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.success-icon{width:60px;height:60px;background-color:#28a745;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;margin:0 auto 1rem}.error-icon{width:60px;height:60px;background-color:#dc3545;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;margin:0 auto 1rem}.auth-status h2{margin:1rem 0;color:#333}.auth-status p{color:#666;margin-bottom:1.5rem}.auth-status.success h2{color:#28a745}.auth-status.error h2{color:#dc3545}#root{width:100%;height:100%}*{margin:0;padding:0;outline:none}
