:root{--color-bg-primary:#0a1628;--color-bg-secondary:#0f1f3d;--color-bg-card:#0f1f3db3;--color-bg-glass:#ffffff0d;--color-border-glass:#ffffff1a;--color-text-primary:#e8f0ff;--color-text-secondary:#8ba3c7;--color-text-muted:#4a6a8a;--color-accent-blue:#3b82f6;--color-accent-cyan:#06b6d4;--color-accent-teal:#14b8a6;--color-accent-orange:#f59e0b;--color-accent-red:#ef4444;--color-accent-green:#22c55e;--gradient-ocean:linear-gradient(135deg, #0a1628 0%, #1a2e52 50%, #0f2040 100%);--gradient-card:linear-gradient(135deg, #3b82f61a 0%, #06b6d40d 100%);--gradient-tide-high:linear-gradient(180deg, #3b82f6 0%, #06b6d4 100%);--gradient-tide-low:linear-gradient(180deg, #06b6d4 0%, #14b8a6 100%);--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-2xl:48px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 2px 8px #0003;--shadow-md:0 4px 16px #0000004d;--shadow-lg:0 8px 32px #0006;--shadow-glow:0 0 20px #3b82f64d;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-md:1rem;--font-size-lg:1.25rem;--font-size-xl:1.5rem;--font-size-2xl:2rem;--font-size-3xl:2.5rem;--transition-fast:.15s ease;--transition-normal:.3s ease;--transition-slow:.5s ease;--nav-height:64px}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{font-family:var(--font-family);background:var(--gradient-ocean);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6}#app{height:100%;padding-bottom:calc(var(--nav-height) + 20px);scroll-behavior:smooth;overflow:hidden auto}#app::-webkit-scrollbar{width:4px}#app::-webkit-scrollbar-track{background:0 0}#app::-webkit-scrollbar-thumb{background:var(--color-text-muted);border-radius:var(--radius-full)}.loading-screen{background:var(--gradient-ocean);z-index:9999;transition:opacity var(--transition-slow), visibility var(--transition-slow);flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loading-screen.hidden{opacity:0;visibility:hidden;pointer-events:none}.loading-text{font-size:var(--font-size-xl);color:var(--color-accent-cyan);margin-top:var(--spacing-lg);letter-spacing:4px;font-weight:600}.bottom-nav{height:var(--nav-height);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--color-border-glass);z-index:1000;padding-bottom:env(safe-area-inset-bottom);background:#0a1628f2;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{color:var(--color-text-muted);font-size:var(--font-size-xs);cursor:pointer;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);transition:all var(--transition-fast);background:0 0;border:none;flex-direction:column;align-items:center;gap:4px;display:flex}.nav-item:hover{color:var(--color-text-secondary)}.nav-item.active{color:var(--color-accent-cyan)}.nav-item.active .nav-icon{filter:drop-shadow(0 0 6px #06b6d480)}.nav-icon{width:22px;height:22px}.page{padding:var(--spacing-md);animation:fadeIn var(--transition-normal);display:none}.page.active{display:block}.card{background:var(--color-bg-card);-webkit-backdrop-filter:blur(12px);border:1px solid var(--color-border-glass);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-md);transition:transform var(--transition-fast), box-shadow var(--transition-fast)}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.page-header{padding:var(--spacing-lg) 0}.page-title{font-size:var(--font-size-2xl);background:linear-gradient(135deg, var(--color-text-primary), var(--color-accent-cyan));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.page-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-xs)}.grid-2{gap:var(--spacing-md);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--spacing-md);grid-template-columns:repeat(3,1fr);display:grid}@media (width<=768px){.grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){:root{--spacing-md:12px;--spacing-lg:16px}.page{padding:var(--spacing-sm)}}.search-bar{margin-bottom:var(--spacing-lg);position:relative}.search-input{width:100%;padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg-glass);border:1px solid var(--color-border-glass);border-radius:var(--radius-full);color:var(--color-text-primary);font-size:var(--font-size-md);font-family:var(--font-family);transition:all var(--transition-fast);outline:none;padding-left:48px}.search-input::placeholder{color:var(--color-text-muted)}.search-input:focus{border-color:var(--color-accent-cyan);box-shadow:0 0 0 3px #06b6d426}.search-icon{width:20px;height:20px;color:var(--color-text-muted);position:absolute;top:50%;left:16px;transform:translateY(-50%)}.location-card{background:var(--gradient-card);border:1px solid var(--color-border-glass);border-radius:var(--radius-lg);padding:var(--spacing-lg);cursor:pointer;transition:all var(--transition-normal);position:relative;overflow:hidden}.location-card:before{content:"";opacity:0;transition:opacity var(--transition-normal);background:linear-gradient(135deg,#06b6d41a 0%,#0000 60%);position:absolute;inset:0}.location-card:hover:before{opacity:1}.location-card:hover{box-shadow:var(--shadow-glow);border-color:#06b6d44d;transform:translateY(-4px)}.location-name{font-size:var(--font-size-lg);margin-bottom:var(--spacing-xs);font-weight:600}.location-region{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.location-status{align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);display:flex}.status-dot{border-radius:50%;width:8px;height:8px;animation:2s infinite pulse}.status-dot.rising{background:var(--color-accent-cyan);box-shadow:0 0 8px #06b6d499}.status-dot.falling{background:var(--color-accent-teal);box-shadow:0 0 8px #14b8a699}.tide-chart-container{background:var(--color-bg-card);border:1px solid var(--color-border-glass);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-md);position:relative}.tide-chart-header{margin-bottom:var(--spacing-md);justify-content:space-between;align-items:center;display:flex}.tide-chart-title{font-size:var(--font-size-md);font-weight:600}.tide-chart-date{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.chart-wrapper{height:200px;position:relative}.date-selector{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) 0;margin-bottom:var(--spacing-md);scrollbar-width:none;display:flex;overflow-x:auto}.date-selector::-webkit-scrollbar{display:none}.date-item{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);background:var(--color-bg-glass);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;flex-direction:column;flex-shrink:0;align-items:center;min-width:56px;display:flex}.date-item:hover{border-color:var(--color-border-glass);color:var(--color-text-primary)}.date-item.active{border-color:var(--color-accent-cyan);color:var(--color-accent-cyan);background:#06b6d426}.date-item .day{font-size:var(--font-size-xs);margin-bottom:2px}.date-item .num{font-size:var(--font-size-lg);font-weight:600}.tide-info-grid{gap:var(--spacing-md);margin-bottom:var(--spacing-md);grid-template-columns:repeat(2,1fr);display:grid}.tide-point-card{background:var(--color-bg-glass);border:1px solid var(--color-border-glass);border-radius:var(--radius-md);padding:var(--spacing-md);text-align:center}.tide-point-card.high{border-left:3px solid var(--color-accent-blue)}.tide-point-card.low{border-left:3px solid var(--color-accent-teal)}.tide-point-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--spacing-xs)}.tide-point-time{font-size:var(--font-size-lg);margin-bottom:2px;font-weight:600}.tide-point-height{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.weather-card{align-items:center;gap:var(--spacing-lg);display:flex}.weather-icon{font-size:48px;line-height:1}.weather-temp{font-size:var(--font-size-3xl);font-weight:700}.weather-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.weather-details{gap:var(--spacing-sm) var(--spacing-lg);margin-top:var(--spacing-md);grid-template-columns:repeat(2,1fr);display:grid}.weather-detail-item{align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);display:flex}.weather-detail-label{color:var(--color-text-muted)}.weather-detail-value{color:var(--color-text-primary);font-weight:500}.wave-card{gap:var(--spacing-md);text-align:center;grid-template-columns:repeat(3,1fr);display:grid}.wave-item{padding:var(--spacing-md);background:var(--color-bg-glass);border-radius:var(--radius-md);border:1px solid var(--color-border-glass)}.wave-value{font-size:var(--font-size-xl);color:var(--color-accent-cyan);margin-bottom:var(--spacing-xs);font-weight:700}.wave-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.wave-unit{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.astro-card{gap:var(--spacing-md);grid-template-columns:repeat(2,1fr);display:grid}.astro-item{align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-glass);border-radius:var(--radius-md);display:flex}.astro-icon{font-size:28px}.astro-info{flex:1}.astro-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.astro-value{font-size:var(--font-size-md);font-weight:600}.moon-phase-container{align-items:center;gap:var(--spacing-lg);padding:var(--spacing-md);display:flex}.moon-visual{background:linear-gradient(90deg,silver 50%,#1a1a2e 50%);border-radius:50%;width:60px;height:60px;position:relative;overflow:hidden;box-shadow:0 0 15px #c8c8c84d}.moon-info{flex:1}.moon-name{font-size:var(--font-size-md);margin-bottom:var(--spacing-xs);font-weight:600}.moon-detail{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.detail-header{align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);display:flex}.back-btn{background:var(--color-bg-glass);border:1px solid var(--color-border-glass);border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.back-btn:hover{border-color:var(--color-accent-cyan);background:#ffffff1a}.map-container{width:100%;height:calc(100vh - var(--nav-height) - 120px);border-radius:var(--radius-lg);border:1px solid var(--color-border-glass);overflow:hidden}.settings-item{padding:var(--spacing-md) 0;border-bottom:1px solid var(--color-border-glass);justify-content:space-between;align-items:center;display:flex}.settings-item:last-child{border-bottom:none}.settings-label{font-size:var(--font-size-md);font-weight:500}.settings-desc{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:2px}.section-title{font-size:var(--font-size-md);color:var(--color-text-secondary);margin-bottom:var(--spacing-md);align-items:center;gap:var(--spacing-sm);font-weight:600;display:flex}.section-title:before{content:"";background:var(--color-accent-cyan);border-radius:var(--radius-full);width:3px;height:16px}.custom-marker{background:0 0;border:none}.marker-dot{background:var(--color-accent-cyan);z-index:2;border:2px solid #fffc;border-radius:50%;width:12px;height:12px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.marker-pulse{background:#06b6d44d;border-radius:50%;width:20px;height:20px;animation:2s infinite markerPulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes markerPulse{0%{opacity:1;transform:translate(-50%,-50%)scale(1)}to{opacity:0;transform:translate(-50%,-50%)scale(2.5)}}.custom-popup .leaflet-popup-content-wrapper{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#e8f0ff;background:#0f1f3df2;border:1px solid #ffffff1a;border-radius:12px;box-shadow:0 8px 32px #0006}.custom-popup .leaflet-popup-tip{background:#0f1f3df2;border:1px solid #ffffff1a}.custom-popup .leaflet-popup-close-button{color:#8ba3c7}.custom-popup .leaflet-popup-close-button:hover{color:#e8f0ff}.station-list{gap:var(--spacing-md);grid-template-columns:1fr;display:grid}.all-stations{gap:var(--spacing-sm);grid-template-columns:repeat(2,1fr);display:grid}@media (width<=480px){.all-stations{grid-template-columns:1fr}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.wave-loader{align-items:flex-end;gap:4px;height:40px;display:flex}.wave-bar{background:var(--color-accent-cyan);border-radius:var(--radius-full);width:6px;animation:1.2s ease-in-out infinite waveBar}.wave-bar:first-child{height:20px;animation-delay:0s}.wave-bar:nth-child(2){height:30px;animation-delay:.1s}.wave-bar:nth-child(3){height:40px;animation-delay:.2s}.wave-bar:nth-child(4){height:30px;animation-delay:.3s}.wave-bar:nth-child(5){height:20px;animation-delay:.4s}@keyframes waveBar{0%,to{opacity:.5;transform:scaleY(.5)}50%{opacity:1;transform:scaleY(1)}}.wave-bg{bottom:var(--nav-height);pointer-events:none;z-index:0;height:100px;position:fixed;left:0;right:0;overflow:hidden}.wave-bg svg{width:200%;height:100%;position:absolute;bottom:0}.wave-bg .wave1{opacity:.3;animation:8s linear infinite waveMove}.wave-bg .wave2{opacity:.2;animation:12s linear infinite reverse waveMove}@keyframes waveMove{0%{transform:translate(0)}to{transform:translate(-50%)}}.animate-in{animation:fadeInUp var(--transition-normal) forwards;opacity:0}.animate-in:first-child{animation-delay:0s}.animate-in:nth-child(2){animation-delay:80ms}.animate-in:nth-child(3){animation-delay:.16s}.animate-in:nth-child(4){animation-delay:.24s}.animate-in:nth-child(5){animation-delay:.32s}.animate-in:nth-child(6){animation-delay:.4s}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes countUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg, var(--color-bg-glass) 25%, #ffffff14 50%, var(--color-bg-glass) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite shimmer}.ripple{position:relative;overflow:hidden}.ripple:after{content:"";background:radial-gradient(circle at var(--ripple-x,50%) var(--ripple-y,50%), #ffffff26 0%, transparent 60%);opacity:0;transition:opacity var(--transition-fast);position:absolute;inset:0}.ripple:active:after{opacity:1}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.float-animation{animation:3s ease-in-out infinite float}.login-page{min-height:100vh;padding:var(--spacing-lg);justify-content:center;align-items:center;display:flex}.login-card{background:var(--color-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-2xl);text-align:center;width:100%;max-width:360px}.login-icon{margin-bottom:var(--spacing-md);font-size:48px}.login-title{font-size:var(--font-size-xl);color:var(--color-text-primary);margin-bottom:var(--spacing-xs);font-weight:700}.login-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-xl)}.login-input{text-align:center;letter-spacing:2px;font-size:var(--font-size-md)!important}.login-btn{width:100%;margin-top:var(--spacing-md)}.login-error{color:#f87171;font-size:var(--font-size-sm);margin-top:var(--spacing-md)}.form-group{margin-bottom:var(--spacing-md)}.form-group label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs);display:block}.form-input{border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text-primary);font-size:var(--font-size-sm);background:#ffffff0d;outline:none;padding:10px 14px;transition:border-color .2s}.form-input:focus{border-color:var(--color-accent-cyan);box-shadow:0 0 0 3px #06b6d41a}.form-input::placeholder{color:var(--color-text-muted)}.form-row{gap:var(--spacing-md);grid-template-columns:1fr 1fr;display:grid}.form-hint{color:var(--color-text-muted);margin-bottom:var(--spacing-md);font-size:12px}.btn{border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;border:none;padding:10px 20px;font-weight:500;transition:all .2s}.btn-primary{color:#fff;background:linear-gradient(135deg,#06b6d4,#0891b2)}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #06b6d466}.btn-secondary{color:var(--color-text-primary);border:1px solid var(--color-border);background:#ffffff14}.btn-secondary:hover{background:#ffffff1f}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;padding:var(--spacing-lg);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:420px;animation:.25s modalIn;overflow:hidden}@keyframes modalIn{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-sm);justify-content:space-between;align-items:center;display:flex}.modal-header h3{font-size:var(--font-size-md);color:var(--color-text-primary);font-weight:600}.modal-close{color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:4px 8px;font-size:18px}.modal-close:hover{color:var(--color-text-primary);background:#ffffff1a}.modal-body{padding:var(--spacing-md) var(--spacing-lg)}.modal-footer{gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg) var(--spacing-lg);justify-content:flex-end;display:flex}.station-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--spacing-sm);transition:all .2s;overflow:hidden}.station-card:active{transform:scale(.98)}.station-card.pinned{background:linear-gradient(135deg,#06b6d40d,#0000);border-color:#06b6d44d}.station-card-main{padding:14px var(--spacing-md);cursor:pointer;justify-content:space-between;align-items:center;display:flex}.station-card-main:hover{background:#ffffff08}.station-left{align-items:center;gap:8px;display:flex}.pin-badge{font-size:12px}.station-info{flex-direction:column;gap:2px;display:flex}.station-name{font-size:var(--font-size-md);color:var(--color-text-primary);font-weight:500}.station-region{color:var(--color-text-muted);font-size:12px}.station-right{align-items:center;gap:12px;display:flex}.station-weather{align-items:center;gap:4px;display:flex}.weather-mini-icon{font-size:18px}.weather-mini-temp{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:600}.tide-badge{border-radius:var(--radius-sm);padding:3px 8px;font-size:12px;font-weight:500}.tide-badge.rising{color:#06b6d4;background:#06b6d41f}.tide-badge.falling{color:#f59e0b;background:#f59e0b1f}.context-menu{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);z-index:2000;min-width:140px;animation:.15s menuIn;position:fixed;overflow:hidden;box-shadow:0 8px 24px #0006}@keyframes menuIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-item{width:100%;color:var(--color-text-primary);text-align:left;cursor:pointer;background:0 0;border:none;padding:10px 16px;font-size:13px;transition:background .15s;display:block}.context-item:hover{background:#ffffff14}.context-item.danger{color:#f87171}.context-item.danger:hover{background:#ef44441a}.station-actions{gap:var(--spacing-sm);margin-bottom:var(--spacing-md);display:flex}.action-btn{border-radius:var(--radius-md);border:1px solid var(--color-border);color:var(--color-text-primary);font-size:var(--font-size-sm);cursor:pointer;background:#ffffff0d;align-items:center;gap:6px;padding:8px 14px;transition:all .2s;display:flex}.action-btn:hover{border-color:var(--color-accent-cyan);background:#06b6d41a}.location-weather-card{margin-bottom:var(--spacing-md);padding:var(--spacing-md)!important}.loc-weather-loading{color:var(--color-text-muted);font-size:var(--font-size-sm);align-items:center;gap:8px;display:flex}.loc-loading-icon{animation:1.5s infinite pulse}.loc-weather-error{color:var(--color-text-muted);font-size:var(--font-size-sm);text-align:center;padding:var(--spacing-sm)}.loc-weather-content{gap:var(--spacing-md);flex-direction:column;display:flex}.loc-weather-top{align-items:center;gap:var(--spacing-md);display:flex}.loc-weather-main{align-items:center;gap:6px;display:flex}.loc-main-icon{font-size:36px}.loc-main-temp{color:var(--color-text-primary);font-size:32px;font-weight:700;line-height:1}.loc-weather-desc{flex-direction:column;gap:2px;display:flex}.loc-desc-text{font-size:var(--font-size-md);color:var(--color-text-primary);font-weight:500}.loc-desc-location{color:var(--color-text-muted);font-size:12px}.loc-weather-details{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;display:grid}.loc-detail-item{border-radius:var(--radius-sm);background:#ffffff08;flex-direction:column;gap:2px;padding:8px 10px;display:flex}.loc-detail-label{color:var(--color-text-muted);font-size:11px}.loc-detail-value{color:var(--color-text-primary);font-size:13px;font-weight:600}.loc-tide-chart-wrap{border-radius:var(--radius-sm);height:130px;margin-top:4px;overflow:hidden}.empty-message,.error-message,.loading-placeholder{text-align:center;padding:var(--spacing-2xl);color:var(--color-text-muted);font-size:var(--font-size-sm)}.error-message{color:#f87171}.more-btn{color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:4px 8px;font-size:20px;font-weight:700;line-height:1;transition:background .2s,color .2s}.more-btn:hover{color:var(--color-text-primary);background:#ffffff14}.manage-btn{background:#ffffff0f!important;border-color:#ffffff1f!important}.manage-btn.active{background:var(--color-accent)!important;border-color:var(--color-accent)!important;color:#fff!important}.station-card.manage-mode{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.station-card.manage-mode .station-card-main{align-items:center;gap:12px;display:flex}.drag-handle{color:var(--color-text-muted);cursor:grab;touch-action:none;flex-shrink:0;padding:4px;font-size:18px}.drag-handle:active{cursor:grabbing}.station-manage-actions{flex-shrink:0;gap:8px;margin-left:auto;display:flex}.manage-pin-btn,.manage-del-btn{border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1f;padding:4px 10px;font-size:12px;transition:all .2s}.manage-pin-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:#4fd1c526}.manage-del-btn{color:#f87171;border-color:#f8717133}.manage-del-btn:hover{background:#f8717126;border-color:#f87171}.station-card.dragging{opacity:.5;border:1px dashed var(--color-accent)}.search-bar-wrap,.search-bar{position:relative}.search-clear{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;padding:4px 8px;font-size:16px;line-height:1;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.search-clear:hover{color:var(--color-text-primary);background:#ffffff14}.search-results{background:var(--color-card-bg,#1a2332);border-radius:var(--radius-md);z-index:100;border:1px solid #ffffff1a;max-height:320px;margin-top:6px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 8px 32px #0006}.search-loading{text-align:center;color:var(--color-text-muted);padding:16px;font-size:13px}.search-group-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;padding:8px 14px 4px;font-size:11px;font-weight:600}.search-result-item{cursor:pointer;justify-content:space-between;align-items:center;gap:8px;padding:10px 14px;transition:background .15s;display:flex}.search-result-item:hover{background:#ffffff0d}.search-result-item+.search-result-item{border-top:1px solid #ffffff0a}.search-item-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.search-item-name{color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;overflow:hidden}.search-item-region{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.search-item-action{color:var(--color-accent);flex-shrink:0;font-size:12px}.search-item-actions{flex-shrink:0;gap:6px;display:flex}.search-action-btn{border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;background:#ffffff0a;border:1px solid #ffffff1f;padding:4px 10px;font-size:12px;transition:all .2s}.search-action-btn.view-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:#06b6d41f}.search-action-btn.add-btn:hover{color:#4fd1c5;background:#4fd1c51f;border-color:#4fd1c5}.search-action-btn.added{color:#4fd1c5;pointer-events:none;background:#4fd1c526;border-color:#4fd1c5}
