:root{--bg-base:#0c0c0c;--bg-surface:#141414;--bg-card:#1a1a1a;--bg-card-inner:#111;--bg-input:#1a1a1a;--bg-hover:#222;--border:#ffffff12;--border-hover:#ffffff1f;--border-active:#ffffff2e;--text-primary:#fff;--text-secondary:#aaa;--text-muted:#666;--text-dim:#444;--accent:#6366f1;--accent-hover:#818cf8;--accent-bg:#6366f11a;--green:#22c55e;--green-bg:#22c55e1a;--green-bright:#4ade80;--red:#ef4444;--red-bg:#ef44441a;--red-bright:#f87171;--yellow:#eab308;--font:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", monospace;--sidebar-width:56px;--topbar-height:52px;--radius:12px;--radius-sm:8px;--radius-xs:6px}:root[data-theme=light],[data-theme=light]{--bg-base:#f5f6fa;--bg-surface:#fff;--bg-card:#fff;--bg-card-inner:#f9f9fb;--bg-input:#f1f2f4;--bg-hover:#eef0f3;--border:#00000014;--border-hover:#00000026;--border-active:#00000040;--text-primary:#121212;--text-secondary:#4b5563;--text-muted:#6b7280;--text-dim:#9ca3af;--accent:#6366f1;--accent-hover:#818cf8;--accent-bg:#6366f11a;--green:#10b981;--green-bg:#10b98126;--green-bright:#059669;--red:#ef4444;--red-bg:#ef444426;--red-bright:#dc2626;--yellow:#f59e0b}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{font-family:var(--font);background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}*{scrollbar-width:thin;scrollbar-color:var(--border-hover) transparent}.app-layout{background-color:var(--bg-base);min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border);z-index:50;flex-direction:column;align-items:center;padding:14px 0;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{cursor:pointer;border-radius:8px;width:30px;height:30px;margin-bottom:20px;overflow:hidden}.sidebar-logo img{object-fit:contain;width:100%;height:100%}.sidebar-nav{flex-direction:column;flex:1;align-items:center;gap:4px;display:flex}.sidebar-nav-top{flex-direction:column;align-items:center;gap:4px;display:flex}.sidebar-nav-bottom{flex-direction:column;align-items:center;gap:4px;margin-top:auto;display:flex}.sidebar-icon{border-radius:var(--radius-sm);width:36px;height:36px;color:var(--text-dim);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:all .15s;display:flex}.sidebar-icon:hover{color:var(--text-secondary);background:var(--bg-hover)}.sidebar-icon.active{color:var(--accent);background:var(--accent-bg)}.sidebar-icon svg{width:18px;height:18px}.sidebar-divider{background:var(--border);width:24px;height:1px;margin:8px 0}.main-area{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.topbar{z-index:1000;height:var(--topbar-height);border-bottom:1px solid var(--border);background:var(--bg-surface);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:8px;display:flex}.topbar-right{align-items:center;gap:12px;display:flex}.topbar-pill{border:1px solid var(--border);color:var(--text-secondary);white-space:nowrap;background:0 0;border-radius:999px;align-items:center;gap:6px;padding:5px 12px;font-size:.75rem;font-weight:500;display:flex}.topbar-pill .pill-label{color:var(--text-muted)}.topbar-pill .pill-value{font-family:var(--font-mono);font-weight:600}.topbar-pill .pill-value.positive{color:var(--green)}.topbar-pill .pill-value.negative{color:var(--red)}.topbar-account{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:999px;align-items:center;gap:8px;padding:5px 12px;font-size:.75rem;transition:border-color .15s;display:flex}.topbar-account:hover{border-color:var(--border-hover)}.topbar-icon-btn{width:32px;height:32px;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-xs);background:0 0;border:none;justify-content:center;align-items:center;transition:all .15s;display:flex}.topbar-icon-btn:hover{color:var(--text-secondary);background:var(--bg-hover)}.topbar-icon-btn svg{width:16px;height:16px}.notif-wrapper{position:relative}.notif-active{color:var(--accent)!important;background:var(--accent-bg)!important}.notif-dot{background:var(--red);width:8px;height:8px;box-shadow:0 0 8px var(--red);border-radius:50%;animation:2s ease-in-out infinite notifPulse;position:absolute;top:4px;right:4px}@keyframes notifPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}.notif-dropdown{background:var(--bg-card);border:1px solid var(--border-hover);border-radius:var(--radius);width:360px;box-shadow:0 20px 60px #00000059, 0 8px 20px #0003, 0 0 0 1px var(--border);z-index:2000;animation:.2s cubic-bezier(.16,1,.3,1) notifSlideIn;position:absolute;top:calc(100% + 12px);right:-8px;overflow:hidden}@keyframes notifSlideIn{0%{opacity:0;transform:translateY(-8px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.notif-dropdown:before{content:"";background:var(--bg-card);border-left:1px solid var(--border-hover);border-top:1px solid var(--border-hover);z-index:1;width:12px;height:12px;position:absolute;top:-6px;right:16px;transform:rotate(45deg)}.notif-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px 10px;display:flex}.notif-title{color:var(--text-primary);letter-spacing:-.2px;font-size:.85rem;font-weight:700}.notif-count{color:var(--accent);background:var(--accent-bg);font-size:.68rem;font-weight:600;font-family:var(--font-mono);border-radius:999px;padding:2px 8px}.notif-body{max-height:340px;padding:6px;overflow-y:auto}.notif-section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:6px;padding:8px 10px 4px;font-size:.68rem;font-weight:600;display:flex}.notif-section-dot{border-radius:50%;width:6px;height:6px}.notif-section-dot.triggered{background:var(--red);box-shadow:0 0 6px var(--red)}.notif-section-dot.active{background:var(--green);box-shadow:0 0 6px var(--green)}.notif-item{border-radius:var(--radius-sm);cursor:pointer;color:inherit;align-items:center;gap:12px;padding:10px;text-decoration:none;transition:all .15s;display:flex}.notif-item:hover{background:var(--bg-hover)}.notif-item.triggered{background:var(--red-bg);border-left:3px solid var(--red)}.notif-item.triggered:hover{background:#ef444426}.notif-item-icon{border-radius:var(--radius-xs);justify-content:center;align-items:center;width:36px;min-width:36px;height:36px;display:flex}.notif-item-icon svg{width:16px;height:16px}.notif-item-content{flex:1;min-width:0}.notif-item-title{align-items:center;gap:6px;margin-bottom:3px;font-size:.82rem;display:flex}.notif-symbol{color:var(--text-primary);font-weight:700;font-family:var(--font-mono);letter-spacing:-.3px}.notif-condition{color:var(--text-secondary);text-transform:capitalize;font-size:.75rem}.notif-item-meta{align-items:center;gap:8px;display:flex}.notif-tag{text-transform:uppercase;letter-spacing:.3px;border-radius:999px;padding:1px 6px;font-size:.62rem;font-weight:600}.notif-tag.triggered{color:var(--red);background:var(--red-bg)}.notif-tag.active{color:var(--green);background:var(--green-bg)}.notif-time{color:var(--text-dim);font-size:.68rem;font-family:var(--font-mono)}.notif-item-chevron{color:var(--text-dim);transition:color .15s}.notif-item:hover .notif-item-chevron{color:var(--text-secondary)}.notif-item-chevron svg{width:14px;height:14px}.notif-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:36px 20px;display:flex}.notif-empty svg{width:32px;height:32px;color:var(--text-dim);opacity:.5;margin-bottom:12px}.notif-empty p{color:var(--text-secondary);margin-bottom:4px;font-size:.85rem;font-weight:600}.notif-empty span{color:var(--text-dim);font-size:.72rem}.notif-loading{flex-direction:column;gap:8px;padding:12px 10px;display:flex}.notif-skeleton{border-radius:var(--radius-sm);background:linear-gradient(90deg, var(--bg-hover) 25%, var(--bg-card-inner) 50%, var(--bg-hover) 75%);background-size:200% 100%;height:52px;animation:1.5s ease-in-out infinite notifShimmer}@keyframes notifShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.notif-footer{border-top:1px solid var(--border);padding:10px 16px}.notif-view-all{width:100%;color:var(--accent);background:var(--accent-bg);border-radius:var(--radius-sm);cursor:pointer;justify-content:center;align-items:center;gap:6px;padding:8px;font-size:.78rem;font-weight:600;text-decoration:none;transition:all .15s;display:flex}.notif-view-all:hover{background:var(--accent-bg);filter:brightness(1.3)}.notif-view-all svg{width:14px;height:14px;transition:transform .2s}.notif-view-all:hover svg{transform:translate(3px)}.content{flex:1;padding:32px 40px;overflow-y:auto}.content-inner{width:100%;max-width:1800px;margin:0 auto}.overview-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.overview-title{color:var(--text-primary);letter-spacing:-.3px;font-size:1.3rem;font-weight:600}.search-container{z-index:100;position:relative}.search-input-wrapper{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);cursor:pointer;align-items:center;gap:8px;width:140px;padding:8px 14px;transition:all .5s cubic-bezier(.16,1,.3,1);display:flex}.search-input-wrapper:hover{border-color:var(--border-hover)}.search-input-wrapper.expanded{border-color:var(--accent);width:320px;box-shadow:0 0 0 2px var(--accent-bg);cursor:text}.search-input-wrapper svg{width:14px;height:14px;color:var(--text-muted);flex-shrink:0}.search-input-wrapper input{color:var(--text-primary);font-family:var(--font);background:0 0;border:none;outline:none;flex:1;width:100%;font-size:.82rem}.search-shortcut{color:var(--text-dim);border:1px solid var(--border);font-size:.68rem;font-family:var(--font-mono);border-radius:4px;margin-left:auto;padding:2px 6px}.search-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:360px;max-height:480px;margin-top:8px;padding:8px;position:absolute;top:100%;right:0;overflow-y:auto;box-shadow:0 10px 40px #0003}.search-dropdown-item{border-radius:var(--radius-sm);cursor:pointer;justify-content:space-between;align-items:center;padding:12px 16px;transition:background .15s;display:flex}.search-dropdown-item:hover{background:var(--bg-hover)}.overview-cards{grid-template-columns:1fr 360px;gap:20px;margin-bottom:24px;display:grid}.balance-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;padding:16px 18px;display:flex}.balance-card-header{justify-content:space-between;align-items:center;margin-bottom:2px;display:flex}.balance-card-title{color:var(--text-secondary);font-size:.78rem;font-weight:600}.balance-toggle{border:1px solid var(--border);border-radius:var(--radius-xs);gap:0;display:flex;overflow:hidden}.balance-toggle-btn{cursor:pointer;color:var(--text-muted);font-size:.7rem;font-weight:500;font-family:var(--font);background:0 0;border:none;padding:4px 12px;transition:all .15s}.balance-toggle-btn.active{background:var(--text-primary);color:var(--bg-base)}.balance-toggle-btn:hover:not(.active){color:var(--text-secondary)}.balance-amount{color:var(--text-primary);font-size:1.8rem;font-weight:700;font-family:var(--font);letter-spacing:-1px;margin-top:2px}.balance-sub{color:var(--text-dim);margin-top:2px;margin-bottom:8px;font-size:.7rem}.balance-periods{align-self:flex-end;align-items:center;gap:0;margin-bottom:6px;display:flex}.period-btn{cursor:pointer;color:var(--text-muted);font-size:.68rem;font-weight:500;font-family:var(--font);border-radius:var(--radius-xs);background:0 0;border:1px solid #0000;padding:4px 10px;transition:all .15s}.period-btn.active{background:var(--bg-hover);border-color:var(--border);color:var(--text-primary)}.period-btn:hover:not(.active){color:var(--text-secondary)}.chart-container{flex:1;min-height:130px;max-height:150px;margin-bottom:8px;position:relative}.chart-canvas{width:100%;height:100%;min-height:130px;max-height:150px}.chart-y-labels{flex-direction:column;justify-content:space-between;padding:8px 0;display:flex;position:absolute;top:0;bottom:0;right:0}.chart-y-label{color:var(--text-dim);font-size:.65rem;font-family:var(--font-mono);text-align:right}.chart-x-labels{justify-content:space-between;margin-top:8px;display:flex}.chart-x-label{color:var(--text-dim);font-size:.62rem;font-family:var(--font-mono)}.action-buttons{border-top:1px solid var(--border);grid-template-columns:repeat(4,1fr);gap:8px;margin-top:8px;padding-top:16px;display:grid}.action-btn{cursor:pointer;font-size:.82rem;font-weight:500;font-family:var(--font);border-radius:var(--radius-sm);text-align:center;border:1px solid var(--border);color:var(--text-muted);background:0 0;padding:10px 16px;transition:all .15s}.action-btn:hover{color:var(--text-secondary);border-color:var(--border-hover);background:var(--bg-hover)}.action-btn.active{color:var(--text-primary);border-color:var(--border-active);background:0 0}.swap-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;padding:16px 18px;display:flex}.swap-card-title{color:var(--text-primary);margin-bottom:12px;font-size:.78rem;font-weight:600}.swap-input-group{margin-bottom:8px}.swap-label{color:var(--text-dim);margin-bottom:6px;font-size:.7rem;display:block}.swap-input-row{background:var(--bg-card-inner);border:1px solid var(--border);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.swap-input-value{color:var(--text-primary);font-size:1.4rem;font-weight:600;font-family:var(--font);letter-spacing:-.5px}.swap-input-value .decimal{color:var(--text-dim)}.swap-token{cursor:pointer;color:var(--text-secondary);border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:.78rem;font-weight:500;display:flex}.swap-token svg{width:12px;height:12px;color:var(--text-dim)}.swap-arrow{justify-content:center;align-items:center;margin:4px auto;display:flex}.swap-arrow-circle{border:1px solid var(--border);background:var(--bg-card-inner);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex}.swap-arrow-circle:hover{border-color:var(--border-hover);background:var(--bg-hover)}.swap-arrow-circle svg{width:14px;height:14px;color:var(--text-secondary)}.swap-info{border-top:1px solid var(--border);justify-content:space-between;margin-top:6px;padding:6px 0;display:flex}.swap-info-label{color:var(--text-dim);font-size:.72rem}.swap-info-value{color:var(--text-secondary);font-size:.72rem;font-weight:500}.swap-submit{background:var(--accent);color:#fff;border-radius:var(--radius-sm);width:100%;font-size:.82rem;font-weight:600;font-family:var(--font);cursor:pointer;border:none;margin-top:auto;padding:10px;transition:all .15s}.swap-submit:hover{background:var(--accent-hover)}.table-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.table-wrapper{scrollbar-width:thin;scrollbar-color:var(--border) transparent;overflow-x:auto}.stock-table{border-collapse:collapse;width:100%}.stock-table thead{z-index:10;position:sticky;top:0}.stock-table th{text-align:left;color:var(--text-dim);background:var(--bg-card);border-bottom:1px solid var(--border);white-space:nowrap;-webkit-user-select:none;user-select:none;padding:14px 20px;font-size:.72rem;font-weight:500}.stock-table th.sortable{cursor:pointer;transition:color .15s}.stock-table th.sortable:hover{color:var(--text-secondary)}.th-rank{text-align:center;width:40px}.th-price,.th-change,.th-change-abs,.th-volume,.th-mcap{text-align:right}.th-rec,.td-rec{text-align:center;width:90px}.th-ind,.td-ind{text-align:center;min-width:100px}.stock-table td{border-bottom:1px solid var(--border);padding:14px 20px}.stock-table tbody tr{cursor:pointer;transition:background .1s}.stock-table tbody tr:hover{background:#ffffff05}.stock-table tbody tr:last-child td{border-bottom:none}.td-rank{text-align:center;color:var(--text-dim);font-size:.75rem}.td-symbol{font-weight:600;font-family:var(--font-mono);color:var(--text-primary);font-size:.82rem}.stock-logo{vertical-align:middle;background:#ffffff0a;border-radius:50%;width:24px;height:24px;margin-right:10px}.td-name{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:.72rem;overflow:hidden}.td-price{text-align:right;font-family:var(--font-mono);font-size:.85rem;font-weight:600}.td-change{text-align:right;font-family:var(--font-mono);font-size:.8rem;font-weight:600}.td-change.positive{color:var(--green)}.td-change.negative{color:var(--red)}.td-change-abs{text-align:right;font-family:var(--font-mono);font-size:.78rem}.td-change-abs.positive{color:var(--green-bright)}.td-change-abs.negative{color:var(--red-bright)}.td-volume,.td-mcap{text-align:right;font-family:var(--font-mono);color:var(--text-secondary);font-size:.78rem}.range-bar{min-width:120px}.range-values{flex-direction:column;gap:2px;width:100%;display:flex}.range-track{background:#ffffff0f;border-radius:2px;width:100%;height:3px;position:relative;overflow:hidden}.range-fill{border-radius:2px;height:100%;transition:width .4s;position:absolute;left:0}.range-fill.in-green{background:var(--green)}.range-fill.in-red{background:var(--red)}.range-fill.in-neutral{background:var(--text-dim)}.range-labels{width:100%;font-size:.6rem;font-family:var(--font-mono);color:var(--text-dim);justify-content:space-between;display:flex}.signal-badge{border-radius:var(--radius-xs);text-transform:uppercase;letter-spacing:.3px;text-align:center;white-space:nowrap;padding:3px 10px;font-size:.62rem;font-weight:700;display:inline-block}.signal-badge.strong-buy{color:var(--green);background:var(--green-bg)}.signal-badge.buy{color:var(--green-bright);background:#22c55e0f}.signal-badge.neutral{color:var(--text-muted);background:#ffffff08}.signal-badge.sell{color:var(--red-bright);background:#ef44440f}.signal-badge.strong-sell{color:var(--red);background:var(--red-bg)}.liquidity-dots{justify-content:center;gap:4px;display:flex}.liquidity-dot{background:var(--accent);border-radius:50%;width:6px;height:6px}.liquidity-dot.dim{background:var(--text-dim)}.skeleton-row td{padding:14px 20px}.skeleton{position:relative;overflow:hidden}.skeleton-block{background:#ffffff0a;border-radius:4px}.skeleton:after{content:"";background:linear-gradient(90deg,#0000,#ffffff05,#0000);width:100%;height:100%;animation:2s infinite shimmer;position:absolute;top:0;left:-100%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;justify-content:center;align-items:center;padding:24px;display:none;position:fixed;inset:0}.modal-overlay.active{display:flex}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:680px;max-height:85vh;animation:.2s ease-out modalIn;overflow-y:auto}@keyframes modalIn{0%{opacity:0;transform:scale(.97)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-close{background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-xs);width:30px;height:30px;color:var(--text-muted);cursor:pointer;z-index:1;justify-content:center;align-items:center;font-size:1.1rem;transition:all .15s;display:flex;position:absolute;top:16px;right:16px}.modal-close:hover{color:var(--text-primary);border-color:var(--border-hover)}.modal-content{padding:24px;position:relative}.modal-header{margin-bottom:20px}.modal-symbol{color:var(--text-primary);font-size:1.4rem;font-weight:800;font-family:var(--font-mono);letter-spacing:-.3px}.modal-name{color:var(--text-muted);margin-top:3px;font-size:.78rem}.modal-price-block{margin-bottom:20px}.modal-price{font-size:2rem;font-weight:700;font-family:var(--font);color:var(--text-primary);letter-spacing:-1px}.modal-change{font-size:.85rem;font-weight:600;font-family:var(--font-mono);margin-top:3px}.modal-grid{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.modal-stat{background:var(--bg-card-inner);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px}.modal-stat-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px;font-size:.62rem;font-weight:600}.modal-stat-value{font-size:.85rem;font-weight:600;font-family:var(--font-mono);color:var(--text-primary)}.search-modal-overlay{z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:flex-start;padding-top:120px;display:flex;position:fixed;inset:0}.search-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:480px;animation:.15s ease-out modalIn;overflow:hidden}.search-modal-input{border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text-primary);font-family:var(--font);background:0 0;outline:none;padding:16px 20px;font-size:.92rem}.search-modal-input::placeholder{color:var(--text-dim)}.search-modal-results{max-height:320px;overflow-y:auto}.search-modal-item{cursor:pointer;border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 20px;transition:background .1s;display:flex}.search-modal-item:hover{background:var(--bg-hover)}.search-modal-item:last-child{border-bottom:none}.search-modal-item .sr-symbol{font-weight:600;font-family:var(--font-mono);color:var(--text-primary);font-size:.82rem}.search-modal-item .sr-name{color:var(--text-dim);margin-top:2px;font-size:.7rem}.search-modal-item .sr-price{text-align:right;font-family:var(--font-mono);font-size:.82rem}@media (max-width:1024px){.overview-cards{grid-template-columns:1fr}.swap-card{display:none}.modal-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){html,body{max-width:100vw;overflow-x:hidden}.app-layout,.main-area{width:100%;max-width:100vw;overflow-x:hidden}.content{overflow-x:hidden}.content-inner{max-width:100%;overflow-x:hidden}.sidebar{display:none}.main-area{margin-left:0}.content{padding:16px 14px}.topbar{padding:0 12px;overflow:hidden}.topbar-pill{padding:4px 8px;font-size:.68rem}.topbar-account{background:var(--bg-surface);border:1px solid var(--border);white-space:nowrap;border-radius:999px;align-items:center;padding:4px 10px;font-size:.68rem;display:flex}.topbar-right .topbar-icon-btn{display:none}.overview-header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:12px}.overview-title{font-size:1.15rem}.search-input-wrapper,.search-input-wrapper.expanded{width:100%}.search-dropdown{width:100%;left:0;right:0}.search-shortcut{display:none}.overview-cards{grid-template-columns:1fr;gap:14px;max-width:100%;margin-bottom:16px}.swap-card{display:none}.balance-card{box-sizing:border-box;border-radius:12px;max-width:100%;padding:14px}.balance-card-header{flex-direction:column;align-items:flex-start;gap:6px}.balance-card-title{font-size:.72rem}.balance-toggle{align-self:flex-start}.balance-amount{font-size:1.6rem}.balance-sub{margin-bottom:6px;font-size:.68rem}.balance-periods{align-self:flex-start;gap:0}.period-btn{padding:4px 8px;font-size:.65rem}.chart-container{min-height:110px;max-height:130px;margin-bottom:6px}.chart-canvas{min-height:110px;max-height:130px}.action-buttons{box-sizing:border-box;grid-template-columns:repeat(2,1fr);gap:6px;max-width:100%;margin-top:6px;padding-top:10px}.action-btn{text-overflow:ellipsis;white-space:nowrap;padding:8px 10px;font-size:.76rem;overflow:hidden}.modal-grid{grid-template-columns:repeat(2,1fr)}.modal{max-width:100%;margin:10px}}.bg-gradient,.bg-grid{display:none}.skeleton-base{background-color:var(--bg-card-inner);background-image:linear-gradient(90deg,#fff0 0%,#ffffff08 20%,#ffffff0f 60%,#fff0 100%);background-size:200% 100%;flex-shrink:0;animation:1.5s linear infinite shimmer;display:inline-block}[data-theme=light] .skeleton-base,:root[data-theme=light] .skeleton-base{background-image:linear-gradient(90deg,#0000 0%,#00000008 20%,#0000000f 60%,#0000 100%)}.user-menu{align-items:center;display:flex;position:relative}.sidebar-icon.user-avatar-btn{border-radius:50%;justify-content:center;align-items:center;padding:0;display:flex;overflow:hidden}.user-avatar{object-fit:cover;border-radius:50%;width:22px;height:22px}.user-avatar-fallback{background:linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 60%, #000));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.65rem;font-weight:700;display:flex}.user-dropdown{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);z-index:1000;width:220px;padding:8px;animation:.2s userMenuSlide;position:absolute;bottom:0;left:48px;box-shadow:0 10px 25px #00000080}@keyframes userMenuSlide{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.user-dropdown-header{align-items:center;gap:12px;padding:12px 8px;display:flex}.user-dropdown-avatar{border-radius:50%;flex-shrink:0;width:36px;height:36px}.user-dropdown-name{color:var(--text-primary);font-size:.9rem;font-weight:700}.user-dropdown-email{color:var(--text-muted);word-break:break-all;font-size:.72rem}.user-dropdown-divider{background:var(--border);height:1px;margin:4px 0}.user-dropdown-item{border-radius:var(--radius-sm);width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:10px 12px;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .2s;display:flex}.onboard-overlay{-webkit-backdrop-filter:blur(8px);z-index:9999;background:#0009;justify-content:center;align-items:center;padding:20px;animation:.3s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.onboard-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:20px;flex-direction:column;gap:30px;width:100%;max-width:480px;padding:40px;animation:.4s cubic-bezier(.16,1,.3,1) slideUp;display:flex;position:relative;box-shadow:0 24px 48px #0009}.onboard-close-btn{background:var(--bg-hover);border:1px solid var(--border);width:32px;height:32px;color:var(--text-muted);cursor:pointer;z-index:1;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:16px;right:16px}.onboard-close-btn:hover:not(:disabled){color:var(--red,#ef4444);border-color:var(--red,#ef4444);background:#ef44441a}.onboard-close-btn:disabled{opacity:.4;cursor:not-allowed}.onboard-close-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin}.ai-insight-card{background:linear-gradient(145deg, var(--bg-surface), var(--bg-hover));border:1px solid var(--border-hover);border-radius:12px;margin-top:20px;padding:16px;position:relative;overflow:hidden;box-shadow:0 4px 20px #00000026}.ai-insight-card:before{content:"";background:linear-gradient(90deg, transparent, var(--accent), transparent);opacity:.5;height:2px;position:absolute;top:0;left:0;right:0}.ai-insight-header{align-items:center;gap:8px;margin-bottom:12px;display:flex}.ai-param-icon{font-size:1.1rem}.ai-insight-title{color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;font-size:.9rem;font-weight:800}.ai-insight-badge{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent);border-radius:4px;margin-left:auto;padding:2px 6px;font-size:.65rem;font-weight:700}.ai-insight-body{color:var(--text-secondary);font-size:.85rem;line-height:1.5}.ai-insight-text{margin:0}.ai-skeleton-container{flex-direction:column;gap:8px;display:flex}.ai-skeleton-line{background:var(--bg-input);border-radius:4px;height:12px;position:relative;overflow:hidden}.ai-skeleton-line:after{content:"";background:linear-gradient(90deg,#0000,#ffffff0d,#0000);animation:1.5s infinite ai-shimmer;position:absolute;inset:0}@keyframes ai-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.onboard-header{text-align:center;flex-direction:column;align-items:center;gap:12px;display:flex}.onboard-logo{background:var(--bg-surface);border:1px solid var(--border);border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:8px;display:flex;box-shadow:0 8px 16px #0003}.onboard-logo img{width:32px;height:auto}.onboard-title{color:var(--text-primary);letter-spacing:-.5px;font-size:1.6rem;font-weight:800}.onboard-subtitle{color:var(--text-secondary);font-size:.95rem}.onboard-steps{justify-content:center;align-items:center;gap:12px;margin-bottom:10px;display:flex}.onboard-step-dot{background:var(--bg-input);border:2px solid var(--border);border-radius:50%;width:12px;height:12px;transition:all .3s}.onboard-step-dot.active{background:var(--accent);border-color:var(--accent);box-shadow:0 0 10px var(--accent)}.onboard-step-line{background:var(--border);border-radius:1px;width:40px;height:2px}.onboard-body{flex-direction:column;gap:24px;display:flex}.onboard-label{color:var(--text-primary);justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.9rem;font-weight:700;display:flex}.onboard-tag{background:var(--bg-input);color:var(--text-secondary);border-radius:4px;padding:2px 8px;font-size:.75rem}.onboard-tag.ok{color:#10b981;background:#10b9811a}.onboard-tag.err{color:#ef4444;background:#ef44441a}.onboard-pic-area{flex-direction:column;align-items:center;gap:16px;margin:10px 0;display:flex}.onboard-pic-preview{background:var(--bg-input);border:2px dashed var(--border);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;transition:all .2s;display:flex;position:relative;overflow:hidden}.onboard-pic-preview:hover{border-color:var(--accent)}.onboard-pic-preview img{object-fit:cover;width:100%;height:100%}.onboard-pic-placeholder{color:var(--text-muted)}.onboard-pic-overlay{color:#fff;opacity:0;background:#0009;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:absolute;inset:0}.onboard-pic-preview:hover .onboard-pic-overlay{opacity:1}.onboard-pic-hint{color:var(--text-dim);font-size:.8rem}.onboard-input-wrap{background:var(--bg-input);border:1px solid var(--border);border-radius:12px;align-items:center;transition:border-color .2s;display:flex;overflow:hidden}.onboard-input-wrap:focus-within{border-color:var(--accent)}.onboard-input-prefix{color:var(--text-muted);padding:14px 0 14px 16px;font-size:1rem;font-weight:600}.onboard-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;width:100%;padding:14px 16px 14px 8px;font-size:1rem;font-weight:600}.onboard-input.full{background:var(--bg-input);border:1px solid var(--border);border-radius:12px;padding:14px 16px;transition:border-color .2s}.onboard-input.full:focus{border-color:var(--accent)}.onboard-hint{color:var(--text-dim);margin-top:6px;font-size:.75rem;display:block}.onboard-error{color:#ef4444;text-align:center;background:#ef44441a;border:1px solid #ef444433;border-radius:8px;padding:12px;font-size:.85rem;font-weight:600}.onboard-actions{gap:12px;margin-top:10px;display:flex}.onboard-btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:8px;padding:14px;font-size:1rem;font-weight:700;transition:all .2s;display:flex}.onboard-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 16px #6f42c14d}.onboard-btn-primary:active:not(:disabled){transform:translateY(0)}.onboard-btn-primary:disabled{opacity:.5;cursor:not-allowed}.onboard-btn-secondary{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:14px 20px;font-size:1rem;font-weight:700;transition:all .2s;display:flex}.onboard-btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary)}@media (max-width:600px){.onboard-modal{width:95%;padding:30px 20px}.onboard-actions{flex-direction:column}}@media (max-width:768px){.hide-on-mobile{display:none!important}}.signin-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.signin-card{background:var(--bg-surface);border:1px solid var(--border);text-align:center;border-radius:20px;width:100%;max-width:420px;padding:40px 32px;box-shadow:0 20px 60px #0000004d}.signin-logo{margin-bottom:32px}.signin-logo-img{width:80px;height:auto;margin:0 auto 16px;display:block}.signin-logo h1{color:var(--text-primary);margin:0 0 6px;font-size:1.8rem;font-weight:800}.signin-logo p{color:var(--text-muted);margin:0;font-size:.85rem}.signin-error{color:#ef4444;background:#ef44441a;border:1px solid #ef444433;border-radius:10px;margin-bottom:20px;padding:12px;font-size:.85rem;font-weight:600}.signin-google-btn{background:var(--bg-card);border:1px solid var(--border);width:100%;color:var(--text-primary);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;gap:12px;padding:14px 20px;font-family:inherit;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.signin-google-btn:hover{background:var(--bg-hover);border-color:var(--border-hover);transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.signin-google-btn:active{transform:translateY(0)}.signin-footer{color:var(--text-dim);margin-top:24px;font-size:.75rem}.signin-footer a{color:var(--accent);text-decoration:none}.signin-footer a:hover{text-decoration:underline}@media (max-width:768px){.signin-card{border-radius:16px;padding:32px 24px}.signin-logo h1{font-size:1.5rem}.signin-google-btn{padding:12px 16px;font-size:.9rem}}
.mob-bottom-nav{display:none}@media (max-width:768px){.mob-bottom-nav{z-index:9000;background:var(--bg-surface);border-top:1px solid var(--border);-webkit-backdrop-filter:blur(16px);height:64px;padding:0 4px;padding-bottom:env(safe-area-inset-bottom,0px);box-sizing:border-box;justify-content:space-around;align-items:center;width:100%;max-width:100vw;display:flex;position:fixed;bottom:0;left:0;right:0}.mob-nav-item{color:var(--text-dim);letter-spacing:.3px;-webkit-tap-highlight-color:transparent;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;padding:6px 0;font-size:.6rem;font-weight:600;text-decoration:none;transition:color .2s;display:flex;position:relative}.mob-nav-item svg{stroke-width:1.6px;width:22px;height:22px;transition:all .2s}.mob-nav-avatar{object-fit:cover;background:var(--bg-card);border-radius:50%;width:24px;height:24px;transition:all .2s}.mob-nav-item.active,.mob-profile-btn.active{color:var(--accent)}.mob-nav-item.active svg{filter:drop-shadow(0 0 4px var(--accent-bg))}.mob-profile-trigger.active svg{filter:none}.mob-nav-item.active .mob-nav-avatar{box-shadow:none}.mob-profile-trigger,.mob-more-trigger{position:relative}.mob-more-menu{width:auto;min-width:200px;left:50%;transform:translate(-50%);animation:.22s ease-out mobMoreSlideUp!important;right:auto!important}@keyframes mobMoreSlideUp{0%{opacity:0;transform:translate(-50%)translateY(8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.mob-profile-btn{color:var(--text-dim);font-size:inherit;font-weight:inherit;letter-spacing:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:2px;width:100%;padding:6px 0;transition:color .2s;display:flex}.mob-profile-btn.active{color:var(--accent)}.mob-profile-btn span{color:inherit;font-size:inherit;font-weight:inherit;letter-spacing:inherit}.mob-profile-btn svg{stroke-width:1.6px;width:22px;height:22px}.mob-profile-menu{background:var(--bg-surface);border:1px solid var(--border);z-index:9999;border-radius:16px;width:240px;padding:12px;animation:.22s ease-out mobMenuSlideUp;position:absolute;bottom:calc(100% + 12px);right:-8px;box-shadow:0 -12px 40px #00000080}.mob-profile-header{text-align:center;flex-direction:column;align-items:center;padding:12px 0 16px;display:flex}.mob-profile-avatar-wrap{border-radius:50%;width:52px;height:52px;margin-bottom:12px}.mob-pm-avatar,.mob-pm-avatar-fallback{object-fit:cover;border-radius:50%;width:100%;height:100%}.mob-pm-avatar-fallback{background:var(--bg-card);color:var(--accent);justify-content:center;align-items:center;font-size:1.2rem;font-weight:700;display:flex}.mob-profile-name{color:var(--text-primary);margin-bottom:2px;font-size:1rem;font-weight:700;line-height:1.2}.mob-profile-sub{flex-direction:column;align-items:center;gap:1px;display:flex}.mob-profile-username{color:var(--accent);font-size:.75rem;font-weight:700}.mob-profile-email{color:var(--text-dim);font-size:.7rem;font-weight:500}@keyframes mobMenuSlideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.mob-pm-item{color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-size:.85rem;font-weight:600;text-decoration:none;transition:all .15s;display:flex}.mob-pm-item svg{stroke-width:1.6px;flex-shrink:0;width:18px;height:18px}.mob-pm-item:hover,.mob-pm-item:active{background:var(--bg-hover);color:var(--text-primary)}.mob-pm-divider{background:var(--border);height:1px;margin:4px 8px}.mob-pm-logout{color:var(--red-bright,#ef4444)}.mob-pm-logout:hover{background:var(--red-bg);color:var(--red-bright,#ef4444)}.main-area{padding-bottom:72px!important}}
