@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--bg-base:#0a0b0e;--bg-surface:#12141a;--bg-elevated:#1a1d27;--bg-overlay:#20243a;--border-subtle:#1e2130;--border-default:#252836;--border-strong:#353848;--accent:#6366f1;--accent-hover:#4f46e5;--accent-muted:#6366f126;--accent-glow:#6366f166;--color-up:#22c55e;--color-up-muted:#22c55e1f;--color-down:#ef4444;--color-down-muted:#ef44441f;--color-warning:#f59e0b;--color-warning-muted:#f59e0b1f;--color-info:#38bdf8;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#475569;--text-disabled:#2d3748;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--shadow-sm:0 1px 3px #00000080;--shadow-md:0 4px 12px #0009;--shadow-lg:0 8px 32px #000000b3;--shadow-accent:0 0 20px #6366f14d;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--sidebar-width:220px;--sidebar-collapsed:64px;--topbar-height:56px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:14px}body{font-family:var(--font-sans);background-color:var(--bg-base);color:var(--text-primary);min-height:100vh;line-height:1.5;overflow-x:hidden}#root{flex-direction:column;min-height:100vh;display:flex}a{color:var(--accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-hover)}button{cursor:pointer;font-family:var(--font-sans);background:0 0;border:none;outline:none}input,textarea,select{font-family:var(--font-sans);outline:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-surface)}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}*{scrollbar-width:thin;scrollbar-color:var(--border-strong) var(--bg-surface)}.font-mono{font-family:var(--font-mono)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-up{color:var(--color-up)}.text-down{color:var(--color-down)}.text-accent{color:var(--accent)}.text-warning{color:var(--color-warning)}.text-xs{font-size:11px}.text-sm{font-size:12px}.text-base{font-size:14px}.text-lg{font-size:16px}.text-xl{font-size:18px}.text-2xl{font-size:22px}.text-3xl{font-size:28px}.text-4xl{font-size:36px}.font-light{font-weight:300}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-y-auto{overflow-y:auto}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.rounded-sm{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-full{border-radius:var(--radius-full)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sr-only{clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.glass-card{-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-default);border-radius:var(--radius-lg);background:#12141ad9}.glass-card-elevated{-webkit-backdrop-filter:blur(24px);border:1px solid var(--border-strong);border-radius:var(--radius-lg);background:#1a1d27e6}@keyframes skeleton-pulse{0%,to{opacity:.4}50%{opacity:.7}}.skeleton{background:var(--bg-elevated);border-radius:var(--radius-sm);animation:1.5s ease-in-out infinite skeleton-pulse}@keyframes flash-up{0%{background-color:#0000}20%{background-color:var(--color-up-muted)}to{background-color:#0000}}@keyframes flash-down{0%{background-color:#0000}20%{background-color:var(--color-down-muted)}to{background-color:#0000}}.flash-up{animation:.8s ease-out flash-up}.flash-down{animation:.8s ease-out flash-down}.btn{justify-content:center;align-items:center;gap:var(--space-2);border-radius:var(--radius-md);transition:all var(--transition-base);white-space:nowrap;cursor:pointer;border:1px solid #0000;padding:10px 20px;font-size:14px;font-weight:500;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover);box-shadow:var(--shadow-accent)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-default)}.btn-secondary:hover:not(:disabled){background:var(--bg-overlay);border-color:var(--border-strong)}.btn-ghost{color:var(--text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--bg-elevated);color:var(--text-primary)}.btn-danger{color:var(--color-down);border-color:var(--color-down);background:0 0}.btn-danger:hover:not(:disabled){background:var(--color-down-muted)}.btn-sm{padding:6px 12px;font-size:12px}.btn-lg{border-radius:var(--radius-lg);padding:14px 28px;font-size:16px}.input{background:var(--bg-base);border:1px solid var(--border-default);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:10px 14px;font-size:14px}.input::placeholder{color:var(--text-muted)}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted)}.input:disabled{opacity:.5;cursor:not-allowed}@keyframes shake{0%,to{transform:translate(0)}15%{transform:translate(-8px)}30%{transform:translate(8px)}45%{transform:translate(-6px)}60%{transform:translate(6px)}75%{transform:translate(-4px)}90%{transform:translate(4px)}}.shake{animation:.5s ease-out shake}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fadeIn{animation:fadeIn var(--transition-base) ease}.animate-fadeInUp{animation:fadeInUp var(--transition-slow) ease}.animate-fadeInDown{animation:fadeInDown var(--transition-base) ease}.animate-scaleIn{animation:scaleIn var(--transition-base) ease}@keyframes pulse-glow{0%,to{box-shadow:0 0 8px var(--accent-glow)}50%{box-shadow:0 0 20px var(--accent-glow), 0 0 40px #6366f133}}.glow-accent{animation:2s ease-in-out infinite pulse-glow}.divider{background:var(--border-default);width:100%;height:1px}.badge{border-radius:var(--radius-full);letter-spacing:.03em;text-transform:uppercase;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:500;display:inline-flex}.badge-up{color:var(--color-up);background:var(--color-up-muted)}.badge-down{color:var(--color-down);background:var(--color-down-muted)}.badge-neutral{color:var(--text-secondary);background:var(--bg-elevated)}.badge-accent{color:var(--accent);background:var(--accent-muted)}.app-layout{height:100vh;display:flex;overflow:hidden}.page-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.main-area{padding:var(--space-6);flex:1;overflow-y:auto}.stat-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-5);transition:border-color var(--transition-base), box-shadow var(--transition-base)}.stat-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md)}.scrollbar-thin::-webkit-scrollbar{width:4px}.scrollbar-thin::-webkit-scrollbar-track{background:0 0}.scrollbar-thin::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:4px}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border-default);height:100vh;transition:width var(--transition-base), min-width var(--transition-base);z-index:50;flex-direction:column;display:flex;position:relative;overflow:hidden}.sidebar--collapsed{width:var(--sidebar-collapsed);min-width:var(--sidebar-collapsed)}.sidebar__header{border-bottom:1px solid var(--border-subtle);height:var(--topbar-height);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 12px;display:flex}.sidebar__logo{align-items:center;gap:10px;display:flex;overflow:hidden}.sidebar__logo-icon{background:var(--accent);border-radius:var(--radius-md);color:#fff;width:32px;height:32px;box-shadow:0 0 12px var(--accent-glow);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar__logo-text{letter-spacing:-.02em;color:var(--text-primary);white-space:nowrap;font-size:18px;font-weight:700}.sidebar__logo-accent{color:var(--accent)}.sidebar__toggle{border-radius:var(--radius-sm);width:24px;height:24px;color:var(--text-muted);transition:color var(--transition-fast), background var(--transition-fast);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar__toggle:hover{color:var(--text-primary);background:var(--bg-elevated)}.sidebar__toggle svg{transition:transform var(--transition-base)}.sidebar__toggle svg.rotate-180{transform:rotate(180deg)}.sidebar__nav{flex:1;padding:8px;overflow:hidden auto}.sidebar__nav-group{flex-direction:column;gap:2px;display:flex}.sidebar__nav-item{border-radius:var(--radius-md);color:var(--text-secondary);transition:background var(--transition-fast), color var(--transition-fast);white-space:nowrap;align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.sidebar__nav-item:hover{background:var(--bg-elevated);color:var(--text-primary)}.sidebar__nav-item--active{background:var(--accent-muted);color:var(--accent);border:1px solid #6366f133}.sidebar__nav-item--active:hover{background:var(--accent-muted);color:var(--accent)}.sidebar__nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:18px;display:flex}.sidebar__nav-label{text-overflow:ellipsis;overflow:hidden}.sidebar__footer{border-top:1px solid var(--border-subtle);flex-direction:column;flex-shrink:0;gap:8px;padding:12px 8px;display:flex}.sidebar__user{border-radius:var(--radius-md);align-items:center;gap:10px;padding:8px;display:flex;overflow:hidden}.sidebar__avatar{border-radius:var(--radius-full);background:var(--accent-muted);width:32px;height:32px;color:var(--accent);border:1px solid #6366f14d;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex}.sidebar__user-info{flex-direction:column;min-width:0;display:flex;overflow:hidden}.sidebar__username{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.sidebar__user-status{color:var(--text-muted);white-space:nowrap;font-size:11px}.sidebar__logout{border-radius:var(--radius-md);color:var(--text-muted);transition:background var(--transition-fast), color var(--transition-fast);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:8px 12px;font-size:13px;font-weight:500;display:flex}.sidebar__logout:hover{background:var(--color-down-muted);color:var(--color-down)}.topbar{height:var(--topbar-height);padding:0 var(--space-6);background:var(--bg-surface);border-bottom:1px solid var(--border-default);z-index:40;flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.topbar__left,.topbar__right{align-items:center;gap:var(--space-4);display:flex}.topbar__market{border-radius:var(--radius-full);letter-spacing:.02em;text-transform:uppercase;border:1px solid #0000;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:600;display:flex}.topbar__market-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.topbar__market--open{color:var(--color-up);background:var(--color-up-muted);border-color:#22c55e33}.topbar__market--open .topbar__market-dot{background:var(--color-up);box-shadow:0 0 6px var(--color-up);animation:2s ease-in-out infinite pulse-dot}.topbar__market--pre_market{color:var(--color-warning);background:var(--color-warning-muted);border-color:#f59e0b33}.topbar__market--pre_market .topbar__market-dot{background:var(--color-warning)}.topbar__market--after_hours{color:var(--color-info);background:#38bdf81a;border-color:#38bdf833}.topbar__market--after_hours .topbar__market-dot{background:var(--color-info)}.topbar__market--closed{color:var(--text-muted);background:var(--bg-elevated);border-color:var(--border-subtle)}.topbar__market--closed .topbar__market-dot{background:var(--text-muted)}.topbar__market--unknown{color:var(--text-muted);background:var(--bg-elevated);border-color:var(--border-subtle)}.topbar__market--unknown .topbar__market-dot{background:var(--text-muted)}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.topbar__futu{align-items:center;gap:5px;font-size:12px;font-weight:500;display:flex}.topbar__futu--connected{color:var(--color-up)}.topbar__futu--disconnected{color:var(--color-down)}.topbar__ws{align-items:center;gap:5px;font-size:12px;font-weight:500;display:flex}.topbar__ws--connected{color:var(--color-up)}.topbar__ws--connecting{color:var(--color-warning)}.topbar__ws--disconnected{color:var(--text-muted)}.topbar__ws--error{color:var(--color-down)}.topbar__clock{color:var(--text-secondary);align-items:center;gap:5px;font-size:12px;display:flex}.topbar__time{font-family:var(--font-mono);color:var(--text-primary);font-size:13px;font-weight:500}.topbar__tz{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:10px}.login-page{background:var(--bg-base);justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.login-page__canvas{pointer-events:none;position:absolute;inset:0}.login-page__center{z-index:1;width:100%;max-width:440px;padding:20px;animation:.6s fadeInUp;position:relative}.login-card{-webkit-backdrop-filter:blur(32px);border:1px solid var(--border-default);background:#12141aeb;border-radius:20px;padding:36px;box-shadow:0 32px 80px #0009,0 0 0 1px #6366f11a}.login-card__logo{align-items:center;gap:14px;margin-bottom:28px;display:flex}.login-card__logo-icon{background:var(--accent);color:#fff;width:52px;height:52px;box-shadow:0 0 24px var(--accent-glow), 0 0 48px #6366f133;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;animation:3s ease-in-out infinite pulse-glow;display:flex}.login-card__logo-text{flex-direction:column;gap:2px;display:flex}.login-card__brand{letter-spacing:-.03em;color:var(--text-primary);font-size:26px;font-weight:800}.login-card__brand span{color:var(--accent)}.login-card__tagline{color:var(--text-muted);letter-spacing:.05em;font-size:12px}.login-card__divider{background:var(--border-subtle);height:1px;margin-bottom:24px}.login-card__tabs{background:var(--bg-base);border-radius:var(--radius-md);border:1px solid var(--border-subtle);gap:4px;margin-bottom:24px;padding:4px;display:flex}.login-card__tab{color:var(--text-muted);transition:all var(--transition-base);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:6px;padding:8px;font-size:13px;font-weight:500;display:flex}.login-card__tab:hover{color:var(--text-secondary)}.login-card__tab.active{background:var(--bg-elevated);color:var(--text-primary);box-shadow:0 1px 4px #0000004d}.login-passkey{text-align:center;flex-direction:column;align-items:center;gap:20px;display:flex}.login-passkey__icon-wrap{width:80px;height:80px;color:var(--accent);justify-content:center;align-items:center;display:flex;position:relative}.login-passkey__ring{border:1px solid var(--accent-glow);border-radius:50%;animation:2s ease-in-out infinite pulse-ring;position:absolute;inset:-8px}@keyframes pulse-ring{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.2;transform:scale(1.1)}}.login-passkey__desc{color:var(--text-secondary);max-width:300px;font-size:13px;line-height:1.6}.login-passkey__username{width:100%}.login-passkey__btn{width:100%;padding:14px;font-size:15px}.login-passkey__loading-dots:after{content:"...";animation:1s steps(4,end) infinite dots}@keyframes dots{0%,20%{content:""}40%{content:"."}60%{content:".."}80%,to{content:"..."}}.login-passkey__unsupported{background:var(--color-warning-muted);border-radius:var(--radius-md);color:var(--color-warning);text-align:left;border:1px solid #f59e0b4d;align-items:flex-start;gap:10px;padding:14px;font-size:13px;line-height:1.5;display:flex}.login-password{flex-direction:column;gap:16px;display:flex}.login-password__field{flex-direction:column;gap:6px;display:flex}.login-password__label{color:var(--text-secondary);font-size:12px;font-weight:500}.login-password__input-wrap{position:relative}.login-password__input-wrap .input{padding-right:40px}.login-password__eye{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;align-items:center;padding:0;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.login-password__eye:hover{color:var(--text-secondary)}.login-card__error{background:var(--color-down-muted);border-radius:var(--radius-md);color:var(--color-down);border:1px solid #ef44444d;align-items:center;gap:8px;margin-top:12px;padding:10px 14px;font-size:13px;display:flex}.login-card__content{flex-direction:column;display:flex}.login-card__footer-note{text-align:center;color:var(--text-muted);letter-spacing:.03em;margin-top:24px;font-size:11px}.passkey-setup{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.passkey-setup__bg{pointer-events:none;background:radial-gradient(80% 60% at 50% -20%,#6366f114 0%,#0000 70%),radial-gradient(60% 40% at 80% 80%,#6366f10a 0%,#0000 60%);position:absolute;inset:0}.passkey-setup__container{z-index:1;flex-direction:column;align-items:center;gap:24px;width:100%;max-width:520px;padding:24px;display:flex;position:relative}.passkey-setup__header{align-items:center;gap:10px;display:flex}.passkey-setup__logo{background:var(--accent);border-radius:var(--radius-md);color:#fff;width:32px;height:32px;box-shadow:0 0 16px var(--accent-glow);justify-content:center;align-items:center;display:flex}.passkey-setup__logo-text{color:var(--text-primary);font-size:18px;font-weight:700}.passkey-setup__card{-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid var(--border-default);width:100%;box-shadow:var(--shadow-lg);background:#12141af2;border-radius:20px;padding:40px}.passkey-setup__steps{justify-content:center;align-items:center;gap:0;margin-bottom:36px;display:flex}.passkey-setup__step{border:2px solid var(--border-strong);width:32px;height:32px;color:var(--text-muted);transition:all var(--transition-base);border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex}.passkey-setup__step.active{border-color:var(--accent);color:var(--accent);background:var(--accent-muted)}.passkey-setup__step.done{border-color:var(--color-up);color:var(--color-up);background:var(--color-up-muted)}.passkey-setup__step-line{background:var(--border-default);height:2px;transition:background var(--transition-slow);flex:1;min-width:40px}.passkey-setup__step-line.done{background:var(--color-up)}.passkey-setup__content{text-align:center;flex-direction:column;align-items:center;gap:20px;display:flex}.passkey-setup__icon-wrap{border-radius:24px;justify-content:center;align-items:center;width:88px;height:88px;display:flex}.passkey-setup__icon-wrap--blue,.passkey-setup__icon-wrap--accent{color:var(--accent);background:#6366f11a;border:1px solid #6366f133}.passkey-setup__icon-wrap--accent.pulsing{animation:1.5s ease-in-out infinite pulse-glow}.passkey-setup__title{color:var(--text-primary);letter-spacing:-.02em;font-size:24px;font-weight:700}.passkey-setup__desc{color:var(--text-secondary);max-width:380px;font-size:14px;line-height:1.7}.passkey-setup__benefits{text-align:left;grid-template-columns:1fr 1fr;gap:12px;width:100%;display:grid}.passkey-setup__benefit{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);align-items:flex-start;gap:10px;padding:12px;display:flex}.passkey-setup__benefit svg{flex-shrink:0;margin-top:1px}.passkey-setup__benefit strong{color:var(--text-primary);margin-bottom:2px;font-size:13px;display:block}.passkey-setup__benefit p{color:var(--text-muted);font-size:11px;line-height:1.4}.passkey-setup__warning,.passkey-setup__unsupported,.passkey-setup__error{border-radius:var(--radius-md);text-align:left;align-items:flex-start;gap:8px;width:100%;padding:12px 14px;font-size:13px;line-height:1.5;display:flex}.passkey-setup__warning{background:var(--color-warning-muted);color:var(--color-warning);border:1px solid #f59e0b4d}.passkey-setup__unsupported,.passkey-setup__error{background:var(--color-down-muted);color:var(--color-down);border:1px solid #ef44444d}.passkey-setup__actions{flex-direction:column;align-items:center;gap:10px;width:100%;margin-top:4px;display:flex}.passkey-setup__actions .btn{width:100%}.passkey-setup__loading-dot{background:currentColor;border-radius:50%;width:8px;height:8px;animation:1s ease-in-out infinite pulse-glow}.passkey-setup__content--success{gap:16px}.passkey-setup__success-icon{width:88px;height:88px;color:var(--color-up);justify-content:center;align-items:center;display:flex;position:relative}.passkey-setup__success-ring{border:2px solid var(--color-up);opacity:.3;border-radius:50%;animation:2s ease-in-out infinite pulse-ring;position:absolute;inset:-8px}.passkey-setup__success-tips{flex-direction:column;gap:8px;width:100%;display:flex}.passkey-setup__success-tip{color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;display:flex}.passkey-setup__logout{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;font-size:12px}.passkey-setup__logout:hover{color:var(--color-down)}.dashboard-page{padding:var(--space-6);gap:var(--space-6);flex-direction:column;width:100%;max-width:1400px;margin:0 auto;display:flex}.dashboard-welcome{justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.dashboard-welcome__title{color:var(--text-primary);letter-spacing:-.02em;font-size:22px;font-weight:700}.dashboard-welcome__sub{color:var(--text-muted);margin-top:3px;font-size:13px}.dashboard-status-badge{border-radius:var(--radius-full);border:1px solid #0000;align-items:center;gap:7px;padding:6px 14px;font-size:12px;font-weight:500;display:flex}.dashboard-status-badge.connected{color:var(--color-up);background:var(--color-up-muted);border-color:#22c55e33}.dashboard-status-badge.disconnected{color:var(--color-down);background:var(--color-down-muted);border-color:#ef444433}.dashboard-status-dot{background:currentColor;border-radius:50%;width:7px;height:7px}.dashboard-status-badge.connected .dashboard-status-dot{animation:2s ease-in-out infinite pulse-dot}.dashboard-stats{gap:var(--space-4);grid-template-columns:repeat(4,1fr);display:grid}@media (width<=1100px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.dashboard-stats{grid-template-columns:1fr}}.dashboard-stat-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-5);gap:var(--space-2);transition:border-color var(--transition-base), box-shadow var(--transition-base);flex-direction:column;display:flex}.dashboard-stat-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md)}.dashboard-stat-card__header{justify-content:space-between;align-items:center;display:flex}.dashboard-stat-card__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:500}.dashboard-stat-card__icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:34px;height:34px;display:flex}.dashboard-stat-card__value{font-family:var(--font-mono);color:var(--text-primary);letter-spacing:-.02em;margin-top:4px;font-size:26px;font-weight:600}.dashboard-stat-card__sub{color:var(--text-muted);align-items:center;gap:4px;font-size:12px;display:flex}.dashboard-stat-card__sub.up{color:var(--color-up)}.dashboard-stat-card__sub.down{color:var(--color-down)}.dashboard-grid{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}@media (width<=900px){.dashboard-grid{grid-template-columns:1fr}}.dashboard-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden}.dashboard-card__header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.dashboard-card__title{color:var(--text-primary);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.dashboard-card__link{color:var(--accent);font-size:12px;text-decoration:none}.dashboard-card__link:hover{color:var(--accent-hover)}.dashboard-card__skeleton{padding:8px 0}.dashboard-skeleton-row{justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.dashboard-card__list{flex-direction:column;display:flex}.dashboard-card__empty{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:160px;padding:40px;font-size:13px;display:flex}.dashboard-quote-row{border-bottom:1px solid var(--border-subtle);transition:background var(--transition-fast);justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.dashboard-quote-row:last-child{border-bottom:none}.dashboard-quote-row:hover{background:var(--bg-elevated)}.dashboard-quote-row__symbol{flex-direction:column;gap:2px;display:flex}.dashboard-quote-row__code{font-family:var(--font-mono);color:var(--text-primary);font-size:14px;font-weight:600}.dashboard-quote-row__name{color:var(--text-muted);font-size:11px}.dashboard-quote-row__price-block{align-items:center;gap:10px;display:flex}.dashboard-quote-row__price{font-family:var(--font-mono);font-size:15px;font-weight:600}.dashboard-quote-row__price.up{color:var(--color-up)}.dashboard-quote-row__price.down{color:var(--color-down)}.dashboard-quote-row__rate{font-family:var(--font-mono);border-radius:var(--radius-sm);padding:2px 7px;font-size:12px}.dashboard-quote-row__rate.up{color:var(--color-up);background:var(--color-up-muted)}.dashboard-quote-row__rate.down{color:var(--color-down);background:var(--color-down-muted)}.watchlist-panel{background:var(--bg-surface);border-right:1px solid var(--border-default);flex-direction:column;height:100%;display:flex;overflow:hidden}.watchlist-panel__header{flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px 10px;display:flex}.watchlist-panel__title{color:var(--text-primary);font-size:14px;font-weight:600}.watchlist-panel__count{background:var(--bg-elevated);color:var(--text-muted);border-radius:var(--radius-full);border:1px solid var(--border-default);padding:2px 7px;font-size:11px;font-weight:600}.watchlist-panel__search-wrap{flex-shrink:0;padding:0 10px 10px;position:relative}.watchlist-panel__search{background:var(--bg-base);border:1px solid var(--border-default);border-radius:var(--radius-md);transition:border-color var(--transition-fast);align-items:center;gap:8px;padding:7px 10px;display:flex}.watchlist-panel__search:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-muted)}.watchlist-panel__search-icon{color:var(--text-muted);flex-shrink:0}.watchlist-panel__search-input{color:var(--text-primary);background:0 0;border:none;flex:1;min-width:0;font-size:13px}.watchlist-panel__search-input::placeholder{color:var(--text-muted)}.watchlist-panel__search-spinner,.watchlist-panel__search-clear{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;align-items:center;padding:0;display:flex}.watchlist-panel__search-clear:hover{color:var(--text-secondary)}.watchlist-panel__dropdown{background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;max-height:240px;position:absolute;top:calc(100% - 6px);left:10px;right:10px;overflow-y:auto}.watchlist-panel__dropdown-item{cursor:pointer;transition:background var(--transition-fast);border:none;border-bottom:1px solid var(--border-subtle);text-align:left;background:0 0;justify-content:space-between;align-items:center;width:100%;padding:10px 12px;display:flex}.watchlist-panel__dropdown-item:last-child{border-bottom:none}.watchlist-panel__dropdown-item:hover{background:var(--bg-overlay)}.watchlist-panel__dropdown-symbol{flex-direction:column;gap:2px;min-width:0;display:flex}.watchlist-panel__dropdown-code{font-family:var(--font-mono);color:var(--text-primary);font-size:13px;font-weight:600}.watchlist-panel__dropdown-name{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.watchlist-panel__dropdown-add{color:var(--accent);flex-shrink:0}.watchlist-panel__dropdown-empty{text-align:center;color:var(--text-muted);padding:16px 12px;font-size:13px}.watchlist-panel__list{flex:1;overflow-y:auto}.watchlist-panel__loading{flex-direction:column;gap:8px;padding:10px;display:flex}.watchlist-panel__skeleton{justify-content:space-between;align-items:center;padding:10px;display:flex}.watchlist-panel__empty{height:200px;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:13px;display:flex}.watchlist-panel__item{border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:background var(--transition-fast);outline:none;justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;display:flex}.watchlist-panel__item:hover{background:var(--bg-elevated)}.watchlist-panel__item:hover .watchlist-panel__remove-btn{opacity:1}.watchlist-panel__item.selected{background:var(--accent-muted);border-left:2px solid var(--accent)}.watchlist-panel__item-left{align-items:center;gap:6px;min-width:0;display:flex}.watchlist-panel__item-order{flex-direction:column;gap:1px;display:flex}.watchlist-panel__move-btn{width:16px;height:14px;color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast), background var(--transition-fast);background:0 0;border:none;border-radius:2px;justify-content:center;align-items:center;padding:0;display:flex}.watchlist-panel__move-btn:hover:not(:disabled){color:var(--text-primary);background:var(--bg-elevated)}.watchlist-panel__move-btn:disabled{opacity:.3;cursor:not-allowed}.watchlist-panel__item-info{flex-direction:column;gap:1px;min-width:0;display:flex}.watchlist-panel__item-symbol{font-family:var(--font-mono);color:var(--text-primary);letter-spacing:.03em;font-size:13px;font-weight:700}.watchlist-panel__item-name{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:100px;font-size:10px;overflow:hidden}.watchlist-panel__item-right{flex-shrink:0;align-items:center;gap:6px;display:flex}.watchlist-panel__item-price{font-family:var(--font-mono);font-size:14px;font-weight:600}.watchlist-panel__item-price.up{color:var(--color-up)}.watchlist-panel__item-price.down{color:var(--color-down)}.watchlist-panel__item-change{font-family:var(--font-mono);border-radius:var(--radius-sm);align-items:center;gap:2px;padding:2px 5px;font-size:10px;font-weight:500;display:flex}.watchlist-panel__item-change.up{color:var(--color-up);background:var(--color-up-muted)}.watchlist-panel__item-change.down{color:var(--color-down);background:var(--color-down-muted)}.watchlist-panel__remove-btn{width:20px;height:20px;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);opacity:0;transition:opacity var(--transition-fast), color var(--transition-fast), background var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex}.watchlist-panel__remove-btn:hover{color:var(--color-down);background:var(--color-down-muted)}.watchlist-panel__item-loading{border-radius:var(--radius-sm);display:inline-block}.kline-chart{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);flex-direction:column;height:100%;display:flex;overflow:hidden}.kline-chart__header{border-bottom:1px solid var(--border-subtle);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.kline-chart__title{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.kline-chart__symbol{font-family:var(--font-mono);color:var(--text-primary);letter-spacing:.05em;font-size:16px;font-weight:700}.kline-chart__tooltip{font-family:var(--font-mono);flex-wrap:wrap;align-items:center;gap:12px;font-size:12px;display:flex}.kline-chart__tooltip.up{color:var(--color-up)}.kline-chart__tooltip.down{color:var(--color-down)}.kline-chart__tooltip span{white-space:nowrap}.kline-chart__periods{background:var(--bg-base);border-radius:var(--radius-md);border:1px solid var(--border-subtle);align-items:center;gap:2px;padding:3px;display:flex}.kline-chart__period-btn{color:var(--text-muted);transition:all var(--transition-fast);cursor:pointer;background:0 0;border:none;border-radius:5px;padding:4px 10px;font-size:12px;font-weight:500}.kline-chart__period-btn:hover{color:var(--text-primary);background:var(--bg-elevated)}.kline-chart__period-btn.active{color:var(--accent);background:var(--accent-muted);font-weight:600}.kline-chart__container{flex:1;min-height:300px;position:relative;overflow:hidden}.kline-chart__loading{background:var(--bg-surface);z-index:1;align-items:flex-end;padding:12px;display:flex;position:absolute;inset:0}.kline-chart__loading-bars{align-items:flex-end;gap:3px;width:100%;height:60%;display:flex}.kline-chart__loading-bar{border-radius:2px 2px 0 0;flex:1;min-width:4px}.quote-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--transition-base), box-shadow var(--transition-base), background var(--transition-fast);outline:none;padding:14px 16px}.quote-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md)}.quote-card--selected{border-color:var(--accent);background:var(--bg-elevated);box-shadow:0 0 0 1px var(--accent), var(--shadow-md)}.quote-card__header{justify-content:space-between;align-items:flex-start;margin-bottom:8px;display:flex}.quote-card__symbol-block{flex-direction:column;gap:2px;min-width:0;display:flex}.quote-card__symbol{font-family:var(--font-mono);color:var(--text-primary);letter-spacing:.05em;font-size:15px;font-weight:700}.quote-card__name{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:11px;overflow:hidden}.quote-card__direction{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.quote-card__direction.up{color:var(--color-up);background:var(--color-up-muted)}.quote-card__direction.down{color:var(--color-down);background:var(--color-down-muted)}.quote-card__price-row{margin-bottom:10px}.quote-card__price{font-family:var(--font-mono);letter-spacing:-.02em;font-size:24px;font-weight:600;line-height:1}.quote-card__price.up{color:var(--color-up)}.quote-card__price.down{color:var(--color-down)}.quote-card__footer{justify-content:space-between;align-items:center;display:flex}.quote-card__change{align-items:center;gap:6px;display:flex}.quote-card__change-amt{font-family:var(--font-mono);font-size:13px;font-weight:500}.quote-card__change-rate{font-family:var(--font-mono);border-radius:var(--radius-sm);padding:2px 6px;font-size:12px;font-weight:500}.quote-card__change-amt.up,.quote-card__change-rate.up{color:var(--color-up)}.quote-card__change-rate.up{background:var(--color-up-muted)}.quote-card__change-amt.down,.quote-card__change-rate.down{color:var(--color-down)}.quote-card__change-rate.down{background:var(--color-down-muted)}.quote-card__volume{color:var(--text-muted);font-size:11px;font-family:var(--font-mono)}.market-page{height:100%;display:flex;overflow:hidden}.market-page__watchlist{flex-shrink:0;width:280px;min-width:280px;height:100%;overflow:hidden}.market-page__main{gap:var(--space-3);padding:var(--space-4);flex-direction:column;flex:1;min-width:0;display:flex;overflow-y:auto}.market-page__empty{flex:1;justify-content:center;align-items:center;display:flex}.market-page__quote-header{flex-shrink:0}.market-page__quote-header .quote-card{cursor:default;padding:16px 20px}.market-page__quote-header .quote-card__price{font-size:32px}.market-page__chart{flex:1;min-height:380px;max-height:520px}.market-page__details{flex-shrink:0}.market-detail-row{gap:var(--space-3);background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);grid-template-columns:repeat(6,1fr);padding:16px 20px;display:grid}@media (width<=1200px){.market-detail-row{grid-template-columns:repeat(3,1fr)}}@media (width<=800px){.market-page{flex-direction:column}.market-page__watchlist{width:100%;min-width:unset;height:200px}.market-detail-row{grid-template-columns:repeat(2,1fr)}}.market-detail-item{flex-direction:column;gap:4px;display:flex}.market-detail-item__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px}.market-detail-item__value{font-family:var(--font-mono);color:var(--text-primary);font-size:14px;font-weight:600}.settings-page{padding:var(--space-6);gap:var(--space-6);flex-direction:column;max-width:720px;display:flex}.settings-page__header{flex-direction:column;gap:4px;display:flex}.settings-page__title{color:var(--text-primary);letter-spacing:-.02em;font-size:22px;font-weight:700}.settings-page__subtitle{color:var(--text-muted);font-size:13px}.settings-sections{gap:var(--space-4);flex-direction:column;display:flex}.settings-section{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden}.settings-section--danger{border-color:#ef44444d}.settings-section--danger .settings-section__header{color:var(--color-down);border-bottom-color:#ef444433}.settings-section__header{border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);align-items:center;gap:8px;padding:14px 20px;font-size:14px;font-weight:600;display:flex}.settings-section__body{flex-direction:column;display:flex}.settings-row{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;display:flex}.settings-row:last-child{border-bottom:none}.settings-row__label{color:var(--text-muted);white-space:nowrap;font-size:13px;font-weight:500}.settings-row__value{color:var(--text-primary);font-size:14px;font-weight:500}.settings-row__value--mono{font-family:var(--font-mono)}.settings-row__desc{color:var(--text-muted);margin-top:3px;font-size:12px}.settings-badge{border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:5px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.settings-badge--success{color:var(--color-up);background:var(--color-up-muted);border:1px solid #22c55e33}.settings-badge--warning{color:var(--color-warning);background:var(--color-warning-muted);border:1px solid #f59e0b33}.settings-badge--error{color:var(--color-down);background:var(--color-down-muted);border:1px solid #ef444433}.settings-badge--info{color:var(--color-info);background:#38bdf81a;border:1px solid #38bdf833}.settings-alert{border-bottom:1px solid var(--border-subtle);align-items:flex-start;gap:10px;padding:14px 20px;font-size:13px;line-height:1.5;display:flex}.settings-alert strong{margin-bottom:2px;font-weight:600;display:block}.settings-alert p{color:inherit;opacity:.8}.settings-alert--warning{background:var(--color-warning-muted);color:var(--color-warning);border-bottom-color:#f59e0b26}.settings-alert--error{background:var(--color-down-muted);color:var(--color-down);border-bottom-color:#ef444426}.settings-alert--info{color:var(--color-info);background:#38bdf814;border-bottom-color:#38bdf826}.settings-passkey-item{align-items:center;gap:12px;display:flex}.settings-passkey-item__icon{border-radius:var(--radius-md);background:var(--accent-muted);width:40px;height:40px;color:var(--accent);border:1px solid #6366f133;flex-shrink:0;justify-content:center;align-items:center;display:flex}
