.header{background:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:100;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;height:56px;padding:0 16px;display:flex}.header-left{flex-shrink:0;align-items:center;gap:12px;display:flex}.header-brand{align-items:center;gap:8px;display:flex}.brand-icon{color:var(--color-primary)}.brand-name{letter-spacing:-.5px;background:linear-gradient(135deg, var(--color-primary), #a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:18px;font-weight:700}.header-center{flex:1;max-width:480px;margin:0 auto}.search-bar{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);height:36px;transition:border-color var(--transition-fast);align-items:center;padding:0 14px;display:flex}.search-bar:focus-within{border-color:var(--color-primary);box-shadow:var(--shadow-glow)}.search-icon{color:var(--color-text-muted);flex-shrink:0}.search-input{color:var(--color-text);background:0 0;border:none;flex:1;height:100%;padding:0 10px;font-size:14px}.search-input::placeholder{color:var(--color-text-muted)}.search-spinner{animation:1s linear infinite searchSpin}@keyframes searchSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.search-error{color:var(--color-danger,#ef4444);white-space:nowrap;flex-shrink:0;padding-right:2px;font-size:11px}.header-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.header-btn{color:var(--color-text-secondary);transition:color var(--transition-fast), background var(--transition-fast);background:0 0;align-items:center;gap:6px;font-size:14px;display:flex}.icon-btn{border-radius:var(--radius-md);justify-content:center;width:36px;height:36px}.icon-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.login-btn{border-radius:var(--radius-lg);background:var(--color-primary);color:#fff;padding:6px 16px;font-weight:500}.login-btn:hover{background:var(--color-primary-hover)}.user-menu-wrapper{position:relative}.user-avatar-btn{background:0 0;padding:0}.user-avatar{background:linear-gradient(135deg, var(--color-primary), #a78bfa);color:#fff;width:34px;height:34px;transition:box-shadow var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:flex}.user-avatar-btn:hover .user-avatar{box-shadow:var(--shadow-glow)}.user-menu{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);width:220px;box-shadow:var(--shadow-lg);z-index:200;animation:.15s menuSlide;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}@keyframes menuSlide{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.user-menu-header{flex-direction:column;gap:2px;padding:14px 16px;display:flex}.user-menu-name{font-size:14px;font-weight:600}.user-menu-email{color:var(--color-text-muted);font-size:12px}.user-menu-divider{background:var(--color-border);height:1px}.user-menu-item{width:100%;color:var(--color-text-secondary);transition:background var(--transition-fast), color var(--transition-fast);background:0 0;align-items:center;gap:10px;padding:10px 16px;font-size:14px;display:flex}.user-menu-item:hover{background:var(--color-surface-hover);color:var(--color-text)}@media (width<=768px){.header{height:48px;padding:0 8px;padding-top:var(--safe-top);gap:8px}.header-left{gap:8px}.brand-name{font-size:16px}.brand-icon{display:none}.header-center{max-width:none;margin:0}.search-bar{height:34px;padding:0 10px}.search-input{padding:0 8px;font-size:13px}.icon-btn{width:40px;min-width:40px;height:40px}.login-btn{padding:6px 12px;font-size:13px}.login-btn span{display:none}.user-menu{width:200px;right:-4px}}@media (width<=400px){.header-center{display:none}.header{justify-content:space-between}}.sidebar{background:var(--color-surface);border-right:1px solid var(--color-border);width:280px;transition:width var(--transition-normal), opacity var(--transition-normal);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.sidebar--closed{opacity:0;pointer-events:none;border-right:none;width:0}.sidebar-tabs{border-bottom:1px solid var(--color-border);padding:0;display:flex}.sidebar-tab{color:var(--color-text-muted);transition:all var(--transition-fast);white-space:nowrap;background:0 0;border-bottom:2px solid #0000;flex:1;justify-content:center;align-items:center;gap:5px;padding:10px 4px;font-size:11px;font-weight:500;display:flex}.sidebar-tab:hover{color:var(--color-text-secondary);background:var(--color-surface-hover)}.sidebar-tab--active{color:var(--color-primary-hover);border-bottom-color:var(--color-primary)}.sidebar-tab-count{background:var(--color-surface-active);min-width:16px;height:16px;color:var(--color-text-muted);border-radius:8px;justify-content:center;align-items:center;font-size:10px;display:flex}.sidebar-tab--active .sidebar-tab-count{background:var(--color-primary-muted);color:var(--color-primary-hover)}.sidebar-groups .sidebar-section-header{align-items:center;display:flex}.sidebar-group-add-btn{border-radius:var(--radius-sm);width:22px;height:22px;color:var(--color-text-muted);transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;margin-left:auto;display:flex}.sidebar-group-add-btn:hover{background:var(--color-surface-hover);color:var(--color-primary)}.favgroup-list{flex-wrap:wrap;gap:6px;display:flex}.favgroup-chip-wrap{position:relative}.favgroup-chip{border-radius:var(--radius-lg);background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-secondary);transition:all var(--transition-fast);white-space:nowrap;align-items:center;gap:5px;padding:5px 10px;font-size:12px;font-weight:500;display:flex;position:relative}.favgroup-chip:hover{border-color:var(--color-border-light);color:var(--color-text);background:var(--color-surface-hover)}.favgroup-chip--active{background:var(--color-primary-muted);border-color:var(--color-primary);color:var(--color-primary-hover)}.favgroup-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.favgroup-count{color:var(--color-text-muted);background:var(--color-surface-active);border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;font-size:10px;display:flex}.favgroup-chip-edit{border-radius:var(--radius-sm);width:18px;height:18px;color:var(--color-text-muted);background:0 0;justify-content:center;align-items:center;margin-left:2px;padding:0;display:none}.favgroup-chip:hover .favgroup-chip-edit{display:flex}.favgroup-chip-edit:hover{color:var(--color-text);background:var(--color-surface-active)}.favgroup-edit-row{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;gap:6px;width:100%;padding:8px;display:flex}.favgroup-edit-input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);width:100%;padding:5px 8px;font-size:12px}.favgroup-edit-input:focus{border-color:var(--color-primary);outline:none}.favgroup-color-row{flex-wrap:wrap;gap:4px;display:flex}.favgroup-color-dot{cursor:pointer;width:16px;height:16px;transition:all var(--transition-fast);border:2px solid #0000;border-radius:50%}.favgroup-color-dot:hover{transform:scale(1.2)}.favgroup-color-dot--active{box-shadow:0 0 0 1px var(--color-border-light);border-color:#fff}.favgroup-edit-actions{gap:4px;display:flex}.favgroup-edit-ok,.favgroup-edit-cancel,.favgroup-edit-delete{border-radius:var(--radius-sm);width:24px;height:24px;transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;display:flex}.favgroup-edit-ok{color:var(--color-primary)}.favgroup-edit-ok:hover{background:var(--color-primary-muted)}.favgroup-edit-cancel{color:var(--color-text-muted)}.favgroup-edit-cancel:hover{color:var(--color-text);background:var(--color-surface-hover)}.favgroup-edit-delete{color:var(--color-text-muted);margin-left:auto}.favgroup-edit-delete:hover{color:var(--color-danger);background:#ef44441f}.favgroup-create{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;gap:8px;margin-top:8px;padding:10px;display:flex}.favgroup-create-input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);padding:7px 10px;font-size:13px}.favgroup-create-input:focus{border-color:var(--color-primary);outline:none}.favgroup-create-input::placeholder{color:var(--color-text-muted)}.favgroup-create-actions{gap:6px;display:flex}.favgroup-create-ok{border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;transition:background var(--transition-fast);align-items:center;gap:4px;padding:5px 12px;font-size:12px;font-weight:600;display:flex}.favgroup-create-ok:hover{background:var(--color-primary-hover)}.favgroup-create-ok:disabled{opacity:.5}.favgroup-create-cancel{border-radius:var(--radius-sm);color:var(--color-text-muted);transition:color var(--transition-fast);background:0 0;padding:5px 10px;font-size:12px}.favgroup-create-cancel:hover{color:var(--color-text)}.sidebar-section{border-bottom:1px solid var(--color-border);padding:16px}.sidebar-section-header{text-transform:uppercase;letter-spacing:.8px;color:var(--color-text-muted);align-items:center;gap:6px;margin-bottom:10px;font-size:11px;font-weight:600;display:flex}.category-list{flex-wrap:wrap;gap:6px;display:flex}.category-chip{border-radius:var(--radius-lg);background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-secondary);transition:all var(--transition-fast);white-space:nowrap;align-items:center;gap:5px;padding:5px 10px;font-size:12px;font-weight:500;display:flex}.category-chip:hover{border-color:var(--color-border-light);color:var(--color-text);background:var(--color-surface-hover)}.category-chip--active{background:var(--color-primary-muted);border-color:var(--color-primary);color:var(--color-primary-hover)}.category-count{color:var(--color-text-muted);background:var(--color-surface-active);border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;font-size:10px;display:flex}.sidebar-spots-list{flex-direction:column;flex:1;display:flex;overflow:hidden}.spots-scroll{flex:1;padding:0 16px 16px;overflow-y:auto}.spot-list-item{border-radius:var(--radius-md);text-align:left;width:100%;color:var(--color-text);transition:background var(--transition-fast);background:0 0;align-items:center;gap:10px;margin-bottom:2px;padding:10px 12px;display:flex}.spot-list-item:hover{background:var(--color-surface-hover)}.spot-list-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.spot-list-info{flex-direction:column;flex:1;gap:1px;display:flex;overflow:hidden}.spot-list-title{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.spot-list-cat{color:var(--color-text-muted);align-items:center;gap:4px;font-size:11px;display:flex}.spot-list-lock{opacity:.6}.spot-list-rating{color:#f59e0b;flex-shrink:0;font-size:11px;font-weight:600}.sidebar-empty{text-align:center;color:var(--color-text-muted);padding:24px 16px;font-size:13px}.sidebar-footer{border-top:1px solid var(--color-border);padding:12px 16px}.add-spot-btn{border-radius:var(--radius-md);background:var(--color-primary);color:#fff;width:100%;transition:background var(--transition-fast), box-shadow var(--transition-fast);justify-content:center;align-items:center;gap:8px;padding:10px;font-size:14px;font-weight:600;display:flex}.add-spot-btn:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-glow)}@media (width<=768px){.sidebar{z-index:50;width:280px;height:100%;box-shadow:var(--shadow-lg);padding-left:var(--safe-left);position:absolute}.sidebar--open{animation:.25s sidebarSlideIn}@keyframes sidebarSlideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}.sidebar--closed{box-shadow:none;transform:translate(-100%)}.sidebar-tab{min-height:44px;padding:12px 4px;font-size:11px}.sidebar-section{padding:12px}.category-chip{min-height:36px;padding:8px 12px;font-size:13px}.spot-list-item{min-height:48px;padding:12px}.spots-scroll{padding:0 12px 12px}.sidebar-footer{padding:12px;padding-bottom:calc(12px + var(--safe-bottom))}.add-spot-btn{min-height:48px;padding:12px;font-size:15px}}.spot-marker{cursor:pointer;position:relative}.spot-marker-pin{background:var(--marker-color);width:28px;height:28px;transition:transform var(--transition-fast), box-shadow var(--transition-fast);border-radius:50% 50% 50% 0;justify-content:center;align-items:center;display:flex;transform:rotate(-45deg);box-shadow:0 2px 8px #0006}.spot-marker:hover .spot-marker-pin{transform:rotate(-45deg)scale(1.15);box-shadow:0 4px 16px #00000080}.spot-marker--selected .spot-marker-pin{transform:rotate(-45deg)scale(1.2);box-shadow:0 4px 16px #00000080,0 0 0 3px #fff6}.spot-marker-dot{background:#fff;border-radius:50%;width:10px;height:10px;transform:rotate(45deg)}.spot-marker-pulse{background:var(--marker-color);opacity:0;border-radius:50%;width:10px;height:10px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.spot-marker--selected .spot-marker-pulse{animation:1.5s ease-out infinite markerPulse}@keyframes markerPulse{0%{opacity:.6;transform:translate(-50%)scale(1)}to{opacity:0;transform:translate(-50%)scale(4)}}.spot-marker--draggable{cursor:grab}.spot-marker--draggable:active{cursor:grabbing}.spot-marker--draggable .spot-marker-pin{box-shadow:0 4px 16px #00000080, 0 0 0 3px #ffffff80, 0 0 12px var(--marker-color);transform:rotate(-45deg)scale(1.25)}.spot-marker--draggable .spot-marker-pulse{animation:1.5s ease-out infinite markerDragPulse}@keyframes markerDragPulse{0%{opacity:.5;transform:translate(-50%)scale(1)}to{opacity:0;transform:translate(-50%)scale(5)}}@media (width<=768px){.spot-marker-pin{width:32px;height:32px}.spot-marker-dot{width:12px;height:12px}.spot-marker:after{content:"";position:absolute;inset:-8px}}.map-wrapper{width:100%;height:100%;position:relative}.map-container{width:100%;height:100%}.map-container--adding{cursor:crosshair!important}.map-adding-banner{z-index:10;background:var(--color-primary);color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg), var(--shadow-glow);pointer-events:none;padding:10px 24px;font-size:14px;font-weight:600;position:absolute;top:16px;left:50%;transform:translate(-50%)}.map-adding-banner--with-input{pointer-events:auto;flex-wrap:wrap;align-items:center;gap:10px;max-width:560px;padding:8px 12px 8px 18px;display:flex}.map-adding-label{white-space:nowrap;font-size:13px}.map-adding-search{flex:1;align-items:center;gap:0;min-width:160px;display:flex}.map-adding-input{border-radius:var(--radius-md) 0 0 var(--radius-md);color:#fff;background:#fff3;border:none;outline:none;flex:1;min-width:0;padding:5px 10px;font-size:13px}.map-adding-input::placeholder{color:#fff9}.map-adding-input:focus{background:#ffffff4d}.map-adding-search-btn{border-radius:0 var(--radius-md) var(--radius-md) 0;color:#fff;cursor:pointer;background:#ffffff40;border:none;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:30px;transition:background .15s;display:flex}.map-adding-search-btn:hover:not(:disabled){background:#fff6}.map-adding-search-btn:disabled{opacity:.5;cursor:not-allowed}.map-adding-spin{animation:1s linear infinite mapAddingSpin}@keyframes mapAddingSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.map-adding-error{color:#fca5a5;text-align:center;width:100%;font-size:11px}.hover-info{font-size:13px;font-family:var(--font-family);color:#1a1a1a;padding:2px 4px}.search-result-pin{background:#ef4444;border:3px solid #fff;border-radius:50%;width:16px;height:16px;animation:1.5s ease-in-out infinite searchPinPulse;box-shadow:0 2px 8px #0006,0 0 0 2px #ef44444d}@keyframes searchPinPulse{0%,to{box-shadow:0 2px 8px #0006,0 0 0 2px #ef44444d}50%{box-shadow:0 2px 8px #0006,0 0 0 8px #ef444426}}.search-result-info{font-family:var(--font-family);flex-direction:column;gap:8px;min-width:160px;max-width:280px;padding:4px 2px;display:flex}.search-result-address{color:#1a1a1a;word-break:break-word;font-size:13px;line-height:1.4}.search-result-add-btn{color:#fff;font-size:12px;font-weight:600;font-family:var(--font-family);cursor:pointer;background:#6366f1;border:none;border-radius:6px;justify-content:center;align-items:center;gap:4px;padding:6px 12px;transition:background .15s;display:flex}.search-result-add-btn:hover{background:#4f46e5}.map-placeholder{background:var(--color-bg);background-image:radial-gradient(circle at 25% 25%,#6366f114 0%,#0000 50%),radial-gradient(circle at 75% 75%,#a78bfa0f 0%,#0000 50%);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.map-placeholder-content{text-align:center;max-width:480px;padding:40px}.map-placeholder-icon{margin-bottom:16px;font-size:64px}.map-placeholder-content h2{margin-bottom:12px;font-size:22px;font-weight:700}.map-placeholder-content p{color:var(--color-text-secondary);margin-bottom:12px;font-size:14px;line-height:1.5}.map-placeholder-content pre{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-primary);text-align:left;margin-bottom:16px;padding:12px 16px;font-size:13px}.map-placeholder-content code{background:var(--color-surface);border-radius:var(--radius-sm);color:var(--color-primary);padding:2px 6px;font-size:13px}.map-placeholder-hint{color:var(--color-text-muted)}.map-placeholder-hint a{color:var(--color-primary)}.map-placeholder-hint a:hover{text-decoration:underline}@media (width<=768px){.map-adding-banner{border-radius:var(--radius-md);padding:8px 18px;font-size:13px;top:12px}.map-adding-banner--with-input{flex-direction:column;align-items:stretch;gap:6px;max-width:none;padding:10px 12px;left:12px;right:12px;transform:none}.map-adding-label{text-align:center;font-size:12px}.map-adding-input{padding:8px 10px;font-size:16px}.map-placeholder-content{padding:24px 20px}.map-placeholder-icon{font-size:48px}.map-placeholder-content h2{font-size:18px}.map-placeholder-content p{font-size:13px}.map-placeholder-content pre{padding:10px 12px;font-size:11px;overflow-x:auto}}.spot-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:360px;max-width:calc(100vw - 32px);max-height:calc(100vh - 100px);box-shadow:var(--shadow-lg);z-index:20;padding:20px;animation:.2s panelSlideIn;position:absolute;top:16px;right:16px;overflow-y:auto}@keyframes panelSlideIn{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.spot-panel-top-bar{justify-content:flex-end;align-items:center;gap:4px;margin-bottom:8px;display:flex}.spot-panel-close,.spot-panel-fav{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--color-text-muted);transition:background var(--transition-fast), color var(--transition-fast);background:0 0;justify-content:center;align-items:center;display:flex}.spot-panel-close:hover,.spot-panel-fav:hover{background:var(--color-surface-hover);color:var(--color-text)}.spot-panel-fav--active,.spot-panel-fav--active:hover{color:#ef4444}.spot-panel-group-wrap{position:relative}.spot-panel-group-btn{border-radius:var(--radius-sm);height:32px;color:var(--color-text-muted);transition:background var(--transition-fast), color var(--transition-fast);background:0 0;align-items:center;gap:4px;padding:0 10px;font-size:11px;font-weight:500;display:flex}.spot-panel-group-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.spot-panel-group-btn--assigned,.spot-panel-group-btn--assigned:hover{color:var(--group-color)}.spot-panel-group-label{text-overflow:ellipsis;white-space:nowrap;max-width:80px;overflow:hidden}.spot-panel-group-dropdown{z-index:30;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:160px;box-shadow:var(--shadow-lg);margin-top:4px;padding:4px;position:absolute;top:100%;left:0}.spot-panel-group-option{border-radius:var(--radius-sm);width:100%;color:var(--color-text-secondary);text-align:left;transition:background var(--transition-fast);background:0 0;align-items:center;gap:8px;padding:7px 10px;font-size:12px;font-weight:500;display:flex}.spot-panel-group-option:hover{background:var(--color-surface-hover)}.spot-panel-group-option--active{color:var(--color-primary-hover);background:var(--color-primary-muted)}.spot-panel-group-option-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.spot-panel-header{margin-bottom:12px}.spot-panel-badges{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.spot-panel-badge{border-radius:var(--radius-lg);color:#fff;text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.spot-panel-badge--private{color:var(--color-warning);background:#f59e0b33}.spot-panel-title{letter-spacing:-.3px;font-size:18px;font-weight:700}.spot-panel-status{flex-wrap:wrap;gap:6px;margin-bottom:14px;display:flex}.spot-status-btn{border-radius:var(--radius-lg);background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-muted);transition:all var(--transition-fast);align-items:center;gap:5px;padding:5px 10px;font-size:11px;font-weight:500;display:flex}.spot-status-btn:hover{border-color:var(--status-color);color:var(--status-color);background:color-mix(in srgb, var(--status-color) 8%, transparent)}.spot-status-btn--active{border-color:var(--status-color);color:var(--status-color);background:color-mix(in srgb, var(--status-color) 14%, transparent)}.spot-panel-rating-row{align-items:center;gap:10px;margin-bottom:14px;display:flex}.star-rating{gap:2px;display:flex}.star-btn{transition:transform var(--transition-fast);background:0 0;align-items:center;padding:2px;display:flex}.star-btn:not(.star-btn--readonly):hover{transform:scale(1.2)}.star-btn--readonly{cursor:default}.spot-panel-rating-info{color:var(--color-text-muted);font-size:13px}.spot-panel-desc{color:var(--color-text-secondary);white-space:pre-wrap;margin-bottom:14px;font-size:14px;line-height:1.5}.spot-panel-notes{border-radius:var(--radius-md);background:#f59e0b0f;border:1px solid #f59e0b26;margin-bottom:14px;padding:10px 12px}.spot-panel-notes--empty{background:0 0;border:1px dashed #f59e0b40}.spot-panel-notes-label{color:var(--color-warning);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:6px;margin-bottom:6px;font-size:11px;font-weight:600;display:flex}.spot-panel-notes-edit{border-radius:var(--radius-sm);width:22px;height:22px;color:var(--color-warning);opacity:.5;transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;margin-left:auto;display:flex}.spot-panel-notes-edit:hover{opacity:1;background:#f59e0b1f}.spot-panel-notes-text{color:var(--color-text-secondary);white-space:pre-wrap;cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast);padding:2px 0;font-size:13px;line-height:1.5}.spot-panel-notes-text:hover{background:#f59e0b14}.spot-panel-notes-add{color:var(--color-warning);opacity:.7;transition:opacity var(--transition-fast);background:0 0;align-items:center;gap:6px;padding:6px 0;font-size:13px;display:flex}.spot-panel-notes-add:hover{opacity:1}.spot-panel-notes-editor{flex-direction:column;gap:8px;display:flex}.spot-panel-notes-input{background:var(--color-bg);border-radius:var(--radius-md);width:100%;color:var(--color-text);resize:vertical;min-height:60px;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);border:1px solid #f59e0b4d;padding:8px 10px;font-size:13px;line-height:1.5}.spot-panel-notes-input:focus{border-color:var(--color-warning);outline:none;box-shadow:0 0 0 3px #f59e0b1f}.spot-panel-notes-input::placeholder{color:var(--color-text-muted)}.spot-panel-notes-actions{align-items:center;gap:6px;display:flex}.spot-panel-notes-save{border-radius:var(--radius-sm);color:var(--color-warning);transition:background var(--transition-fast);background:#f59e0b26;align-items:center;gap:4px;padding:5px 12px;font-size:12px;font-weight:600;display:flex}.spot-panel-notes-save:hover{background:#f59e0b40}.spot-panel-notes-save:disabled{opacity:.5}.spot-panel-notes-cancel{border-radius:var(--radius-sm);color:var(--color-text-muted);transition:color var(--transition-fast);background:0 0;padding:5px 10px;font-size:12px}.spot-panel-notes-cancel:hover{color:var(--color-text)}.spot-panel-notes-hint{color:var(--color-text-muted);opacity:.6;margin-left:auto;font-size:10px}.spot-panel-phone{border-radius:var(--radius-md);color:#60a5fa;background:#3b82f60f;border:1px solid #3b82f626;align-items:center;gap:8px;margin-bottom:14px;padding:8px 12px;display:flex}.spot-panel-phone a{color:#60a5fa;transition:color var(--transition-fast);font-size:14px;font-weight:500;text-decoration:none}.spot-panel-phone a:hover{color:#93bbfd;text-decoration:underline}.spot-panel-meta{border-top:1px solid var(--color-border);flex-direction:column;gap:8px;padding:14px 0;display:flex}.spot-panel-meta-row{color:var(--color-text-muted);align-items:center;gap:8px;font-size:12px;display:flex}.spot-panel-navigate{border-radius:var(--radius-sm);color:#60a5fa;transition:background var(--transition-fast), color var(--transition-fast);background:#3b82f61a;align-items:center;gap:4px;margin-left:auto;padding:3px 8px;font-size:11px;font-weight:500;text-decoration:none;display:inline-flex}.spot-panel-navigate:hover{color:#93bbfd;background:#3b82f633}.spot-panel-actions{gap:8px;padding-top:12px;display:flex}.spot-panel-action-btn{border-radius:var(--radius-md);background:var(--color-surface-hover);border:1px solid var(--color-border);color:var(--color-text-secondary);transition:all var(--transition-fast);align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;display:flex}.spot-panel-action-btn:hover{background:var(--color-surface-active);color:var(--color-text)}.spot-panel-action-btn--danger{color:var(--color-danger);background:#ef44441a;border-color:#ef444433}.spot-panel-action-btn--danger:hover{color:var(--color-danger-hover);background:#ef44442e}.spot-panel-edit{flex-direction:column;gap:14px;display:flex}.spot-panel-edit-group{flex-direction:column;gap:4px;display:flex}.spot-panel-edit-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.spot-panel-edit-input{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:9px 12px;font-size:14px}.spot-panel-edit-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-muted)}.spot-panel-edit-textarea{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);resize:vertical;min-height:60px;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:9px 12px;font-size:13px}.spot-panel-edit-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-muted)}.spot-panel-edit-textarea::placeholder{color:var(--color-text-muted)}.category-grid--compact{gap:4px}.category-grid--compact .category-option{padding:4px 8px;font-size:11px}.spot-panel-edit-actions{gap:8px;padding-top:4px;display:flex}.spot-panel-save-btn{border-radius:var(--radius-md);background:var(--color-primary);color:#fff;transition:background var(--transition-fast);align-items:center;gap:6px;padding:8px 18px;font-size:13px;font-weight:600;display:flex}.spot-panel-save-btn:hover{background:var(--color-primary-hover)}.spot-panel-save-btn:disabled{opacity:.6}.spot-panel-cancel-btn{border-radius:var(--radius-md);background:var(--color-surface-hover);border:1px solid var(--color-border);color:var(--color-text-secondary);transition:all var(--transition-fast);padding:8px 14px;font-size:13px;font-weight:500}.spot-panel-cancel-btn:hover{background:var(--color-surface-active);color:var(--color-text)}.spot-panel-edit .visibility-toggle{gap:8px;display:flex}.spot-panel-edit .visibility-btn{border-radius:var(--radius-md);background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-secondary);transition:all var(--transition-fast);flex:1;justify-content:center;align-items:center;gap:6px;padding:8px 12px;font-size:12px;font-weight:500;display:flex}.spot-panel-edit .visibility-btn:hover{border-color:var(--color-border-light);color:var(--color-text)}.spot-panel-edit .visibility-btn--active{border-color:var(--color-primary);background:var(--color-primary-muted);color:var(--color-primary-hover)}.spot-panel-edit .visibility-btn--private{border-color:var(--color-warning);color:var(--color-warning);background:#f59e0b1a}.spot-panel-edit-position{align-items:center;gap:8px;display:flex}.spot-panel-edit-coords{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);flex:1;align-items:center;gap:6px;padding:9px 12px;font-family:monospace;font-size:13px;display:flex}.spot-panel-reposition-btn{border-radius:var(--radius-md);background:var(--color-surface-hover);border:1px solid var(--color-border);color:var(--color-text-secondary);white-space:nowrap;transition:all var(--transition-fast);align-items:center;gap:5px;padding:8px 14px;font-size:12px;font-weight:500;display:flex}.spot-panel-reposition-btn:hover{background:var(--color-surface-active);color:var(--color-text)}.spot-panel-reposition-btn--active{border-color:var(--color-primary);background:var(--color-primary-muted);color:var(--color-primary-hover);animation:2s ease-in-out infinite bannerPulse}@keyframes bannerPulse{0%,to{opacity:1}50%{opacity:.7}}.spot-panel-comments{border-top:1px solid var(--color-border);margin-top:16px;padding-top:16px}.spot-panel-comments-header{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:6px;margin-bottom:12px;font-size:12px;font-weight:600;display:flex}.comment-form{gap:8px;margin-bottom:12px;display:flex}.comment-input{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);transition:border-color var(--transition-fast);flex:1;padding:8px 12px;font-size:13px}.comment-input:focus{border-color:var(--color-primary)}.comment-input::placeholder{color:var(--color-text-muted)}.comment-submit{border-radius:var(--radius-md);background:var(--color-primary);color:#fff;width:36px;height:36px;transition:background var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.comment-submit:hover:not(:disabled){background:var(--color-primary-hover)}.comment-submit:disabled{opacity:.4;cursor:default}.comments-list{flex-direction:column;gap:8px;max-height:240px;display:flex;overflow-y:auto}.comment-item{border-radius:var(--radius-md);background:var(--color-bg);border:1px solid var(--color-border);padding:10px 12px}.comment-header{align-items:center;gap:8px;margin-bottom:4px;display:flex}.comment-author{color:var(--color-text);font-size:12px;font-weight:600}.comment-date{color:var(--color-text-muted);font-size:11px}.comment-delete{border-radius:var(--radius-sm);width:22px;height:22px;color:var(--color-text-muted);transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;margin-left:auto;display:flex}.comment-delete:hover{color:var(--color-danger);background:#ef444426}.comment-text{color:var(--color-text-secondary);white-space:pre-wrap;font-size:13px;line-height:1.45}.comments-empty{color:var(--color-text-muted);text-align:center;padding:12px;font-size:12px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (width<=768px){.spot-panel{width:100%;max-width:100%;max-height:80vh;padding:12px 16px;padding-bottom:calc(16px + var(--safe-bottom));border-radius:var(--radius-lg) var(--radius-lg) 0 0;border:none;border-top:1px solid var(--color-border);animation:.25s panelSlideUp;inset:auto 0 0}.spot-panel:before{content:"";background:var(--color-border-light);border-radius:2px;flex-shrink:0;width:36px;height:4px;margin:0 auto 12px;display:block}@keyframes panelSlideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.spot-panel-top-bar{margin-bottom:4px}.spot-panel-close,.spot-panel-fav{width:40px;height:40px}.spot-panel-title{font-size:17px}.spot-status-btn{min-height:36px;padding:8px 12px;font-size:12px}.spot-panel-action-btn{min-height:44px;padding:10px 16px;font-size:14px}.comment-input{min-height:44px;padding:10px 12px;font-size:14px}.comment-submit{width:44px;height:44px}.star-btn{padding:4px}.comments-list{max-height:200px}.spot-panel--editing{max-height:45vh}}.modal-overlay{background:var(--color-overlay);z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);justify-content:center;align-items:center;animation:.2s overlayFadeIn;display:flex;position:fixed;inset:0}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:400px;max-width:calc(100vw - 32px);max-height:calc(100vh - 32px);box-shadow:var(--shadow-lg);animation:.25s modalSlideIn;position:relative;overflow-y:auto}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(16px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-close{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--color-text-muted);transition:background var(--transition-fast), color var(--transition-fast);background:0 0;justify-content:center;align-items:center;display:flex;position:absolute;top:14px;right:14px}.modal-close:hover{background:var(--color-surface-hover);color:var(--color-text)}.modal-header{text-align:center;padding:28px 28px 0}.modal-title{letter-spacing:-.3px;margin-bottom:6px;font-size:22px;font-weight:700}.modal-subtitle{color:var(--color-text-secondary);font-size:14px}.modal-form{flex-direction:column;gap:14px;padding:24px 28px;display:flex}.form-group{flex-direction:column;gap:4px;display:flex}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--color-text-muted);pointer-events:none;transition:color var(--transition-fast);position:absolute;left:14px}.input-wrapper:focus-within .input-icon{color:var(--color-primary)}.form-input{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:11px 14px 11px 42px;font-size:14px}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-muted)}.form-input::placeholder{color:var(--color-text-muted)}.form-error{border:1px solid #ef444438;border-left:3px solid var(--color-danger,#ef4444);border-radius:var(--radius-md);color:var(--color-danger,#ef4444);background:#ef444414;align-items:flex-start;gap:10px;padding:12px 14px;font-size:13px;line-height:1.45;animation:.25s errorSlideIn;display:flex}.form-error-icon{flex-shrink:0;margin-top:1px}@keyframes errorSlideIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.form-btn{border-radius:var(--radius-md);background:var(--color-primary);color:#fff;width:100%;transition:background var(--transition-fast), box-shadow var(--transition-fast);justify-content:center;align-items:center;margin-top:4px;padding:11px;font-size:15px;font-weight:600;display:flex}.form-btn:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:var(--shadow-glow)}.form-btn:disabled{opacity:.7;cursor:not-allowed}@keyframes spinAnim{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-footer{text-align:center;color:var(--color-text-muted);border-top:1px solid var(--color-border);justify-content:center;align-items:center;gap:6px;padding:16px 28px 24px;font-size:13px;display:flex}.link-btn{color:var(--color-primary);background:0 0;padding:0;font-size:13px;font-weight:500}.link-btn:hover{text-decoration:underline}@media (width<=768px){.modal-overlay{align-items:flex-end}.modal{border-radius:var(--radius-lg) var(--radius-lg) 0 0;border:none;border-top:1px solid var(--color-border);width:100%;max-width:100%;max-height:90vh;animation:.25s modalSlideUp;overflow-y:auto}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:24px 20px 0}.modal-title{font-size:20px}.modal-form{gap:12px;padding:20px}.modal-footer{padding:14px 20px 20px;padding-bottom:calc(20px + var(--safe-bottom))}.form-input{min-height:48px;padding:12px 14px 12px 42px;font-size:16px}.form-input--no-icon{padding-left:14px}.form-textarea{min-height:80px;font-size:16px}.form-btn{min-height:50px;padding:14px;font-size:16px}.modal-close{width:40px;height:40px;top:12px;right:12px}}.form-input--no-icon{padding-left:14px}.form-label{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:12px;font-weight:600}.form-textarea{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text);resize:vertical;min-height:70px;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:11px 14px;font-size:14px}.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-muted)}.form-textarea::placeholder{color:var(--color-text-muted)}.category-grid{flex-wrap:wrap;gap:6px;display:flex}.category-option{border-radius:var(--radius-lg);background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-secondary);transition:all var(--transition-fast);align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;display:flex}.category-option:hover{border-color:var(--color-border-light);color:var(--color-text)}.category-option--active{border-color:var(--opt-color);background:color-mix(in srgb, var(--opt-color) 12%, transparent);color:var(--color-text)}.category-option-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.visibility-toggle{gap:8px;display:flex}.visibility-btn{border-radius:var(--radius-md);background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-secondary);transition:all var(--transition-fast);flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 14px;font-size:13px;font-weight:500;display:flex}.visibility-btn:hover{border-color:var(--color-border-light);color:var(--color-text)}.visibility-btn--active{border-color:var(--color-primary);background:var(--color-primary-muted);color:var(--color-primary-hover)}.visibility-btn--private{border-color:var(--color-warning);color:var(--color-warning);background:#f59e0b1a}.form-hint{color:var(--color-text-muted);margin-top:6px;font-size:11px}.add-notes-btn{border-radius:var(--radius-md);border:1px dashed var(--color-border);color:var(--color-text-muted);width:100%;transition:all var(--transition-fast);background:0 0;align-items:center;gap:6px;padding:8px 12px;font-size:13px;display:flex}.add-notes-btn:hover{border-color:var(--color-border-light);color:var(--color-text-secondary);background:var(--color-surface-hover)}.address-search-row{align-items:stretch;gap:6px;display:flex}.address-search-input{flex:1;min-width:0}.address-search-btn{border-radius:var(--radius-md);background:var(--color-primary);color:#fff;width:40px;transition:background var(--transition-fast), opacity var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.address-search-btn:hover:not(:disabled){background:var(--color-primary-hover)}.address-search-btn:disabled{opacity:.5;cursor:not-allowed}.modal-resolved-address{color:var(--color-text-muted);font-size:12px}.form-error{border-radius:var(--radius-md);color:var(--color-danger);background:#ef44441a;border:1px solid #ef444433;padding:10px 14px;font-size:13px}.spin{animation:1s linear infinite spin}@media (width<=768px){.category-option{min-height:36px;padding:8px 12px;font-size:13px}.visibility-btn{min-height:48px;padding:12px 14px;font-size:14px}.add-notes-btn{min-height:48px;padding:12px;font-size:14px}}.app{flex-direction:column;width:100%;height:100%;display:flex;overflow:hidden}.app-body{flex:1;display:flex;position:relative;overflow:hidden}.app-main{flex:1;position:relative;overflow:hidden}.mobile-fab,.sidebar-backdrop{display:none}@media (width<=768px){.sidebar-backdrop{z-index:40;background:#00000080;animation:.2s backdropFadeIn;display:block;position:absolute;inset:0}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.mobile-fab{bottom:calc(24px + var(--safe-bottom));background:var(--color-primary);color:#fff;width:56px;height:56px;box-shadow:0 4px 16px #6366f166, var(--shadow-lg);z-index:20;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;transition:transform .15s,box-shadow .15s;animation:.25s fabIn;display:flex;position:absolute;right:16px}.mobile-fab:active{transform:scale(.92)}@keyframes fabIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}}:root{--color-bg:#0f1117;--color-surface:#1a1d27;--color-surface-hover:#222632;--color-surface-active:#2a2f3d;--color-border:#2e3348;--color-border-light:#3a3f52;--color-text:#e8eaf0;--color-text-secondary:#9ba1b0;--color-text-muted:#6b7185;--color-primary:#6366f1;--color-primary-hover:#7c7ff7;--color-primary-muted:#6366f126;--color-danger:#ef4444;--color-danger-hover:#f87171;--color-success:#22c55e;--color-warning:#f59e0b;--color-overlay:#0009;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 20px #6366f14d;--transition-fast:.15s ease;--transition-normal:.25s ease;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--safe-left:env(safe-area-inset-left,0px);--safe-right:env(safe-area-inset-right,0px)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:var(--font-family);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;overscroll-behavior:none}button{cursor:pointer;border:none;outline:none;font-family:inherit}input,textarea{outline:none;font-family:inherit}a{color:var(--color-primary);text-decoration:none}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}
