body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-modal-backdrop{align-items:center;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;overflow:hidden;position:fixed;right:0;top:0;z-index:10000}.login-modal-backdrop:before{animation:scrollEmoji 60s linear infinite;content:"🏔️ ⛺ 🎒 🥾 🧗 🏕️ 🗺️ 🧭 🔦 🎿 🏂 🚴 🏃 ⛰️ 🌲 🌄 🌅 🌌";font-size:3rem;height:100%;left:0;letter-spacing:3rem;line-height:5rem;opacity:.08;overflow:hidden;pointer-events:none;position:absolute;top:0;white-space:nowrap;width:200%}@keyframes scrollEmoji{0%{transform:translateX(0)}to{transform:translateX(-50%)}}.login-modal{animation:slideUp .4s cubic-bezier(.34,1.56,.64,1);background:#fff;border:1px solid #e5e7eb;border-radius:24px;box-shadow:0 25px 80px #0000004d;max-height:90vh;max-width:460px;overflow-y:auto;position:relative;width:90%}.login-modal:before{animation:gradientShift 3s ease infinite;background:linear-gradient(90deg,#667eea,#764ba2 50%,#667eea);background-size:200% 100%;content:"";height:4px;left:0;position:absolute;right:0;top:0}@keyframes gradientShift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.login-modal-header{align-items:center;background:linear-gradient(180deg,var(--bg-secondary) 0,#0000 100%);display:flex;justify-content:space-between;padding:32px 32px 24px}.login-modal-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--primary-color) 0,var(--accent-color) 100%);-webkit-background-clip:text;background-clip:text;font-size:1.75rem;font-weight:700;letter-spacing:-.5px;margin:0}.login-modal-close{align-items:center;background:var(--bg-dark);border:none;border-radius:10px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:28px;height:36px;justify-content:center;line-height:1;padding:0;transition:all .3s cubic-bezier(.34,1.56,.64,1);width:36px}.login-modal-close:hover{background:var(--danger-color);color:#fff;transform:rotate(90deg) scale(1.1)}.login-form{padding:0 32px 32px}.login-error{align-items:center;animation:shake .5s ease;background:linear-gradient(135deg,#ef44441a,#dc26260d);border-left:4px solid var(--danger-color);border-radius:12px;color:var(--danger-color);display:flex;font-size:.9rem;gap:10px;margin-bottom:24px;padding:14px 18px}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.login-error:before{content:"⚠️";font-size:1.2rem}.login-form-group{margin-bottom:24px;position:relative}.login-form-group label{color:#374151;display:block;font-size:.95rem;font-weight:600;letter-spacing:.3px;margin-bottom:10px}.login-form-group input{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;box-sizing:border-box;color:#1f2937;font-family:inherit;font-size:1rem;padding:14px 18px;transition:all .3s cubic-bezier(.34,1.56,.64,1);width:100%}.login-form-group input:focus{background:#fff;border-color:#10b981;box-shadow:0 0 0 4px #10b9811a;outline:none;transform:translateY(-2px)}.login-form-group input::placeholder{color:#9ca3af}.login-submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 8px 24px #667eea66;color:#fff;cursor:pointer;font-size:1.05rem;font-weight:700;letter-spacing:.5px;margin-top:8px;overflow:hidden;padding:16px;position:relative;transition:all .3s cubic-bezier(.34,1.56,.64,1);width:100%}.login-submit-btn:before{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.login-submit-btn:hover:not(:disabled):before{left:100%}.login-submit-btn:hover:not(:disabled){box-shadow:0 12px 32px #667eea80;transform:translateY(-3px)}.login-submit-btn:active:not(:disabled){transform:translateY(-1px)}.login-submit-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.login-switch{align-items:center;color:var(--text-secondary);display:flex;font-size:.9rem;gap:4px;justify-content:center;margin-top:24px;text-align:center}.login-switch-btn{background:none;border:none;border-radius:8px;color:var(--primary-color);cursor:pointer;font-size:.9rem;font-weight:700;padding:6px 12px;position:relative;transition:all .2s}.login-switch-btn:after{background:var(--primary-color);bottom:2px;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);transition:width .3s;width:0}.login-switch-btn:hover:after{width:80%}.login-switch-btn:hover{background:var(--primary-lighter)}.login-tips{background:linear-gradient(135deg,var(--bg-secondary) 0,var(--bg-dark) 100%);border-top:1px solid var(--border-color);padding:20px 32px;position:relative}.login-tips:before{background:linear-gradient(90deg,#0000,var(--primary-color),#0000);border-radius:2px;content:"";height:3px;left:50%;position:absolute;top:0;transform:translateX(-50%);width:60px}.login-tips p{align-items:center;color:var(--text-secondary);display:flex;font-size:.85rem;gap:8px;line-height:1.6;margin:8px 0}.login-tips p:first-child{color:var(--primary-color);font-weight:600}.login-tips p:first-child:before{content:"✨";font-size:1.1rem}.login-tips p:last-child{color:var(--text-light)}.login-tips p:last-child:before{content:"💾";font-size:1.1rem}[data-theme=dark] .login-modal{background:#1e293b;border-color:#ffffff1a;box-shadow:0 25px 80px #000000e6}[data-theme=dark] .login-modal-backdrop:before{opacity:.05}[data-theme=dark] .login-modal-header h2{color:#f1f5f9}[data-theme=dark] .login-form-group label{color:#e2e8f0}[data-theme=dark] .login-form-group input{background:#334155;border-color:#475569;color:#f1f5f9}[data-theme=dark] .login-form-group input:focus{background:#3b4a5f;border-color:#10b981;box-shadow:0 0 0 4px #10b98133}[data-theme=dark] .login-form-group input::placeholder,[data-theme=dark] .login-modal-close{color:#94a3b8}[data-theme=dark] .login-modal-close:hover{background:#334155;color:#f1f5f9}[data-theme=dark] .login-error{background:linear-gradient(135deg,#ef444426,#dc262614);color:#fca5a5}[data-theme=dark] .login-submit-btn{box-shadow:0 8px 24px #667eea4d}[data-theme=dark] .login-submit-btn:hover:not(:disabled){box-shadow:0 12px 32px #667eea66}[data-theme=dark] .login-switch{color:#94a3b8}[data-theme=dark] .login-switch a{color:#10b981}[data-theme=dark] .login-tips{background:linear-gradient(135deg,#10b9811a,#3b82f60d);border-color:#10b98133}[data-theme=dark] .login-tips p{color:#94a3b8}[data-theme=dark] .login-tips p:first-child{color:#10b981}:root{--primary-color:#10b981;--primary-dark:#059669;--primary-light:#34d399;--primary-lighter:#d1fae5;--secondary-color:#3b82f6;--secondary-dark:#2563eb;--secondary-light:#60a5fa;--accent-color:#8b5cf6;--accent-dark:#7c3aed;--danger-color:#ef4444;--danger-dark:#dc2626;--warning-color:#f59e0b;--text-color:#1f2937;--text-primary:#1f2937;--text-secondary:#6b7280;--text-light:#9ca3af;--text-muted:#d1d5db;--bg-color:#f8fafc;--bg-light:#fff;--bg-dark:#f1f5f9;--bg-darker:#e2e8f0;--bg-card:#fff;--card-bg:#fff;--bg-secondary:#f1f5f9;--border-color:#e5e7eb;--border-light:#f3f4f6;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--shadow-color:#0000001a;--chart-colors:#10b981,#3b82f6,#f59e0b,#ef4444,#8b5cf6,#ec4899;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-normal:250ms cubic-bezier(0.4,0,0.2,1);--transition-slow:350ms cubic-bezier(0.4,0,0.2,1)}[data-theme=dark]{--primary-color:#34d399;--primary-dark:#10b981;--primary-light:#6ee7b7;--primary-lighter:#064e3b;--secondary-color:#60a5fa;--secondary-dark:#3b82f6;--secondary-light:#93c5fd;--accent-color:#a78bfa;--accent-dark:#8b5cf6;--danger-color:#f87171;--danger-dark:#ef4444;--warning-color:#fbbf24;--text-color:#f9fafb;--text-primary:#f9fafb;--text-secondary:#d1d5db;--text-light:#9ca3af;--text-muted:#6b7280;--bg-color:#0f172a;--bg-light:#1e293b;--bg-dark:#334155;--bg-darker:#475569;--bg-card:#1e293b;--card-bg:#1e293b;--bg-secondary:#334155;--border-color:#334155;--border-light:#1e293b;--shadow-color:#0006}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;background-color:var(--bg-color);color:#1f2937;color:var(--text-color);font-family:Inter,-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,Segoe UI,Roboto,sans-serif;line-height:1.6;transition:background-color .35s cubic-bezier(.4,0,.2,1),color .35s cubic-bezier(.4,0,.2,1);transition:background-color var(--transition-slow),color var(--transition-slow)}body,html{overscroll-behavior:none}.app,body,html{overflow:hidden}.app{display:flex;height:100vh;position:relative}.app:before{background:#fff;background:var(--bg-light);content:"";height:100vh;left:0;pointer-events:none;position:fixed;top:0;width:100vw;z-index:-1}.content{-webkit-overflow-scrolling:touch;animation:contentFadeIn .4s cubic-bezier(.4,0,.2,1) both;background-color:initial;flex:1 1;overflow-y:auto;overscroll-behavior:contain;padding:32px;padding:var(--spacing-xl)}@keyframes contentFadeIn{0%{opacity:0}to{opacity:1}}.sidebar{-webkit-overflow-scrolling:touch;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#ffffffd9;border-right:1px solid #e5e7eb;border-right:1px solid var(--border-color);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);color:#1f2937;color:var(--text-color);display:flex;flex-direction:column;height:100vh;overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;padding:24px;padding:var(--spacing-lg);padding-bottom:0;width:280px;z-index:10}[data-theme=dark] .sidebar{background:#1e293be6}.sidebar-header{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);margin-bottom:16px;margin-bottom:var(--spacing-md);padding-bottom:16px;padding-bottom:var(--spacing-md);text-align:center}.sidebar-logo{align-items:center;display:flex;gap:8px;gap:var(--spacing-sm);justify-content:center;margin-bottom:4px;margin-bottom:var(--spacing-xs)}.sidebar-logo .logo-icon{color:#10b981;color:var(--primary-color);filter:drop-shadow(0 2px 4px rgba(16,185,129,.3));font-size:2rem}.sidebar-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#10b981,#3b82f6);background:linear-gradient(135deg,var(--primary-color) 0,var(--secondary-color) 100%);-webkit-background-clip:text;background-clip:text;font-size:1.6rem;font-weight:700}.sidebar-subtitle{color:#9ca3af;color:var(--text-light);font-size:.8rem;letter-spacing:2px}.sidebar-main-nav{flex:1 1;padding-top:8px;padding-top:var(--spacing-sm)}.sidebar-nav{list-style:none;padding:0}.sidebar-nav li{margin-bottom:4px;margin-bottom:var(--spacing-xs)}.sidebar-nav a{align-items:center;border-radius:10px;border-radius:var(--radius-md);color:#6b7280;color:var(--text-secondary);display:flex;font-size:.95rem;font-weight:500;gap:8px;gap:var(--spacing-sm);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);position:relative;text-decoration:none;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.sidebar-nav a .nav-icon{color:#9ca3af;color:var(--text-light);font-size:1.2rem;transition:color .15s cubic-bezier(.4,0,.2,1);transition:color var(--transition-fast)}.sidebar-nav a:hover{background-color:#f1f5f9;background-color:var(--bg-dark);color:#1f2937;color:var(--text-color)}.sidebar-nav a:hover .nav-icon{color:#10b981;color:var(--primary-color)}.sidebar-nav a.active{background:#10b981;background:var(--primary-color);box-shadow:0 2px 8px #10b98133;color:#fff}.sidebar-nav a.active .nav-icon{color:#fff}.sidebar-nav-item{align-items:center;border-radius:10px;border-radius:var(--radius-md);color:#6b7280;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:8px;gap:var(--spacing-sm);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.sidebar-nav-item .nav-icon{color:#9ca3af;color:var(--text-light);font-size:1.2rem;transition:color .15s cubic-bezier(.4,0,.2,1);transition:color var(--transition-fast)}.sidebar-nav-item .toggle-icon{color:#9ca3af;color:var(--text-light);font-size:.8rem;margin-left:auto;transition:transform .15s cubic-bezier(.4,0,.2,1);transition:transform var(--transition-fast)}.sidebar-nav-item:hover{background-color:#f1f5f9;background-color:var(--bg-dark);color:#1f2937;color:var(--text-color)}.sidebar-nav-item:hover .nav-icon{color:#10b981;color:var(--primary-color)}.sidebar-nav-item.expanded{color:#1f2937;color:var(--text-color)}.sidebar-nav-item.expanded .nav-icon{color:#10b981;color:var(--primary-color)}.sidebar-subnav{border-left:2px solid #e5e7eb;border-left:2px solid var(--border-color);list-style:none;margin-left:24px;margin-left:var(--spacing-lg);margin-top:4px;margin-top:var(--spacing-xs);padding:0}.sidebar-subnav li{margin-bottom:0}.sidebar-subnav-item{align-items:center;border-radius:10px;border-radius:var(--radius-md);color:#6b7280;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:8px;gap:var(--spacing-sm);padding:4px 16px;padding:var(--spacing-xs) var(--spacing-md);transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.sidebar-subnav-item .nav-icon{color:#9ca3af;color:var(--text-light);font-size:1rem}.sidebar-subnav-item .toggle-icon{color:#9ca3af;color:var(--text-light);font-size:.75rem;margin-left:auto}.sidebar-subnav-item:hover{background-color:#f1f5f9;background-color:var(--bg-dark);color:#1f2937;color:var(--text-color)}.sidebar-subnav-item.expanded{color:#10b981;color:var(--primary-color)}.sidebar-subnav-deep{list-style:none;margin-left:16px;margin-left:var(--spacing-md);margin-top:4px;margin-top:var(--spacing-xs);padding:0}.sidebar-subnav-deep a{border-radius:6px;border-radius:var(--radius-sm);color:#6b7280;color:var(--text-secondary);display:block;font-size:.85rem;padding:4px 16px;padding:var(--spacing-xs) var(--spacing-md);text-decoration:none;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.sidebar-subnav-deep a:hover{background-color:#f1f5f9;background-color:var(--bg-dark);color:#1f2937;color:var(--text-color)}.sidebar-subnav-deep a.active{background-color:#d1fae5;background-color:var(--primary-lighter);color:#10b981;color:var(--primary-color);font-weight:500}.sidebar-footer{background:#fff;background:var(--bg-light);border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);bottom:0;margin-left:-24px;margin-left:calc(var(--spacing-lg)*-1);margin-right:-24px;margin-right:calc(var(--spacing-lg)*-1);margin-top:auto;padding:16px;padding:var(--spacing-md);padding-bottom:16px;padding-bottom:var(--spacing-md);position:-webkit-sticky;position:sticky}.sidebar-footer-icons{gap:8px;gap:var(--spacing-sm)}.sidebar-footer-icons,.sidebar-icon-button{align-items:center;display:flex;justify-content:center}.sidebar-icon-button{background:#f1f5f9;background:var(--bg-dark);border:none;border-radius:10px;border-radius:var(--radius-md);color:#6b7280;color:var(--text-secondary);cursor:pointer;font-size:1.1rem;height:44px;text-decoration:none;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);width:44px}.sidebar-icon-button:hover{background-color:#d1fae5;background-color:var(--primary-lighter);color:#10b981;color:var(--primary-color);transform:translateY(-2px)}.sidebar-icon-button.active{background:linear-gradient(135deg,#10b981,#059669);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-dark) 100%);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#fff}.user-info-container{position:relative}.sidebar-icon-button.user-logged-in{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 8px #10b9814d;color:#fff}.sidebar-icon-button.user-logged-in:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 12px #10b98166;transform:translateY(-2px)}.sidebar-icon-button.user-guest-mode{background:#f1f5f9;background:var(--bg-dark);border:1px dashed #e5e7eb;border:1px dashed var(--border-color);color:#6b7280;color:var(--text-secondary);position:relative}.sidebar-icon-button.user-guest-mode:hover{background:#d1fae5;background:var(--primary-lighter);border-color:#10b981;border-color:var(--primary-color);color:#10b981;color:var(--primary-color);transform:translateY(-2px)}.user-warning-badge{align-items:center;background:linear-gradient(135deg,#f59e0b,#d97706);border:2px solid var(--sidebar-bg);border-radius:50%;box-shadow:0 2px 4px #0003;color:#fff;display:flex;font-size:10px;height:16px;justify-content:center;position:absolute;right:-4px;top:-4px;width:16px}.user-tooltip{animation:tooltipFadeIn .2s ease;background:#fff;background:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:10px;border-radius:var(--radius-md);bottom:calc(100% + 12px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);left:50%;min-width:140px;padding:10px 12px;position:absolute;transform:translateX(-50%);white-space:nowrap;z-index:1000}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateX(-50%) translateY(5px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.user-tooltip:after{border:6px solid #0000;border-top:6px solid var(--bg-light);content:"";left:50%;position:absolute;top:100%;transform:translateX(-50%)}.user-tooltip-username{align-items:center;color:#1f2937;color:var(--text-color);display:flex;font-size:.9rem;font-weight:600;gap:6px;margin-bottom:4px}.user-tooltip-hint{color:#6b7280;color:var(--text-secondary);font-size:.75rem}.user-tooltip.guest{padding:8px 12px}.user-tooltip.guest .user-tooltip-title{color:#6b7280;color:var(--text-secondary);font-size:.8rem;font-weight:500;margin-bottom:4px}.user-tooltip.guest .user-tooltip-text{color:#9ca3af;color:var(--text-light);font-size:.72rem;line-height:1.3}.user-tooltip.logged-in{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-color:#10b981}.user-tooltip.logged-in:after{border-top-color:#ecfdf5}.user-tooltip.logged-in .user-tooltip-username{color:#065f46}.user-tooltip.logged-in .user-tooltip-hint{color:#047857}.logout-confirm-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10001}.logout-confirm-modal{animation:slideUp .3s ease;background:#fff;background:var(--bg-light);border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:320px;padding:24px 32px;text-align:center;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.logout-confirm-icon{align-items:center;background:linear-gradient(135deg,#fee2e2,#fecaca);border-radius:50%;color:#ef4444;display:flex;font-size:1.5rem;height:60px;justify-content:center;margin:0 auto 16px;width:60px}.logout-confirm-modal h3{color:#1f2937;color:var(--text-color);font-size:1.1rem;font-weight:600;margin:0 0 8px}.logout-confirm-modal p{color:#6b7280;color:var(--text-secondary);font-size:.85rem;line-height:1.5;margin:0 0 20px}.logout-confirm-buttons{display:flex;gap:12px}.logout-cancel-btn,.logout-confirm-btn{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:.9rem;font-weight:500;padding:10px 16px;transition:all .2s ease}.logout-cancel-btn{background:#f1f5f9;background:var(--bg-dark);color:#1f2937;color:var(--text-color)}.logout-cancel-btn:hover{background:#e2e8f0;background:var(--bg-darker)}.logout-confirm-btn{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.logout-confirm-btn:hover{box-shadow:0 4px 12px #ef444466;transform:translateY(-1px)}[data-theme=dark] .logout-confirm-modal{background:#fff;background:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color)}[data-theme=dark] .logout-confirm-icon{background:linear-gradient(135deg,#ef444433,#dc262626)}.toggle-button{background:none;border:none;border-radius:6px;border-radius:var(--radius-sm);color:#9ca3af;color:var(--text-light);cursor:pointer;font-size:.8rem;padding:4px;padding:var(--spacing-xs);transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.toggle-button:hover{background-color:#f1f5f9;background-color:var(--bg-dark);color:#1f2937;color:var(--text-color)}.add-button{align-items:center;background:none;border:2px dashed #e5e7eb;border:2px dashed var(--border-color);border-radius:10px;border-radius:var(--radius-md);color:#6b7280;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.9rem;gap:8px;gap:var(--spacing-sm);justify-content:center;margin-top:16px;margin-top:var(--spacing-md);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);width:100%}.add-button:hover{background-color:#d1fae5;background-color:var(--primary-lighter);border-color:#10b981;border-color:var(--primary-color);color:#10b981;color:var(--primary-color)}.page-container{margin:0 auto;max-width:1400px}.page-header{align-items:center;animation:pageHeaderIn .5s cubic-bezier(.4,0,.2,1) both;border-bottom:none;display:flex;justify-content:space-between;margin-bottom:28px;padding-bottom:20px;position:relative;z-index:2}@keyframes pageHeaderIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.page-title{color:#1f2937;color:var(--text-color);font-size:1.6rem;font-weight:700;letter-spacing:-.3px}.page-actions{align-items:center;display:flex;gap:8px;gap:var(--spacing-sm)}.card{animation:cardFadeIn .45s cubic-bezier(.4,0,.2,1) both;background-color:#fff;background-color:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:none;margin-bottom:24px;margin-bottom:var(--spacing-lg);padding:24px;padding:var(--spacing-lg);transition:box-shadow .35s cubic-bezier(.4,0,.2,1),border-color .35s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1);will-change:box-shadow,transform}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.card:hover{border-color:#f3f4f6;border-color:var(--border-light);box-shadow:0 8px 30px #00000012}.card-header{align-items:center;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;margin-bottom:16px;margin-bottom:var(--spacing-md);padding-bottom:16px;padding-bottom:var(--spacing-md)}.card-title{color:#1f2937;color:var(--text-color);font-size:1.1rem;font-weight:600}.card-actions{justify-content:space-between;margin-top:16px;margin-top:var(--spacing-md)}.card-actions,.drag-handle{align-items:center;display:flex}.drag-handle{color:#6b7280;color:var(--text-secondary);cursor:grab;font-size:18px;line-height:1;opacity:.5;padding:4px;transition:opacity .2s,color .2s;-webkit-user-select:none;user-select:none}.drag-handle:hover{color:#10b981;color:var(--primary-color);opacity:1}.drag-handle:active{cursor:grabbing}.card-action-buttons{display:flex;gap:8px;gap:var(--spacing-sm)}.table-container{border-radius:10px;border-radius:var(--radius-md);overflow-x:auto;width:100%}table{border-collapse:collapse;font-size:.9rem;width:100%}table td,table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);padding:16px 24px;padding:var(--spacing-md) var(--spacing-lg);text-align:left;vertical-align:middle}table td:first-child,table th:first-child{width:25%}table td:nth-child(2),table th:nth-child(2){width:35%}table td:nth-child(3),table th:nth-child(3){text-align:right;width:15%}table td:nth-child(4),table th:nth-child(4){text-align:center;width:10%}table td:nth-child(5),table th:nth-child(5){text-align:right;width:15%}table th{background-color:#f8fafc;background-color:var(--bg-color);border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--border-color);color:#6b7280;color:var(--text-secondary);font-size:.72rem;font-weight:600;letter-spacing:.8px;text-transform:uppercase;white-space:nowrap}.gear-table{table-layout:fixed;width:100%}.gear-table td{overflow:hidden;text-overflow:ellipsis}table tbody tr{transition:background-color .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1)}table tbody tr:hover{background-color:#f1f5f9;background-color:var(--bg-dark)}table tbody tr:active{background-color:#e2e8f0;background-color:var(--bg-darker)}table tbody tr:last-child td{border-bottom:none}.button{align-items:center;border:none;border-radius:10px;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:500;gap:8px;gap:var(--spacing-sm);justify-content:center;padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);text-align:center;text-decoration:none;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.button-icon{font-size:1rem}.button-primary{background:linear-gradient(135deg,#10b981,#059669);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-dark) 100%);box-shadow:0 2px 8px #10b98133;color:#fff}.button-primary:hover{background:linear-gradient(135deg,#059669,#047857);background:linear-gradient(135deg,var(--primary-dark) 0,#047857 100%);box-shadow:0 6px 20px #10b9814d;transform:translateY(-1px)}.button-primary:active{box-shadow:0 2px 8px #10b98133;transform:translateY(0)}.button-secondary{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--secondary-color) 0,var(--secondary-dark) 100%);box-shadow:0 2px 8px #3b82f633;color:#fff}.button-secondary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);background:linear-gradient(135deg,var(--secondary-dark) 0,#1d4ed8 100%);box-shadow:0 6px 20px #3b82f64d;transform:translateY(-1px)}.button-secondary:active{box-shadow:0 2px 8px #3b82f633;transform:translateY(0)}.button-danger{background:#ef444414;border:1px solid #ef444433;box-shadow:none;color:#ef4444;color:var(--danger-color)}.button-danger:hover{background:#ef444426;border-color:#ef444459;box-shadow:none;transform:none}.button-outline{background-color:initial;border:2px solid #e5e7eb;border:2px solid var(--border-color);color:#1f2937;color:var(--text-color)}.button-outline:hover{background-color:#f1f5f9;background-color:var(--bg-dark);border-color:#9ca3af;border-color:var(--text-light)}.button-ghost{background-color:initial;color:#6b7280;color:var(--text-secondary)}.button-ghost:hover{background-color:#f1f5f9;background-color:var(--bg-dark);color:#1f2937;color:var(--text-color)}.button-icon-only{border-radius:10px;border-radius:var(--radius-md);height:40px;min-width:40px;padding:8px;padding:var(--spacing-sm)}.button-icon-only svg{stroke-width:2;height:18px;width:18px}.button-outline.button-icon-only{background-color:#fff;background-color:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color)}.button-outline.button-icon-only:hover{background-color:#d1fae5;background-color:var(--primary-lighter);border-color:#10b981;border-color:var(--primary-color);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transform:translateY(-2px)}.button-outline.button-icon-only:hover,.button-outline.button-icon-only:hover svg{color:#10b981;color:var(--primary-color)}.button-outline.button-icon-only[title=\5220\9664\5206\7C7B]:hover,.button-outline.button-icon-only[title=\5220\9664]:hover{background-color:#fef2f2;border-color:#ef4444;border-color:var(--danger-color);color:#ef4444;color:var(--danger-color)}.button-outline.button-icon-only[title=\5220\9664\5206\7C7B]:hover svg,.button-outline.button-icon-only[title=\5220\9664]:hover svg{color:#ef4444;color:var(--danger-color)}[data-theme=dark] .button-outline.button-icon-only[title=\5220\9664\5206\7C7B]:hover,[data-theme=dark] .button-outline.button-icon-only[title=\5220\9664]:hover{background-color:#ef444426}.table-actions{display:flex;gap:4px;gap:var(--spacing-xs);justify-content:flex-end}.table-actions .button-icon-only{height:36px;min-width:36px}.table-actions .button-icon-only svg{height:16px;width:16px}.form-group{margin-bottom:20px}.form-group label{color:#6b7280;color:var(--text-secondary);display:block;font-size:.85rem;font-weight:500;letter-spacing:.2px;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{background-color:#f8fafc;background-color:var(--bg-color);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;border-radius:var(--radius-sm);font-size:.9rem;padding:10px 14px;transition:all .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{box-shadow:0 0 0 3px #10b9811a}.modal-backdrop{animation:backdropIn .25s cubic-bezier(.4,0,.2,1) both;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background-color:#00000073}@keyframes backdropIn{0%{-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0);opacity:0}to{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:1}}.modal{animation:modalIn .35s cubic-bezier(.34,1.56,.64,1) both;box-shadow:0 25px 80px #0000002e,0 0 0 1px #ffffff0d}@keyframes modalIn{0%{opacity:0;transform:scale(.92) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:20px 24px}.modal-title{color:#1f2937;color:var(--text-color);font-size:1.1rem;font-weight:600;letter-spacing:-.2px}.modal-close{align-items:center;background:none;border:none;border-radius:6px;border-radius:var(--radius-sm);color:#9ca3af;color:var(--text-light);cursor:pointer;display:flex;font-size:1.2rem;height:32px;justify-content:center;transition:all .15s ease;width:32px}.modal-close:hover{background:#f1f5f9;background:var(--bg-dark);color:#1f2937;color:var(--text-color)}.modal-body{padding:24px}.modal-footer{border-top:1px solid #f3f4f6;border-top:1px solid var(--border-light);display:flex;gap:10px;justify-content:flex-end;padding:16px 24px}.chart-container{height:400px;margin-bottom:30px}.pie-chart-wrapper{align-items:center;display:flex;flex-direction:column;width:100%}.pie-chart-legend{display:flex;flex-wrap:wrap;gap:8px 16px;justify-content:center;max-width:100%;padding:16px;padding:var(--spacing-md)}.pie-legend-item{align-items:center;background:#f1f5f9;background:var(--bg-dark);border-radius:6px;border-radius:var(--radius-sm);display:flex;font-size:.8rem;gap:6px;padding:4px 8px;white-space:nowrap}.pie-legend-color{border-radius:3px;flex-shrink:0;height:12px;width:12px}.pie-legend-name{color:#1f2937;color:var(--text-color);font-weight:500;max-width:80px;overflow:hidden;text-overflow:ellipsis}.pie-legend-value{color:#6b7280;color:var(--text-secondary);font-size:.75rem}.summary-stats{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.summary-stats .stat-card{background-color:#fff;background-color:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);flex:1 1;min-width:200px;padding:18px 20px;text-align:center}.summary-stats .stat-card h3{color:#6b7280;color:var(--text-secondary);font-size:.82rem;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.summary-stats .stat-card p{font-size:1.5rem;font-weight:700}.weight-unit-selector{align-items:center;display:flex;gap:10px;margin-right:15px}.weight-unit-selector span{color:#9ca3af;color:var(--text-light);font-size:.9rem}.weight-unit-selector select{background-color:#fff;background-color:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:4px;color:#1f2937;color:var(--text-color);padding:5px 10px}.route-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:30px}.route-list{display:flex;flex-direction:column;gap:10px;margin-bottom:30px}@keyframes routeItemIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.route-item{animation:routeItemIn .35s cubic-bezier(.4,0,.2,1) both}.route-item-link{align-items:center;background:#fff;background:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:14px;color:inherit;display:flex;gap:16px;padding:16px 20px;text-decoration:none;transition:all .25s cubic-bezier(.4,0,.2,1)}.route-item-link:hover{border-color:#10b981;border-color:var(--primary-color);box-shadow:0 4px 20px #10b98114;transform:translateX(4px)}.route-item-icon{align-items:center;border-radius:14px;box-shadow:0 2px 8px #0000001f;display:flex;flex-shrink:0;height:56px;justify-content:center;transition:transform .25s cubic-bezier(.4,0,.2,1);width:56px}.route-item-link:hover .route-item-icon{transform:scale(1.08)}.route-item-emoji{filter:drop-shadow(0 1px 2px rgba(0,0,0,.15));font-size:28px;line-height:1}.route-item-info{flex:1 1;min-width:0}.route-item-top{align-items:center;display:flex;gap:10px;margin-bottom:4px}.route-item-name{color:#1f2937;color:var(--text-primary);font-size:15px;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.route-item-status{align-items:center;border-radius:20px;display:inline-flex;flex-shrink:0;font-size:11px;font-weight:600;gap:5px;letter-spacing:.3px;padding:3px 10px}.route-item-status .status-dot{border-radius:50%;flex-shrink:0;height:6px;width:6px}.route-item-status.status-completed{background:#10b9811a;color:#059669}.route-item-status.status-preparing{background:#3b82f61a;color:#2563eb}.route-item-status.status-abandoned{background:#ef44441a;color:#dc2626}[data-theme=dark] .route-item-status.status-completed{background:#10b98126;color:#34d399}[data-theme=dark] .route-item-status.status-preparing{background:#3b82f626;color:#60a5fa}[data-theme=dark] .route-item-status.status-abandoned{background:#ef444426;color:#f87171}.route-item-desc{color:#9ca3af;color:var(--text-light);font-size:13px;margin:0 0 6px;max-width:500px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.route-item-meta{align-items:center;display:flex;flex-wrap:wrap;gap:14px}.route-meta-tag{align-items:center;color:#9ca3af;color:var(--text-light);display:inline-flex;font-size:12px;font-weight:500;gap:4px}.route-item-actions{align-items:center;display:flex;flex-shrink:0;gap:6px}.route-action-btn{align-items:center;background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:9px;color:#6b7280;color:var(--text-secondary);cursor:pointer;display:flex;height:34px;justify-content:center;opacity:0;transition:all .2s ease;width:34px}.route-item-link:hover .route-action-btn{opacity:1}.route-action-btn:hover{background:#f1f5f9;background:var(--bg-dark);border-color:#9ca3af;border-color:var(--text-light);color:#1f2937;color:var(--text-primary)}.route-action-btn.danger:hover{background:#ef444414;border-color:#fca5a5;color:#ef4444}.route-item-arrow{color:#9ca3af;color:var(--text-light);flex-shrink:0;margin-left:4px;opacity:.4;transition:all .2s ease}.route-item-link:hover .route-item-arrow{color:#10b981;color:var(--primary-color);opacity:1;transform:translateX(2px)}.icon-picker{align-items:flex-start;display:flex;gap:16px}.icon-picker-preview{align-items:center;border-radius:18px;box-shadow:0 4px 16px #00000026;display:flex;flex-shrink:0;height:72px;justify-content:center;transition:transform .3s cubic-bezier(.4,0,.2,1);width:72px}.icon-picker-preview:hover{transform:scale(1.05)}.icon-picker-current{filter:drop-shadow(0 2px 3px rgba(0,0,0,.2));font-size:36px;line-height:1}.icon-picker-grid{grid-gap:4px;background:#f8fafc;background:var(--bg-color);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;display:grid;flex:1 1;gap:4px;grid-template-columns:repeat(8,1fr);max-height:160px;overflow-y:auto;padding:4px}.icon-picker-grid::-webkit-scrollbar{width:4px}.icon-picker-grid::-webkit-scrollbar-track{background:#0000}.icon-picker-grid::-webkit-scrollbar-thumb{background:#e5e7eb;background:var(--border-color);border-radius:4px}.icon-picker-item{align-items:center;aspect-ratio:1;background:#0000;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:18px;justify-content:center;padding:0;transition:all .15s ease;width:100%}.icon-picker-item:hover{background:#f1f5f9;background:var(--bg-dark);transform:scale(1.15)}.icon-picker-item.selected{background:#d1fae5;background:var(--primary-lighter);box-shadow:0 0 0 2px #10b981;box-shadow:0 0 0 2px var(--primary-color);transform:scale(1.1)}.route-icon-picker{display:flex;flex-direction:column;gap:10px}.rip-preview{align-items:center;border-radius:16px;box-shadow:0 4px 16px #00000026;display:flex;height:64px;justify-content:center;margin:0 auto 4px;transition:transform .3s ease;width:64px}.rip-preview:hover{transform:scale(1.05)}.rip-preview-icon{align-items:center;color:#fff;display:flex;justify-content:center}.rip-preview-icon .route-icon-emoji{filter:drop-shadow(0 2px 3px rgba(0,0,0,.2));font-size:32px;line-height:1}.rip-search{position:relative}.rip-search-input{background:#fff;background:var(--bg-light);border:1.5px solid #e5e7eb;border:1.5px solid var(--border-color);border-radius:8px;color:#1f2937;color:var(--text-primary);font-size:13px;outline:none;padding:8px 32px 8px 12px;transition:border-color .2s;width:100%}.rip-search-input:focus{border-color:#10b981;border-color:var(--primary-color)}.rip-search-clear,.rip-search-input::placeholder{color:#9ca3af;color:var(--text-light)}.rip-search-clear{background:none;border:none;cursor:pointer;font-size:16px;line-height:1;padding:2px 4px;position:absolute;right:6px;top:50%;transform:translateY(-50%)}.rip-search-clear:hover{color:#1f2937;color:var(--text-primary)}.rip-tabs{-ms-overflow-style:none;display:flex;gap:4px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.rip-tabs::-webkit-scrollbar{display:none}.rip-tab{background:#0000;border:1.5px solid #e5e7eb;border:1.5px solid var(--border-color);border-radius:8px;color:#6b7280;color:var(--text-secondary);cursor:pointer;flex-shrink:0;font-size:12px;font-weight:500;padding:5px 10px;transition:all .2s;white-space:nowrap}.rip-tab:hover{background:#f1f5f9;background:var(--bg-dark);border-color:#9ca3af;border-color:var(--text-light)}.rip-tab.active{background:#d1fae5;background:var(--primary-lighter);border-color:#10b981;border-color:var(--primary-color);color:#10b981;color:var(--primary-color);font-weight:600}.rip-grid{grid-gap:4px;background:#f8fafc;background:var(--bg-color);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:10px;display:grid;gap:4px;grid-template-columns:repeat(8,1fr);max-height:180px;overflow-y:auto;padding:4px}.rip-grid::-webkit-scrollbar{width:4px}.rip-grid::-webkit-scrollbar-track{background:#0000}.rip-grid::-webkit-scrollbar-thumb{background:#e5e7eb;background:var(--border-color);border-radius:4px}.rip-item{align-items:center;aspect-ratio:1;background:#0000;border:none;border-radius:8px;cursor:pointer;display:flex;justify-content:center;padding:0;transition:all .15s ease;width:100%}.rip-item:hover{background:#f1f5f9;background:var(--bg-dark);transform:scale(1.12)}.rip-item.selected{background:#d1fae5;background:var(--primary-lighter);box-shadow:0 0 0 2px #10b981;box-shadow:0 0 0 2px var(--primary-color);transform:scale(1.08)}.rip-item-emoji{font-size:18px;line-height:1}.rip-item-icon{align-items:center;color:#1f2937;color:var(--text-primary);display:flex;justify-content:center}.rip-item.selected .rip-item-icon{color:#10b981;color:var(--primary-color)}.rip-empty{font-size:13px;grid-column:1/-1;padding:20px}.rip-empty,.rip-search-count{color:#9ca3af;color:var(--text-light);text-align:center}.rip-search-count{font-size:11px}.route-color-picker{display:flex;flex-direction:column;gap:10px}.rcp-preview{align-items:center;border-radius:12px;box-shadow:0 2px 12px #0000001f;display:flex;height:48px;justify-content:center;overflow:hidden;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)}.rcp-preview:before{background:linear-gradient(180deg,#ffffff1a,#0000 60%);content:"";inset:0;pointer-events:none;position:absolute}.rcp-preview-label{color:#fff;font-size:13px;font-weight:600;letter-spacing:.5px;position:relative;text-shadow:0 1px 4px #0000004d;z-index:1}.rcp-tabs{-ms-overflow-style:none;display:flex;gap:4px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.rcp-tabs::-webkit-scrollbar{display:none}.rcp-tab{background:#0000;border:1.5px solid #e5e7eb;border:1.5px solid var(--border-color);border-radius:8px;color:#6b7280;color:var(--text-secondary);cursor:pointer;flex-shrink:0;font-size:12px;font-weight:500;padding:5px 10px;transition:all .2s;white-space:nowrap}.rcp-tab:hover{background:#f1f5f9;background:var(--bg-dark);border-color:#9ca3af;border-color:var(--text-light)}.rcp-tab.active{background:#d1fae5;background:var(--primary-lighter);border-color:#10b981;border-color:var(--primary-color);color:#10b981;color:var(--primary-color);font-weight:600}.rcp-grid{grid-gap:6px;background:#f8fafc;background:var(--bg-color);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:10px;display:grid;gap:6px;grid-template-columns:repeat(4,1fr);max-height:180px;overflow-y:auto;padding:4px}.rcp-grid::-webkit-scrollbar{width:4px}.rcp-grid::-webkit-scrollbar-track{background:#0000}.rcp-grid::-webkit-scrollbar-thumb{background:#e5e7eb;background:var(--border-color);border-radius:4px}.rcp-item{align-items:center;background:#0000;border:2px solid #0000;border-radius:10px;cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:6px 4px;transition:all .2s}.rcp-item:hover{background:#f1f5f9;background:var(--bg-dark);border-color:#e5e7eb;border-color:var(--border-color);transform:translateY(-1px)}.rcp-item.selected{background:#d1fae5;background:var(--primary-lighter);border-color:#10b981;border-color:var(--primary-color);box-shadow:0 0 0 1px #10b981;box-shadow:0 0 0 1px var(--primary-color)}.rcp-swatch{border-radius:7px;box-shadow:0 1px 4px #0000001f;height:28px;overflow:hidden;position:relative;width:100%}.rcp-swatch:before{background:linear-gradient(180deg,#ffffff26,#0000 60%);content:"";inset:0;pointer-events:none;position:absolute}.rcp-swatch.auto-swatch{align-items:center;background:conic-gradient(from 0deg,#ef4444 0deg,#f97316 45deg,#eab308 90deg,#22c55e 135deg,#06b6d4 180deg,#3b82f6 225deg,#8b5cf6 270deg,#ec4899 315deg,#ef4444 1turn);display:flex;justify-content:center}.rcp-swatch.auto-swatch span{color:#fff;font-size:10px;font-weight:700;position:relative;text-shadow:0 1px 3px #00000080;z-index:1}.rcp-item-name{color:#6b7280;color:var(--text-secondary);font-size:11px;line-height:1;white-space:nowrap}.rcp-item.selected .rcp-item-name{color:#10b981;color:var(--primary-color);font-weight:600}@media (max-width:768px){.rcp-grid{grid-template-columns:repeat(3,1fr);max-height:160px}.rcp-tabs{gap:3px}.rcp-tab{font-size:11px;padding:4px 8px}.rip-grid{grid-template-columns:repeat(7,1fr);max-height:150px}.rip-tabs{gap:3px}.rip-tab{font-size:11px;padding:4px 8px}.route-item-link{gap:12px;padding:12px 14px}.route-item-icon{border-radius:12px;height:44px;width:44px}.route-item-emoji{font-size:22px}.route-item-actions .route-action-btn{opacity:1}.route-item-arrow{display:none}.route-item-desc{max-width:200px}.icon-picker{align-items:center;flex-direction:column}.icon-picker-grid{grid-template-columns:repeat(8,1fr);max-height:120px}}.pagination{align-items:center;display:flex;gap:16px;gap:var(--spacing-md);justify-content:center;margin-top:24px;margin-top:var(--spacing-lg);padding:16px 0;padding:var(--spacing-md) 0}.pagination-btn{background:#fff;background:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:10px;border-radius:var(--radius-md);color:#1f2937;color:var(--text-color);cursor:pointer;font-size:.875rem;padding:8px 24px;padding:var(--spacing-sm) var(--spacing-lg);transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.pagination-btn:hover:not(:disabled){background:#10b981;background:var(--primary-color);border-color:#10b981;border-color:var(--primary-color);color:#fff}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.pagination-info{color:#6b7280;color:var(--text-secondary);font-size:.875rem}.route-card{border:1px solid #e5e7eb;border:1px solid var(--border-color);box-shadow:none;transition:all .3s ease}.route-card:hover{border-color:#10b981;border-color:var(--primary-color);box-shadow:0 8px 24px #00000014;transform:translateY(-3px)}.route-card-link{color:inherit;text-decoration:none}.route-card-image{height:160px}.route-card-image-overlay{background:linear-gradient(180deg,#0000 50%,#000000b3)}.route-card-content{display:flex;flex-direction:column;flex-grow:1;padding:15px}.route-card-title{font-size:1.1rem;font-weight:500;margin-bottom:5px}.route-card-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;font-size:.9rem;overflow:hidden}.route-card-description,.route-card-stats{color:#9ca3af;color:var(--text-light);margin-bottom:15px}.route-card-stats{display:flex;font-size:.85rem;justify-content:space-between;margin-top:auto}.file-upload{border:2px dashed #e5e7eb;border:2px dashed var(--border-color);border-radius:8px;cursor:pointer;margin-bottom:20px;padding:30px;text-align:center;transition:all .2s ease}.file-upload:hover{border-color:#10b981;border-color:var(--primary-color)}.file-upload-icon{color:#10b981;color:var(--primary-color);font-size:2rem;margin-bottom:10px}.file-upload-text{color:#9ca3af;color:var(--text-light);font-size:.9rem}.file-upload-preview{margin-top:15px;position:relative}.file-upload-preview img{border-radius:4px;max-height:200px;max-width:100%}.imgur-preview{display:inline-block;margin-top:10px;position:relative}.imgur-preview img{border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;max-height:150px;max-width:100%}.file-upload-remove{align-items:center;background-color:#fff;background-color:var(--bg-light);border:none;border-radius:50%;color:#ef4444;color:var(--danger-color);cursor:pointer;display:flex;height:25px;justify-content:center;position:absolute;right:5px;top:5px;width:25px}.tabs{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;margin-bottom:20px}.tab{background:none;border:none;border-bottom:2px solid #0000;color:#1f2937;color:var(--text-color);cursor:pointer;font-size:1rem;padding:10px 20px;transition:all .2s ease}.tab.active,.tab:hover{color:#10b981;color:var(--primary-color)}.tab.active{border-bottom-color:#10b981;border-bottom-color:var(--primary-color)}.tab-content{padding:10px 0}.dropdown{position:relative}.dropdown-toggle{align-items:center;display:flex;gap:5px}.dropdown-menu{background-color:#fff;background-color:var(--bg-light);border-radius:6px;box-shadow:0 2px 10px #0000001a;box-shadow:0 2px 10px var(--shadow-color);display:none;min-width:150px;overflow:hidden;position:absolute;right:0;top:100%;z-index:100}.dropdown:hover .dropdown-menu{display:block}.dropdown-item{align-items:center;background:none;border:none;color:#1f2937;color:var(--text-color);cursor:pointer;display:flex;gap:8px;padding:10px 15px;text-align:left;transition:all .2s ease;width:100%}.dropdown-item:hover{background-color:#f1f5f9;background-color:var(--bg-dark)}.dropdown-icon{font-size:1rem}.category-list{padding:10px 0}.category-list-item{margin-bottom:15px}.category-list-item-header{align-items:center;display:flex;margin-bottom:5px}.category-color{border-radius:50%;margin-right:10px}.category-list-item-header h3{flex:1 1;font-size:.95rem;font-weight:500}.category-weight{color:#9ca3af;color:var(--text-light)}.category-progress{background-color:#f1f5f9;background-color:var(--bg-dark);border-radius:3px;height:6px;margin-bottom:5px;overflow:hidden}.category-progress-bar{border-radius:3px;height:100%}.category-stats{color:#9ca3af;color:var(--text-light);display:flex;font-size:.8rem;justify-content:space-between}.empty-state{background-color:#fff;background-color:var(--bg-light);border:1px dashed #e5e7eb;border:1px dashed var(--border-color);box-shadow:none;padding:60px 24px}.empty-state-icon{font-size:2.8rem;margin-bottom:16px;opacity:.4}.empty-state h3{font-size:1.05rem;font-weight:600}.empty-state p{color:#6b7280;color:var(--text-secondary);font-size:.85rem;line-height:1.6;margin-bottom:20px}.page-error,.page-loading{align-items:center;display:flex;flex-direction:column;height:300px;justify-content:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f1f5f9;border-top:4px solid #10b981;border:4px solid var(--bg-dark);border-radius:50%;border-top-color:var(--primary-color);height:40px;margin-bottom:20px;width:40px}.error-icon{font-size:3rem;margin-bottom:20px}.print-view{margin:0 auto;max-width:800px;padding:30px}.print-header{margin-bottom:30px;text-align:center}.print-date{color:#9ca3af;color:var(--text-light);font-size:.9rem;margin-top:10px}.print-summary{background-color:#fff;background-color:var(--bg-light);border-radius:8px;display:flex;justify-content:space-around;margin-bottom:30px;padding:15px}.print-summary-item{text-align:center}.print-summary-item span{font-weight:500}.print-category{margin-bottom:30px}.print-category h2{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);margin-bottom:15px;padding-bottom:5px}.print-table{border-collapse:collapse;width:100%}.print-table td,.print-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);padding:8px;text-align:left}.col-md-6{flex:0 0 50%;padding:10px}.col-md-4{flex:0 0 33.333%;min-width:300px;padding:10px}.row{display:flex;flex-wrap:wrap;margin:-10px}@media (max-width:1200px){.col-md-4{flex:0 0 50%}}@media (max-width:768px){.col-md-4,.col-md-6{flex:0 0 100%}}.article-container{background-color:#fff;background-color:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);margin:0 auto;max-width:800px;padding:24px}.article-title{color:#10b981;color:var(--primary-color);font-size:2rem;margin-bottom:20px}.article-meta{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);color:#9ca3af;color:var(--text-light);display:flex;font-size:.9rem;justify-content:space-between;margin-bottom:30px;padding-bottom:15px}.article-content{line-height:1.6}.article-intro{font-size:1.1rem}.article-intro,.article-section{margin-bottom:30px}.article-section h2{color:#059669;color:var(--primary-dark);font-size:1.5rem;margin-bottom:15px}.article-section p{margin-bottom:15px}.article-section ol,.article-section ul{margin-bottom:15px;padding-left:20px}.article-section li{margin-bottom:8px}.comparison-table{margin:20px 0;overflow-x:auto}.comparison-table table{border-collapse:collapse;width:100%}.comparison-table td,.comparison-table th{border:1px solid #e5e7eb;border:1px solid var(--border-color);padding:12px}.comparison-table th{background-color:#f1f5f9;background-color:var(--bg-dark);text-align:left}.about-content{margin:0 auto;max-width:900px}.about-section{margin-bottom:40px}.about-section h2{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);color:#059669;color:var(--primary-dark);font-size:1.5rem;margin-bottom:20px;padding-bottom:10px}.feature-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin-top:20px}.about-page .feature-card{box-shadow:none}.feature-card{background-color:#fff;background-color:var(--bg-light);border-radius:8px;box-shadow:0 2px 10px #0000001a;box-shadow:0 2px 10px var(--shadow-color);padding:20px;text-align:center}.feature-icon{font-size:2.5rem;margin-bottom:15px}.feature-card h3{font-size:1.2rem;margin-bottom:10px}.timeline{margin-top:30px;padding-left:30px;position:relative}.timeline:before{background-color:#34d399;background-color:var(--primary-light);content:"";height:100%;left:0;position:absolute;top:0;width:2px}.timeline-item{margin-bottom:30px;position:relative}.timeline-item:before{background-color:#10b981;background-color:var(--primary-color);border:2px solid #fff;border:2px solid var(--bg-light);border-radius:50%;content:"";height:10px;left:-34px;position:absolute;top:5px;width:10px}.timeline-date{color:#10b981;color:var(--primary-color);font-weight:700;margin-bottom:5px}.contact-info{margin-top:20px}.contact-item{align-items:center;display:flex;margin-bottom:10px}.contact-icon{font-size:1.2rem;margin-right:10px}.settings-content{margin:0 auto;max-width:800px}.settings-section{background-color:#fff;background-color:var(--bg-light);border-radius:8px;box-shadow:0 2px 10px #0000001a;box-shadow:0 2px 10px var(--shadow-color);margin-bottom:30px;padding:20px}.settings-section h2{font-size:1.3rem;margin-bottom:20px;padding-bottom:10px}.settings-item,.settings-section h2{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color)}.settings-item{align-items:center;display:flex;justify-content:space-between;padding:15px 0}.settings-item:last-child,.settings-item:last-of-type{border-bottom:none}.settings-item+.settings-hint{margin-top:5px}.settings-item:has(+.invite-code-container),.settings-item:has(+.settings-hint){border-bottom:none}.settings-hint{color:#6b7280;color:var(--text-secondary);font-size:.85rem;margin-top:-10px;padding:0 0 10px}.invite-code-container{padding:15px 0}.invite-code-input-group{align-items:center;display:flex;gap:10px}.invite-code-input{background-color:#fff;background-color:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;color:#1f2937;color:var(--text-color);flex:1 1;font-size:.9rem;max-width:200px;padding:8px 12px;transition:border-color .2s ease}.invite-code-input:focus{border-color:#10b981;border-color:var(--primary-color);outline:none}.invite-code-input.error{border-color:#ef4444;border-color:var(--danger-color)}.invite-code-input::placeholder{color:#9ca3af;color:var(--text-light)}.invite-error{color:#ef4444;color:var(--danger-color);font-size:.85rem;margin-top:8px}.settings-message{border-radius:6px;font-size:.9rem;margin:10px 0;padding:10px 15px}.settings-message.success{background-color:#10b9811a;border:1px solid #10b981;border:1px solid var(--primary-color);color:#10b981;color:var(--primary-color)}.settings-message.error{background-color:#ef44441a;border:1px solid #ef4444;border:1px solid var(--danger-color);color:#ef4444;color:var(--danger-color)}.settings-label{font-weight:500}.settings-control{min-width:200px}.settings-control .current-username{background-color:#d1fae5;background-color:var(--primary-lighter);border-radius:6px;color:#10b981;color:var(--primary-color);font-weight:600;padding:6px 12px}.settings-form{display:flex;flex-direction:column;gap:12px;max-width:400px;padding:15px 0}.settings-form-group{display:flex;flex-direction:column;gap:4px}.settings-input{background-color:#fff;background-color:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;color:#1f2937;color:var(--text-color);font-size:.9rem;padding:10px 12px;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.settings-input:focus{border-color:#10b981;border-color:var(--primary-color);box-shadow:0 0 0 3px #10b9811a;outline:none}.settings-input::placeholder{color:#9ca3af;color:var(--text-light)}.settings-select{background-color:#fff;background-color:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:4px;color:#1f2937;color:var(--text-color);padding:8px 10px;width:100%}.switch{display:inline-block;height:24px;position:relative;width:50px}.switch input{height:0;opacity:0;width:0}.slider{background-color:#f1f5f9;background-color:var(--bg-dark);bottom:0;cursor:pointer;left:0;right:0;top:0}.slider,.slider:before{position:absolute;transition:.4s}.slider:before{background-color:#fff;bottom:4px;content:"";height:16px;left:4px;width:16px}input:checked+.slider{background-color:#10b981;background-color:var(--primary-color)}input:focus+.slider{box-shadow:0 0 1px #10b981;box-shadow:0 0 1px var(--primary-color)}input:checked+.slider:before{transform:translateX(26px)}.slider.round{border-radius:24px}.slider.round:before{border-radius:50%}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.app,.sidebar{flex-direction:column}.sidebar{box-shadow:none;display:flex;height:100vh;height:100dvh;left:-300px;position:fixed;top:0;transition:left .3s ease;width:280px;z-index:1000}.sidebar.open{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);left:0}.sidebar-main-nav{flex:1 1;overflow-y:auto;padding-top:0}.sidebar-footer{background:#fff;background:var(--bg-light);border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);flex-shrink:0;padding:16px;padding:var(--spacing-md);padding-bottom:calc(16px + env(safe-area-inset-bottom, 0px));padding-bottom:calc(var(--spacing-md) + env(safe-area-inset-bottom, 0px))}.sidebar-overlay{background:#00000080;bottom:0;display:block;left:0;opacity:1;position:fixed;right:0;top:0;transition:opacity .3s ease;z-index:999}.mobile-menu-button{align-items:center;background:#fff;background:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:10px;border-radius:var(--radius-md);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#1f2937;color:var(--text-color);cursor:pointer;display:flex;font-size:1.5rem;height:44px;justify-content:center;left:16px;position:fixed;top:16px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);width:44px;z-index:1001}.mobile-menu-button:hover{background:#f1f5f9;background:var(--bg-dark)}.mobile-menu-button:active{transform:scale(.95)}.content{margin-left:0;padding:70px 16px 16px;width:100%}.summary-stats{flex-direction:column}.route-cards{grid-template-columns:1fr}.col-md-4,.col-md-6{flex:0 0 100%}.settings-item{align-items:flex-start;flex-direction:column}.settings-control{margin-top:10px;width:100%}.feature-cards{grid-template-columns:1fr}.page-header{align-items:flex-start;flex-direction:column;gap:16px;gap:var(--spacing-md)}.page-header h1,.page-title{font-size:1.5rem}.page-actions{grid-gap:8px;grid-gap:var(--spacing-sm);display:grid;gap:8px;gap:var(--spacing-sm);grid-template-columns:repeat(2,1fr);width:100%}.page-actions .button{font-size:.75rem;justify-content:center;overflow:hidden;padding:8px 4px;padding:var(--spacing-sm) var(--spacing-xs);white-space:nowrap}.page-actions .button .button-icon{font-size:.85rem;margin-right:4px}.page-actions .weight-unit-selector{align-items:center;display:flex;gap:8px;gap:var(--spacing-sm);grid-column:1/-1;margin-bottom:0;order:-1}.tracks-map-view{flex-direction:column;height:calc(100vh - 160px);position:relative}.map-sidebar{background:#fff;background:var(--bg-light);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);border-right:none;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);left:0;position:absolute;right:0;top:0;z-index:1000}.map-sidebar,.map-sidebar.collapsed{height:auto;max-height:none;min-width:100%!important;width:100%!important}.map-sidebar-header{padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md)}.sidebar-toggle-btn{transform:rotate(90deg)}.map-sidebar.collapsed .sidebar-toggle-btn{transform:rotate(-90deg)}.map-sidebar .track-list{max-height:200px;overflow-y:auto}.map-floating-list-btn,.map-sidebar.collapsed .track-list{display:none}.map-container-full{flex:1 1;width:100%}.pie-chart-legend{gap:6px 10px;padding:8px;padding:var(--spacing-sm)}.pie-legend-item{font-size:.75rem;padding:3px 6px}.pie-legend-name{max-width:60px}.stats-grid{gap:8px;gap:var(--spacing-sm);grid-template-columns:repeat(2,1fr)!important}.stat-card{padding:8px;padding:var(--spacing-sm)}.stat-card .stat-icon{font-size:1rem;height:36px;width:36px}.stat-card .stat-value{font-size:1.1rem}.stat-card .stat-label{font-size:.7rem}.chart-view-toggle{flex-wrap:wrap}.toggle-btn{padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.card{padding:16px;padding:var(--spacing-md)}.card-header{align-items:center;flex-direction:row;flex-wrap:wrap;gap:8px;gap:var(--spacing-sm)}.card-title{flex:1 1;font-size:1rem;min-width:0}.card-actions{flex-direction:row;flex-shrink:0;gap:4px;gap:var(--spacing-xs)}.card-action-buttons{justify-content:flex-end}.category-section .card-actions{flex-direction:row}.category-section .card-actions .button{padding:4px;padding:var(--spacing-xs)}.form-row{flex-direction:column}.form-group{width:100%}.modal-content{margin:10px;max-height:90vh;max-width:none;width:95%}.tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.tab-button{flex-shrink:0;font-size:.85rem;padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);white-space:nowrap}.tracks-container{flex-direction:column;height:auto}.track-list-panel{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);border-right:none;max-height:300px;width:100%}.map-container-full{height:400px;min-height:400px}.gear-grid{grid-template-columns:1fr}.gear-table{font-size:.75rem}.gear-table td,.gear-table th{font-size:.75rem;padding:4px;padding:var(--spacing-xs) var(--spacing-xs);word-break:break-word}.gear-table td:nth-child(2),.gear-table th:nth-child(2){display:none}.gear-table td:first-child,.gear-table th:first-child{max-width:80px;width:25%}.gear-table td:nth-child(3),.gear-table th:nth-child(3){width:15%}.gear-table td:nth-child(4),.gear-table th:nth-child(4){width:18%}.gear-table td:nth-child(5),.gear-table th:nth-child(5){width:10%}.gear-table td:nth-child(6),.gear-table th:nth-child(6){width:18%}.gear-table td:nth-child(7),.gear-table th:nth-child(7){width:14%}.item-status-badge{font-size:.65rem;padding:2px 4px}.table-actions .button{min-height:28px;min-width:28px;padding:4px}.table-actions .button svg{height:14px;width:14px}.route-detail-header{flex-direction:column}.route-detail-stats{flex-wrap:wrap}.article-container{padding:16px;padding:var(--spacing-md)}.article-title{font-size:1.5rem}.article-meta{gap:8px;gap:var(--spacing-sm)}.article-meta,.dashboard-content{flex-direction:column}.chart-section{width:100%}.section-header{align-items:flex-start;flex-direction:column;gap:8px;gap:var(--spacing-sm)}.section-header h2{font-size:1.1rem}.chart-legend{flex-wrap:wrap;gap:4px;gap:var(--spacing-xs)}.legend-item{font-size:.75rem}}@media (max-width:480px){.content{padding:60px 12px 12px}.mobile-menu-button{height:40px;left:12px;top:12px;width:40px}.page-header h1,.page-title{font-size:1.25rem}.page-actions{grid-template-columns:1fr 1fr}.page-actions .button{font-size:.7rem;padding:4px;padding:var(--spacing-xs)}.page-actions .button .button-icon{font-size:.8rem;margin-right:2px}.page-actions .button span:not(.button-icon){display:none}.page-actions .button .button-icon{margin-right:0}.button{font-size:.85rem;padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md)}.card{border-radius:6px;border-radius:var(--radius-sm);padding:8px;padding:var(--spacing-sm)}.stats-grid{grid-template-columns:1fr!important}.stat-card{align-items:center;flex-direction:row;padding:8px;padding:var(--spacing-sm)}.stat-card .stat-content{flex:1 1}.stat-value{font-size:1.25rem}.stat-label{font-size:.75rem}.pie-chart-legend{gap:4px 8px}.pie-legend-item{font-size:.7rem;padding:2px 4px}.pie-legend-name{max-width:50px}.map-sidebar{max-height:150px}.map-sidebar.collapsed{max-height:40px}.track-list{max-height:100px}.track-list-item{padding:8px;padding:var(--spacing-sm)}.sidebar-footer-icons{flex-wrap:wrap;justify-content:center}.sidebar-icon-button{font-size:1rem;height:40px;width:40px}.hide-on-mobile{display:none}table td,table th{font-size:.75rem;padding:4px 8px;padding:var(--spacing-xs) var(--spacing-sm)}}@media (min-width:769px){.mobile-menu-button,.sidebar-overlay{display:none}.sidebar{left:0;position:relative}}@media print{.button,.card-actions,.page-actions,.page-header,.sidebar,.tabs{display:none!important}.app{display:block}.content{padding:0}.card{border:1px solid #ddd;box-shadow:none}body{background-color:#fff;color:#000;font-family:PingFang SC,Microsoft YaHei,SimSun,sans-serif!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.print-view{display:block!important}@page{margin:1cm}}.markdown-article{margin:0 auto;max-width:900px}.back-button{align-items:center;background:none;border:none;border-radius:10px;border-radius:var(--radius-md);color:#6b7280;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:.9rem;gap:8px;gap:var(--spacing-sm);margin-bottom:24px;margin-bottom:var(--spacing-lg);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.back-button:hover{background-color:#f1f5f9;background-color:var(--bg-dark);color:#10b981;color:var(--primary-color)}.article-header{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);margin-bottom:32px;margin-bottom:var(--spacing-xl);padding-bottom:24px;padding-bottom:var(--spacing-lg)}.article-header .article-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#1f2937,#6b7280);background:linear-gradient(135deg,var(--text-color) 0,var(--text-secondary) 100%);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:700;line-height:1.3;margin-bottom:16px;margin-bottom:var(--spacing-md)}.article-header .article-meta{display:flex;flex-wrap:wrap;gap:24px;gap:var(--spacing-lg)}.article-header .meta-item{align-items:center;color:#9ca3af;color:var(--text-light);display:flex;font-size:.9rem;gap:4px;gap:var(--spacing-xs)}.article-header .meta-item svg{color:#10b981;color:var(--primary-color)}.article-content.markdown-body{background-color:#fff;background-color:var(--bg-light);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);font-size:1rem;line-height:1.8;padding:32px;padding:var(--spacing-xl)}.markdown-body h1{border-bottom:2px solid #d1fae5;border-bottom:2px solid var(--primary-lighter);color:#1f2937;color:var(--text-color);font-size:2rem;font-weight:700;margin-bottom:24px;margin-bottom:var(--spacing-lg);padding-bottom:8px;padding-bottom:var(--spacing-sm)}.markdown-body h1,.markdown-body h2{margin-top:32px;margin-top:var(--spacing-xl)}.markdown-body h2{color:#059669;color:var(--primary-dark);font-size:1.5rem;font-weight:600;margin-bottom:16px;margin-bottom:var(--spacing-md);padding-left:16px;padding-left:var(--spacing-md);position:relative}.markdown-body h2:before{background:linear-gradient(180deg,#10b981,#8b5cf6);background:linear-gradient(180deg,var(--primary-color) 0,var(--accent-color) 100%);border-radius:2px;content:"";height:70%;left:0;position:absolute;top:50%;transform:translateY(-50%);width:4px}.markdown-body h3{color:#1f2937;color:var(--text-color);font-size:1.25rem;font-weight:600;margin-top:24px;margin-top:var(--spacing-lg)}.markdown-body h3,.markdown-body p{margin-bottom:16px;margin-bottom:var(--spacing-md)}.markdown-body p{color:#6b7280;color:var(--text-secondary)}.markdown-body ol,.markdown-body ul{margin-bottom:16px;margin-bottom:var(--spacing-md);padding-left:32px;padding-left:var(--spacing-xl)}.markdown-body li{color:#6b7280;color:var(--text-secondary);margin-bottom:8px;margin-bottom:var(--spacing-sm)}.markdown-body li strong{color:#1f2937;color:var(--text-color)}.markdown-body .table-wrapper{border-radius:10px;border-radius:var(--radius-md);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);margin:24px 0;margin:var(--spacing-lg) 0;overflow-x:auto}.markdown-body table{border-collapse:collapse;font-size:.9rem;width:100%}.markdown-body th{background:linear-gradient(135deg,#10b981,#059669);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-dark) 100%);color:#fff;font-weight:600;text-align:left}.markdown-body td,.markdown-body th{padding:16px;padding:var(--spacing-md)}.markdown-body td{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);color:#6b7280;color:var(--text-secondary)}.markdown-body .inline-code,.markdown-body tr:hover td{background-color:#f1f5f9;background-color:var(--bg-dark)}.markdown-body .inline-code{border-radius:4px;color:#8b5cf6;color:var(--accent-color);font-family:SF Mono,Fira Code,monospace;font-size:.85em;padding:2px 6px}.markdown-body .code-block{background-color:#f1f5f9;background-color:var(--bg-dark);border-radius:10px;border-radius:var(--radius-md);margin:16px 0;margin:var(--spacing-md) 0;overflow-x:auto;padding:16px;padding:var(--spacing-md)}.markdown-body .code-block code{font-family:SF Mono,Fira Code,monospace;font-size:.9rem;line-height:1.5}.markdown-body .article-quote{background-color:#d1fae5;background-color:var(--primary-lighter);border-left:4px solid #10b981;border-left:4px solid var(--primary-color);border-radius:0 10px 10px 0;border-radius:0 var(--radius-md) var(--radius-md) 0;color:#6b7280;color:var(--text-secondary);font-style:italic;margin:24px 0;margin:var(--spacing-lg) 0;padding:16px 24px;padding:var(--spacing-md) var(--spacing-lg)}.markdown-body .article-figure{margin:24px 0;margin:var(--spacing-lg) 0;text-align:center}.markdown-body .article-figure img{border-radius:10px;border-radius:var(--radius-md);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);max-width:100%}.markdown-body .article-figure figcaption{color:#9ca3af;color:var(--text-light);font-size:.85rem;font-style:italic;margin-top:8px;margin-top:var(--spacing-sm)}.article-loading{align-items:center;color:#9ca3af;color:var(--text-light);display:flex;flex-direction:column;justify-content:center;min-height:400px}.stat-card{background:linear-gradient(135deg,#fff,#f1f5f9);background:linear-gradient(135deg,var(--bg-light) 0,var(--bg-dark) 100%);border:1px solid #f3f4f6;border:1px solid var(--border-light);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);flex:1 1;min-width:200px;padding:24px;padding:var(--spacing-lg);text-align:center}.stat-card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.stat-card h3{color:#9ca3af;color:var(--text-light);font-size:.85rem;font-weight:500;letter-spacing:.5px;margin-bottom:8px;margin-bottom:var(--spacing-sm);text-transform:uppercase}.stat-card p{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#10b981,#8b5cf6);background:linear-gradient(135deg,var(--primary-color) 0,var(--accent-color) 100%);-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:700}.route-card{background-color:#fff;background-color:var(--bg-light);border:1px solid #f3f4f6;border:1px solid var(--border-light);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);display:flex;flex-direction:column;height:100%;overflow:hidden;transition:all .25s cubic-bezier(.4,0,.2,1);transition:all var(--transition-normal)}.route-card:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);transform:translateY(-6px)}.route-card-image{align-items:flex-start;background-color:#f1f5f9;background-color:var(--bg-dark);background-position:50%;background-size:cover;display:flex;height:180px;justify-content:flex-end;padding:16px;padding:var(--spacing-md);position:relative}.route-card-image .route-status-badge{position:relative;z-index:2}.route-card-image-overlay{background:linear-gradient(180deg,#0000 40%,#000c);bottom:0;left:0;position:absolute;right:0;top:0;z-index:1}.modal-backdrop{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0009;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:100}.modal{animation:slideIn .3s ease;background-color:#fff;background-color:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);max-height:90vh;max-width:90%;overflow-y:auto;width:500px}.form-group input,.form-group select,.form-group textarea{background-color:#fff;background-color:var(--bg-light);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:10px;border-radius:var(--radius-md);color:#1f2937;color:var(--text-color);font-size:.95rem;padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md);transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#10b981;border-color:var(--primary-color);box-shadow:0 0 0 3px #d1fae5;box-shadow:0 0 0 3px var(--primary-lighter);outline:none}.empty-state{background:linear-gradient(135deg,#fff,#f1f5f9);background:linear-gradient(135deg,var(--bg-light) 0,var(--bg-dark) 100%);border:2px dashed #e5e7eb;border:2px dashed var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);padding:32px 24px;padding:var(--spacing-xl) var(--spacing-lg);text-align:center}.empty-state-icon{color:#9ca3af;color:var(--text-light);font-size:4rem;margin-bottom:24px;margin-bottom:var(--spacing-lg)}.empty-state h3{color:#1f2937;color:var(--text-color);font-size:1.3rem;margin-bottom:8px;margin-bottom:var(--spacing-sm)}.empty-state p{color:#9ca3af;color:var(--text-light);margin-bottom:24px;margin-bottom:var(--spacing-lg)}.route-status-badge{align-items:center;border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 2px 4px #0000001a;display:inline-flex;font-size:.75rem;font-weight:600;gap:4px;letter-spacing:.5px;padding:6px 14px;text-transform:uppercase;transition:all .25s cubic-bezier(.4,0,.2,1);transition:all var(--transition-normal)}.route-status-badge:hover{box-shadow:0 4px 6px #00000026;transform:translateY(-1px)}.status-completed{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.status-preparing{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.status-abandoned{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff}.item-status-badge{align-items:center;border-radius:6px;border-radius:var(--radius-sm);display:inline-flex;font-size:.75rem;font-weight:600;padding:4px 12px;transition:all .25s cubic-bezier(.4,0,.2,1);transition:all var(--transition-normal)}.item-status-wishlist{background:#f59e0b26;border:1.5px solid #f59e0b66;color:#d97706}.item-status-wishlist:hover{background:#f59e0b40;border-color:#f59e0b}.item-status-in-use{background:#10b98126;border:1.5px solid #10b98166;color:#059669}.item-status-in-use:hover{background:#10b98140;border-color:#10b981}.item-status-retired{background:#6b728026;border:1.5px solid #6b728066;color:#4b5563}.item-status-retired:hover{background:#6b728040;border-color:#6b7280}[data-theme=dark] .item-status-wishlist{background:#f59e0b33;border-color:#f59e0b80;color:#fbbf24}[data-theme=dark] .item-status-in-use{background:#10b98133;border-color:#10b98180;color:#34d399}[data-theme=dark] .item-status-retired{background:#6b728033;border-color:#6b728080;color:#9ca3af}.dashboard{padding:24px;padding:var(--spacing-lg)}.dashboard-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;gap:var(--spacing-md);justify-content:space-between;margin-bottom:32px;margin-bottom:var(--spacing-xl)}.dashboard-title{color:#1f2937;color:var(--text-color);font-size:1.5rem;font-weight:700;letter-spacing:-.5px;margin-bottom:4px;margin-bottom:var(--spacing-xs)}.dashboard-subtitle{color:#6b7280;color:var(--text-secondary);font-size:.88rem;font-weight:400}.dashboard-controls{align-items:center;display:flex;gap:16px;gap:var(--spacing-md)}.control-group{align-items:center;display:flex;gap:8px;gap:var(--spacing-sm)}.control-group label{color:#6b7280;color:var(--text-secondary);font-size:.9rem;font-weight:500}.select-input{background:#fff;background:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;border-radius:var(--radius-sm);color:#1f2937;color:var(--text-color);cursor:pointer;font-size:.9rem;padding:8px 12px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast)}.select-input:focus,.select-input:hover{border-color:#10b981;border-color:var(--primary-color)}.select-input:focus{box-shadow:0 0 0 3px #10b9811a;outline:none}.chart-view-toggle{background:#f1f5f9;background:var(--bg-dark);border-radius:10px;border-radius:var(--radius-md);display:flex;gap:4px;padding:4px}.stats-grid{grid-gap:16px;grid-gap:var(--spacing-md);display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:32px;margin-bottom:var(--spacing-xl)}.stat-card,.stats-grid{gap:16px;gap:var(--spacing-md)}.stat-card{align-items:center;background:#fff;background:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:none;display:flex;padding:18px 24px;padding:18px var(--spacing-lg);transition:all .25s cubic-bezier(.4,0,.2,1);transition:all var(--transition-normal)}.stat-card:hover{box-shadow:0 4px 16px #0000000f;transform:translateY(-2px)}.stat-icon{align-items:center;border-radius:10px;border-radius:var(--radius-md);display:flex;font-size:1.2rem;height:44px;justify-content:center;width:44px}.stat-card.primary .stat-icon{background:linear-gradient(135deg,#10b981,#059669);background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:#fff}.stat-card.success .stat-icon{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.stat-card.warning .stat-icon{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.stat-card.info .stat-icon{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.stat-content{display:flex;flex-direction:column;gap:4px}.stat-label{color:#6b7280;color:var(--text-secondary);font-size:.78rem;font-weight:500;letter-spacing:.3px;text-transform:uppercase}.stat-value{color:#1f2937;color:var(--text-color);font-size:1.4rem;font-weight:700;letter-spacing:-.3px}.dashboard-content{grid-gap:16px;grid-gap:var(--spacing-md);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:1fr 340px}@media (max-width:1200px){.dashboard-content{grid-template-columns:1fr}}.chart-section,.details-section{background:#fff;background:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:none;padding:24px;padding:var(--spacing-lg);transition:box-shadow .2s ease}.chart-section:hover,.details-section:hover{box-shadow:0 4px 20px #0000000a}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px;margin-bottom:var(--spacing-lg)}.section-header h2{color:#1f2937;color:var(--text-color);font-size:1.1rem;font-weight:600;letter-spacing:-.2px}.section-badge{background:#d1fae5;background:var(--primary-lighter);border-radius:9999px;border-radius:var(--radius-full);color:#059669;color:var(--primary-dark);font-size:.8rem;font-weight:600;padding:4px 12px}[data-theme=dark] .section-badge{background:#10b981;background:var(--primary-color);color:#f8fafc;color:var(--bg-color)}.chart-container-large{min-height:260px;width:100%}.custom-tooltip{background:#fff;background:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:10px;border-radius:var(--radius-md);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);padding:16px;padding:var(--spacing-md)}.tooltip-label{color:#1f2937;color:var(--text-color);font-weight:600;margin-bottom:4px}.tooltip-value{color:#10b981;color:var(--primary-color);font-size:1.1rem;font-weight:600;margin-bottom:2px}.tooltip-percent{color:#6b7280;color:var(--text-secondary);font-size:.85rem}.insight-cards{grid-gap:16px;grid-gap:var(--spacing-md);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:1fr 1fr;margin-bottom:24px;margin-bottom:var(--spacing-lg)}.insight-card{border-radius:10px;border-radius:var(--radius-md);display:flex;flex-direction:column;gap:4px;padding:16px;padding:var(--spacing-md)}.insight-card.heaviest{background:linear-gradient(135deg,#ef44441a,#dc26261a);border:1px solid #ef44444d}.insight-card.lightest{background:linear-gradient(135deg,#10b9811a,#0596691a);border:1px solid #10b9814d}.insight-label{color:#6b7280;color:var(--text-secondary);font-size:.75rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.insight-category{color:#1f2937;color:var(--text-color);font-size:.95rem;font-weight:600}.insight-value{font-size:1.25rem;font-weight:700}.insight-card.heaviest .insight-value{color:#ef4444;color:var(--danger-color)}.insight-card.lightest .insight-value{color:#10b981;color:var(--primary-color)}.category-list{display:flex;flex-direction:column;gap:16px;gap:var(--spacing-md)}.category-item{flex-direction:column}.category-info,.category-item{display:flex;gap:8px;gap:var(--spacing-sm)}.category-info{align-items:center}.category-color{border-radius:3px;flex-shrink:0;height:12px;width:12px}.category-name{color:#1f2937;color:var(--text-color);font-weight:500}.category-stats{grid-gap:8px;grid-gap:var(--spacing-sm);align-items:center;display:grid;gap:8px;gap:var(--spacing-sm);grid-template-columns:80px 1fr 50px}.category-weight{color:#6b7280;color:var(--text-secondary);font-size:.9rem;font-weight:500}.category-bar-container{background:#f1f5f9;background:var(--bg-dark);height:8px;overflow:hidden}.category-bar,.category-bar-container{border-radius:9999px;border-radius:var(--radius-full)}.category-bar{height:100%;transition:width .35s cubic-bezier(.4,0,.2,1);transition:width var(--transition-slow)}.category-percentage{color:#6b7280;color:var(--text-secondary);font-size:.85rem;font-weight:500;text-align:right}.category-total{grid-gap:8px;grid-gap:var(--spacing-sm);border-top:2px solid #e5e7eb;border-top:2px solid var(--border-color);display:grid;font-weight:600;gap:8px;gap:var(--spacing-sm);grid-template-columns:1fr 80px 50px;margin-top:16px;margin-top:var(--spacing-md);padding-top:16px;padding-top:var(--spacing-md)}.total-label{color:#1f2937;color:var(--text-color)}.total-value{color:#10b981;color:var(--primary-color)}.total-percentage{color:#6b7280;color:var(--text-secondary);text-align:right}.location-weather-section{grid-gap:24px;grid-gap:var(--spacing-lg);display:grid;gap:24px;gap:var(--spacing-lg);grid-template-columns:1fr 1fr;margin-bottom:24px;margin-bottom:var(--spacing-lg)}@media (max-width:1200px){.location-weather-section{grid-template-columns:1fr}}.location-map-card,.weather-forecast-card{background:#fff;background:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);padding:24px;padding:var(--spacing-lg);transition:box-shadow .2s ease}.location-map-card:hover,.weather-forecast-card:hover{box-shadow:0 4px 20px #0000000a}.location-map-card .section-header h2,.weather-forecast-card .section-header h2{align-items:center;display:flex;gap:8px;gap:var(--spacing-sm)}.mini-map-container{border-radius:10px;border-radius:var(--radius-md);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);margin-top:16px;margin-top:var(--spacing-md);overflow:hidden}.weather-error,.weather-loading{color:#6b7280;color:var(--text-secondary);font-size:.95rem;padding:32px;padding:var(--spacing-xl);text-align:center}.weather-days{grid-gap:16px;grid-gap:var(--spacing-md);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:repeat(3,1fr);margin-top:16px;margin-top:var(--spacing-md)}.weather-day{align-items:center;background:#f8fafc;background:var(--bg-color);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:10px;border-radius:var(--radius-md);display:flex;flex-direction:column;gap:8px;gap:var(--spacing-sm);padding:16px;padding:var(--spacing-md);transition:all .25s cubic-bezier(.4,0,.2,1);transition:all var(--transition-normal)}.weather-day:hover{border-color:#10b981;border-color:var(--primary-color);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.weather-date{color:#1f2937;color:var(--text-color);font-size:.9rem;font-weight:600}.weather-icon{color:#10b981;color:var(--primary-color);font-size:2rem}.weather-desc{color:#6b7280;color:var(--text-secondary);font-size:.85rem;text-align:center}.weather-temp{align-items:center;display:flex;font-size:1.1rem;font-weight:600;gap:4px}.temp-max{color:#ef4444;color:var(--danger-color)}.temp-min{color:#3b82f6;color:var(--secondary-color)}.temp-divider{color:#d1d5db;color:var(--text-muted)}.tracks-page{padding:24px;padding:var(--spacing-lg)}.tracks-page .page-header{gap:16px;gap:var(--spacing-md)}.filters-panel,.tracks-page .page-header{flex-wrap:wrap;margin-bottom:24px;margin-bottom:var(--spacing-lg)}.filters-panel{background:#fff;background:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);gap:24px;gap:var(--spacing-lg);padding:16px;padding:var(--spacing-md)}.filter-group,.filters-panel{align-items:center;display:flex}.filter-group{gap:8px;gap:var(--spacing-sm)}.filter-group label{align-items:center;color:#6b7280;color:var(--text-secondary);display:flex;font-size:.9rem;font-weight:500;gap:6px}.filter-stats{background:#d1fae5;background:var(--primary-lighter);border-radius:9999px;border-radius:var(--radius-full);color:#059669;color:var(--primary-dark);font-size:.85rem;font-weight:600;margin-left:auto;padding:6px 12px}[data-theme=dark] .filter-stats{background:#10b981;background:var(--primary-color);color:#f8fafc;color:var(--bg-color)}.view-toggle{background:#f1f5f9;background:var(--bg-dark);border-radius:10px;border-radius:var(--radius-md);display:flex;gap:4px;padding:4px}.toggle-btn{align-items:center;background:#0000;border:none;border-radius:6px;border-radius:var(--radius-sm);color:#6b7280;color:var(--text-secondary);cursor:pointer;display:flex;gap:4px;height:34px;justify-content:center;min-width:34px;padding:0 10px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);white-space:nowrap}.toggle-btn,.toggle-label{font-size:.8rem}.toggle-btn:hover{background:#e2e8f0;background:var(--bg-darker);color:#1f2937;color:var(--text-color)}.toggle-btn.active{background:#fff;background:var(--bg-light);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#10b981;color:var(--primary-color)}.tracks-grid{grid-gap:24px;grid-gap:var(--spacing-lg);display:grid;gap:24px;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.track-card{background:#fff;background:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);overflow:hidden;transition:all .25s cubic-bezier(.4,0,.2,1);transition:all var(--transition-normal)}.track-card:hover{border-color:#10b981;border-color:var(--primary-color);box-shadow:0 8px 24px #00000014;transform:translateY(-3px)}.track-card-map{background:#f1f5f9;background:var(--bg-dark);height:180px;position:relative}.track-card-map-placeholder{align-items:center;background:linear-gradient(135deg,#f1f5f9,#f1f5f9);background:linear-gradient(135deg,var(--bg-secondary) 0,var(--bg-dark) 100%);color:#9ca3af;color:var(--text-light);display:flex;flex-direction:column;gap:8px;gap:var(--spacing-sm);height:100%;justify-content:center}.track-card-map-placeholder .placeholder-icon{font-size:2rem;opacity:.5}.track-card-map-placeholder .loading-spinner.small{border-width:2px;height:24px;width:24px}.track-list-badge.loading{animation:pulse 1.5s infinite;background:#10b981;background:var(--primary-color);color:#fff}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.track-card-overlay{position:absolute;right:8px;right:var(--spacing-sm);top:8px;top:var(--spacing-sm);z-index:1000}.expand-btn{align-items:center;background:#fff;background:var(--bg-light);border:none;border-radius:6px;border-radius:var(--radius-sm);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#6b7280;color:var(--text-secondary);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);width:32px}.expand-btn:hover{background:#10b981;background:var(--primary-color);color:#fff}.track-card-content{padding:16px;padding:var(--spacing-md)}.track-card-title{align-items:center;color:#1f2937;color:var(--text-color);font-size:1.1rem;font-weight:600}.track-card-title,.track-meta{display:flex;gap:8px;gap:var(--spacing-sm);margin-bottom:8px;margin-bottom:var(--spacing-sm)}.track-badge{background:#f1f5f9;background:var(--bg-dark);border-radius:6px;border-radius:var(--radius-sm);color:#6b7280;color:var(--text-secondary);font-size:.75rem;font-weight:500;padding:2px 8px}.track-color-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.track-stats{display:flex;gap:16px;gap:var(--spacing-md);margin-bottom:8px;margin-bottom:var(--spacing-sm)}.track-stat{align-items:center;color:#6b7280;color:var(--text-secondary);display:flex;font-size:.85rem;gap:4px}.track-stat .stat-icon{color:#10b981;color:var(--primary-color)}.track-stat .stat-icon.down{color:#ef4444;color:var(--danger-color)}.track-elevation-range{color:#9ca3af;color:var(--text-light);font-size:.8rem;margin-bottom:16px;margin-bottom:var(--spacing-md)}.track-card-actions{align-items:center;border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;padding-top:8px;padding-top:var(--spacing-sm)}.track-date{align-items:center;color:#9ca3af;color:var(--text-light);display:flex;font-size:.8rem;gap:6px}.tracks-map-view{border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);display:flex;height:calc(100vh - 180px);overflow:hidden;position:relative}.map-sidebar{background:#fff;background:var(--bg-light);border-right:1px solid #e5e7eb;border-right:1px solid var(--border-color);display:flex;flex-direction:column;min-width:280px;transition:width .3s ease,min-width .3s ease;width:280px}.map-sidebar.collapsed{min-width:48px;width:48px}.map-sidebar-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;min-height:52px;padding:16px;padding:var(--spacing-md)}.map-sidebar-header h3{color:#1f2937;color:var(--text-color);font-size:1rem;font-weight:600;margin:0;overflow:hidden;white-space:nowrap}.map-sidebar.collapsed .map-sidebar-header{justify-content:center;padding:8px;padding:var(--spacing-sm)}.sidebar-toggle-btn{align-items:center;background:#f1f5f9;background:var(--bg-dark);border:none;border-radius:6px;border-radius:var(--radius-sm);color:#6b7280;color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;height:32px;justify-content:center;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);width:32px}.sidebar-toggle-btn:hover{background:#d1fae5;background:var(--primary-lighter);color:#10b981;color:var(--primary-color)}.map-floating-list-btn{align-items:center;background:#fff;background:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:10px;border-radius:var(--radius-md);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#1f2937;color:var(--text-color);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:6px;left:60px;padding:8px 12px;position:absolute;top:16px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition-fast);z-index:1000}.map-floating-list-btn:hover{background:#d1fae5;background:var(--primary-lighter);border-color:#10b981;border-color:var(--primary-color);color:#10b981;color:var(--primary-color)}.map-floating-list-btn span{background:#10b981;background:var(--primary-color);border-radius:10px;color:#fff;font-size:.75rem;padding:2px 8px}.track-list{flex:1 1;overflow-y:auto}.track-list-item{align-items:center;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light);cursor:pointer;display:flex;gap:8px;gap:var(--spacing-sm);padding:16px;padding:var(--spacing-md);transition:background .15s cubic-bezier(.4,0,.2,1);transition:background var(--transition-fast)}.track-list-item:hover{background:#f1f5f9;background:var(--bg-dark)}.track-list-item.selected{background:#d1fae5;background:var(--primary-lighter);border-left:3px solid #10b981;border-left:3px solid var(--primary-color)}.track-list-info{flex:1 1;min-width:0}.track-list-name{color:#1f2937;color:var(--text-color);display:block;font-weight:500;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track-list-meta{display:flex;gap:4px;margin-bottom:4px}.track-list-badge{background:#e2e8f0;background:var(--bg-darker);border-radius:3px;color:#9ca3af;color:var(--text-light);font-size:.7rem;font-weight:500;padding:1px 6px}.track-list-distance{color:#9ca3af;color:var(--text-light);font-size:.8rem}.map-container-full{flex:1 1;min-width:0}.leaflet-container{background:#f1f5f9;background:var(--bg-dark);font-family:inherit}.leaflet-control-zoom{border:none!important;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f!important;box-shadow:var(--shadow-md)!important}.leaflet-control-zoom a{background:#fff!important;background:var(--bg-light)!important;border:none!important;color:#1f2937!important;color:var(--text-color)!important;height:32px!important;line-height:32px!important;width:32px!important}.leaflet-control-zoom a:hover{background:#f1f5f9!important;background:var(--bg-dark)!important}.leaflet-control-attribution{background:#fffc!important;font-size:10px!important}[data-theme=dark] .leaflet-control-attribution{background:#1e293bcc!important;color:#9ca3af!important;color:var(--text-light)!important}[data-theme=dark] .leaflet-control-attribution a{color:#10b981!important;color:var(--primary-color)!important}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#d1d5db;background:var(--text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#9ca3af;background:var(--text-light)}.usage-stats-container{padding:16px;padding:var(--spacing-md)}.usage-empty-state{align-items:center;color:#6b7280;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;padding:32px 16px;padding:var(--spacing-xl) var(--spacing-md);text-align:center}.usage-empty-state .empty-icon{color:#9ca3af;color:var(--text-light);font-size:3rem;margin-bottom:16px;margin-bottom:var(--spacing-md)}.usage-empty-state h3{color:#1f2937;color:var(--text-color);font-size:1.1rem}.usage-empty-state h3,.usage-empty-state p{margin-bottom:8px;margin-bottom:var(--spacing-sm)}.usage-empty-state p{font-size:.9rem}.usage-hint-text{background:#f1f5f9;background:var(--bg-dark);border-radius:10px;border-radius:var(--radius-md);font-size:.85rem;margin-top:16px;margin-top:var(--spacing-md);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md)}.usage-summary{background:linear-gradient(135deg,#d1fae5,#3b82f61a);background:linear-gradient(135deg,var(--primary-lighter) 0,#3b82f61a 100%);border-radius:16px;border-radius:var(--radius-lg);display:flex;gap:16px;gap:var(--spacing-md);margin-bottom:24px;margin-bottom:var(--spacing-lg);padding:16px;padding:var(--spacing-md)}.usage-summary-item{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:4px;gap:var(--spacing-xs)}.usage-summary-label{color:#6b7280;color:var(--text-secondary);font-size:.8rem}.usage-summary-value{color:#059669;color:var(--primary-dark);font-size:1.5rem;font-weight:700}.usage-stats-grid-inline{grid-gap:16px;grid-gap:var(--spacing-md);display:grid;gap:16px;gap:var(--spacing-md);grid-template-columns:repeat(2,1fr)}.usage-card{background:#fff;background:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);padding:16px;padding:var(--spacing-md)}.usage-card.most-used{border-left:3px solid #10b981;border-left:3px solid var(--primary-color)}.usage-card.least-used{border-left:3px solid #f59e0b;border-left:3px solid var(--warning-color)}.usage-card-header{align-items:center;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light);display:flex;gap:8px;gap:var(--spacing-sm);margin-bottom:16px;margin-bottom:var(--spacing-md);padding-bottom:8px;padding-bottom:var(--spacing-sm)}.usage-card-header h3{color:#1f2937;color:var(--text-color);font-size:.95rem;font-weight:600;margin:0}.usage-icon{font-size:1.1rem}.usage-icon.high{color:#10b981;color:var(--primary-color)}.usage-icon.low{color:#f59e0b;color:var(--warning-color)}.usage-list{flex-direction:column}.usage-item,.usage-list{display:flex;gap:8px;gap:var(--spacing-sm)}.usage-item{align-items:center;background:#f1f5f9;background:var(--bg-dark);border-radius:10px;border-radius:var(--radius-md);padding:8px;padding:var(--spacing-sm);transition:all .2s ease}.usage-item:hover{background:#e2e8f0;background:var(--bg-darker);transform:translateX(4px)}.usage-rank{color:#10b981;color:var(--primary-color);font-size:.85rem;font-weight:700;min-width:28px}.usage-rank.low{color:#f59e0b;color:var(--warning-color)}.usage-item-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.usage-item-name{color:#1f2937;color:var(--text-color);font-size:.9rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.usage-item-category{color:#6b7280;color:var(--text-secondary);font-size:.75rem}.usage-item-stats{align-items:flex-end;display:flex;flex-direction:column;gap:2px}.usage-count{color:#1f2937;color:var(--text-color);font-size:.85rem;font-weight:600}.usage-rate{background:#d1fae5;background:var(--primary-lighter);border-radius:6px;border-radius:var(--radius-sm);color:#10b981;color:var(--primary-color);font-size:.75rem;padding:2px 6px}.usage-rate.low{background:#f59e0b1a;color:#f59e0b;color:var(--warning-color)}.usage-empty{color:#9ca3af;color:var(--text-light);font-size:.9rem;padding:24px;padding:var(--spacing-lg);text-align:center}.usage-explanation{align-items:center;background:#f1f5f9;background:var(--bg-dark);border-radius:10px;border-radius:var(--radius-md);color:#6b7280;color:var(--text-secondary);display:flex;font-size:.8rem;gap:8px;gap:var(--spacing-sm);margin-top:16px;margin-top:var(--spacing-md);padding:8px 16px;padding:var(--spacing-sm) var(--spacing-md)}.usage-explanation .info-icon{color:#3b82f6;color:var(--secondary-color);flex-shrink:0}@media (max-width:768px){.usage-stats-grid-inline{grid-template-columns:1fr}.usage-summary{flex-direction:column;gap:8px;gap:var(--spacing-sm)}}.usage-scrollable-list{background:#fff;background:var(--bg-light);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);overflow:hidden}.usage-list-header{grid-gap:8px;grid-gap:var(--spacing-sm);background:#f1f5f9;background:var(--bg-dark);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);color:#6b7280;color:var(--text-secondary);display:grid;font-size:.8rem;font-weight:600;gap:8px;gap:var(--spacing-sm);grid-template-columns:60px 1fr 120px 100px 80px;letter-spacing:.5px;padding:16px;padding:var(--spacing-md);text-transform:uppercase}.usage-list-body{max-height:320px;overflow-y:auto}.usage-list-item{grid-gap:8px;grid-gap:var(--spacing-sm);align-items:center;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light);display:grid;gap:8px;gap:var(--spacing-sm);grid-template-columns:60px 1fr 120px 100px 80px;padding:16px;padding:var(--spacing-md);transition:all .2s ease}.usage-list-item:hover{background:#f1f5f9;background:var(--bg-dark)}.usage-list-item.unused{opacity:.6}.usage-list-item:last-child{border-bottom:none}.item-rank{color:#10b981;color:var(--primary-color);font-size:.9rem;font-weight:700}.usage-list-item.unused .item-rank{color:#9ca3af;color:var(--text-light)}.item-name{color:#1f2937;color:var(--text-color);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-category{background:#f1f5f9;background:var(--bg-dark);border-radius:6px;border-radius:var(--radius-sm);color:#6b7280;color:var(--text-secondary);font-size:.85rem;padding:4px 8px}.item-category,.item-count{text-align:center}.count-badge{align-items:center;background:linear-gradient(135deg,#10b981,#059669);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-dark) 100%);border-radius:9999px;border-radius:var(--radius-full);color:#fff;display:inline-flex;font-size:.85rem;font-weight:600;height:28px;justify-content:center;min-width:32px;padding:0 10px}.usage-list-item.unused .count-badge{background:#e2e8f0;background:var(--bg-darker);color:#9ca3af;color:var(--text-light)}.item-rate{color:#10b981;color:var(--primary-color);font-size:.9rem;font-weight:600;text-align:right}.item-rate.zero{color:#9ca3af;color:var(--text-light)}.completed-date-group{animation:slideDown .3s ease;background:linear-gradient(135deg,#10b9810d,#3b82f60d);border:1px dashed #10b981;border:1px dashed var(--primary-color);border-radius:16px;border-radius:var(--radius-lg);margin-top:8px;margin-top:var(--spacing-sm);padding:16px;padding:var(--spacing-md)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.completed-date-group label{align-items:center;color:#059669;color:var(--primary-dark);display:flex;font-weight:600;gap:8px;gap:var(--spacing-sm)}.completed-date-group .label-icon{font-size:1.1rem}.date-input{background:#fff;background:var(--bg-light);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:10px;border-radius:var(--radius-md);color:#1f2937;color:var(--text-color);cursor:pointer;font-family:inherit;font-size:1rem;padding:12px 16px;transition:all .2s ease;width:100%}.date-input:hover{border-color:#34d399;border-color:var(--primary-light)}.date-input:focus{border-color:#10b981;border-color:var(--primary-color);box-shadow:0 0 0 3px #10b98126;outline:none}.form-hint{color:#6b7280;color:var(--text-secondary);display:block;font-size:.8rem;margin-top:8px;margin-top:var(--spacing-sm)}[data-theme=dark] .completed-date-group{background:linear-gradient(135deg,#10b9811a,#3b82f61a);border-color:#059669;border-color:var(--primary-dark)}[data-theme=dark] .date-input{background:#f1f5f9;background:var(--bg-dark);border-color:#e5e7eb;border-color:var(--border-color)}[data-theme=dark] .date-input::-webkit-calendar-picker-indicator{filter:invert(1)}@media (max-width:768px){.usage-list-header,.usage-list-item{grid-template-columns:50px 1fr 80px 60px}.usage-list-header .header-category,.usage-list-item .item-category{display:none}}.page-loader{align-items:center;animation:loaderFadeIn .3s ease both;display:flex;height:60vh;justify-content:center;width:100%}@keyframes loaderFadeIn{0%{opacity:0}to{opacity:1}}.page-loader-spinner{animation:page-spin .6s linear infinite;border:3px solid #e5e7eb;border-top-color:#10b981;border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--primary-color);height:36px;width:36px}@keyframes page-spin{to{transform:rotate(1turn)}}.gear-search-toggle{align-items:center;border-radius:10px!important;border-radius:var(--radius-md)!important;display:flex;height:40px;justify-content:center;padding:0!important;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)!important;width:40px}.gear-search-toggle.active{background:#10b981!important;background:var(--primary-color)!important;border-color:#10b981!important;border-color:var(--primary-color)!important;color:#fff!important}.gear-search-toggle svg{height:18px;width:18px}.gear-search-bar{margin-bottom:0;max-height:0;opacity:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .3s cubic-bezier(.4,0,.2,1),margin-bottom .4s cubic-bezier(.4,0,.2,1)}.gear-search-bar.open{margin-bottom:20px;max-height:80px;opacity:1}.gear-search-inner{align-items:center;background:#fff;background:var(--bg-light);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:14px;display:flex;padding:0 16px;position:relative;transition:border-color .3s ease,box-shadow .3s ease}.gear-search-inner:focus-within{border-color:#10b981;border-color:var(--primary-color);box-shadow:0 0 0 4px #10b9811a}.gear-search-icon{color:#9ca3af;color:var(--text-light);flex-shrink:0;font-size:18px;margin-right:12px;transition:color .2s ease}.gear-search-inner:focus-within .gear-search-icon{color:#10b981;color:var(--primary-color)}.gear-search-input{background:#0000;border:none;color:#1f2937;color:var(--text-primary);flex:1 1;font-family:inherit;font-size:15px;outline:none;padding:13px 0}.gear-search-input::placeholder{color:#d1d5db;color:var(--text-muted)}.gear-search-clear{align-items:center;background:#f1f5f9;background:var(--bg-dark);border:none;border-radius:50%;color:#6b7280;color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:14px;height:24px;justify-content:center;margin-left:8px;transition:all .2s ease;width:24px}.gear-search-clear:hover{background:#e2e8f0;background:var(--bg-darker);color:#1f2937;color:var(--text-primary)}.gear-search-count{background:#f1f5f9;background:var(--bg-dark);border-radius:20px;color:#9ca3af;color:var(--text-light);flex-shrink:0;font-size:12px;font-weight:500;margin-left:12px;padding:3px 10px;white-space:nowrap}.gear-page .card:first-child{animation-delay:0s}.gear-page .card:nth-child(2){animation-delay:.04s}.gear-page .card:nth-child(3){animation-delay:.08s}.gear-page .card:nth-child(4){animation-delay:.12s}.gear-page .card:nth-child(5){animation-delay:.16s}.gear-page .card:nth-child(6){animation-delay:.2s}.gear-page .card:nth-child(7){animation-delay:.24s}.gear-page .card:nth-child(8){animation-delay:.28s}.gear-page .card.category-section{transition:box-shadow .35s cubic-bezier(.4,0,.2,1),border-color .35s cubic-bezier(.4,0,.2,1),opacity .3s ease}@media (max-width:768px){.gear-table .item-status-badge{font-size:.6rem;padding:1px 4px;white-space:nowrap}.category-section .card-actions .button{font-size:0;position:relative}.category-section .card-actions .button svg{font-size:14px}.gear-table-mobile-card{display:flex;flex-direction:column;gap:8px}.table-actions{gap:2px}}.gear-action-btn .gear-btn-label{white-space:nowrap}@media (max-width:480px){.gear-action-btn .gear-btn-label{display:inline!important;font-size:.75rem}}@media (max-width:768px){.tracks-page .page-actions{display:flex;flex-wrap:wrap;gap:8px}.tracks-page .page-actions .button,.tracks-page .page-actions .view-toggle{flex:none}.tracks-page .page-actions .view-toggle{order:1}.tracks-page .page-actions .view-toggle .toggle-btn{padding:8px 12px}.tracks-grid{gap:12px;grid-template-columns:1fr}.track-card{border-radius:12px}.track-card-map{height:160px}.track-animation-page .page-actions{display:flex;flex-wrap:wrap;gap:6px;width:100%}.track-animation-page .theme-selector{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;order:2;width:100%}.track-animation-page .theme-btn{border-radius:8px;height:32px;width:32px}.track-animation-page .theme-icon{font-size:14px}.track-animation-page .track-selector-wrapper{order:1;width:100%}.track-animation-page .track-selector-btn{font-size:.85rem;justify-content:space-between;padding:8px 12px;width:100%}.playback-controls .control-buttons{flex-wrap:wrap;gap:4px;justify-content:center}.playback-controls .control-btn{font-size:14px;height:36px;width:36px}.playback-controls .play-btn{height:44px;width:44px}.playback-controls .speed-control{font-size:.75rem}.playback-controls .speed-control select{font-size:.75rem;padding:4px 6px}.playback-controls .record-controls{display:flex;gap:4px}.playback-controls .progress-info{font-size:.75rem;text-align:center;width:100%}.animation-container{flex-direction:column}.data-panel{max-height:none;max-width:none;width:100%}.data-panel .stats-grid{grid-template-columns:repeat(2,1fr)!important}.record-tips{display:none}}
/*# sourceMappingURL=main.9f60a826.css.map*/