:root{color:#101828;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fa;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{min-width:320px;min-height:100%}body{min-width:320px;min-height:100vh;margin:0;overflow-x:hidden}button,input{font:inherit}button{cursor:pointer}h1,h2,p{margin:0}.app-shell{width:100%;max-width:1440px;margin:0 auto;padding:22px}.dashboard-hero{padding:12px 0 14px;display:block;position:relative}.hero-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;min-width:0;display:flex}.hero-copy{min-width:0}.eyebrow,.section-kicker,.metric-label{color:#667085;letter-spacing:0;text-transform:uppercase;font-size:.78rem;font-weight:750}.eyebrow{align-items:center;gap:8px;min-width:0;margin-bottom:0;display:inline-flex}h1{color:#0b1220;letter-spacing:0;font-size:clamp(2rem,4vw,3.65rem);line-height:1.02}.title-row{justify-content:space-between;align-items:center;gap:18px;min-width:0;display:flex}.connection-panel{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;min-width:0;display:flex}.status-pill,.connection-meta span,.group-tab,.freshness,.market-badge{color:#344054;white-space:nowrap;background:#fff;border:1px solid #d0d5dd;border-radius:8px;align-items:center;gap:7px;min-height:34px;font-size:.88rem;font-weight:750;display:inline-flex}.status-pill{justify-content:center;min-width:92px;min-height:34px;padding:0 10px}.status-open{color:#027a48;background:#ecfdf3;border-color:#a6f4c5}.status-connecting,.status-closed{color:#b54708;background:#fffaeb;border-color:#fedf89}.status-error{color:#b42318;background:#fef3f2;border-color:#fecdca}.signal-bars{align-items:flex-end;gap:3px;height:16px;display:inline-flex}.signal-bars span{opacity:.35;background:currentColor;border-radius:999px;width:4px;display:block}.signal-bars span:first-child{height:5px}.signal-bars span:nth-child(2){height:8px}.signal-bars span:nth-child(3){height:12px}.signal-bars span:nth-child(4){height:16px}.status-open .signal-bars span,.status-connecting .signal-bars span:nth-child(-n+2),.status-closed .signal-bars span:nth-child(-n+2),.status-error .signal-bars span:first-child,.status-idle .signal-bars span:first-child{opacity:1}.latency-label{color:currentColor;font-variant-numeric:tabular-nums;text-align:right;min-width:46px;font-size:.74rem;font-weight:850;line-height:1}.connection-meta{flex-wrap:wrap;justify-content:flex-end;gap:10px;min-width:0;display:flex}.connection-meta span{color:#667085;min-height:30px;padding:0 10px;font-size:.82rem}.control-band{background:#fff;border:1px solid #e4e7ec;border-radius:8px;margin-top:14px;padding:14px;display:block}.market-grid>*{min-width:0}.group-tabs{flex-wrap:wrap;align-items:center;gap:8px;min-width:0;display:flex}.group-tab{min-height:36px;padding:0 11px}.group-tab:hover{background:#f9fafb;border-color:#98a2b3}.group-tab.active{color:#175cd3;background:#eff8ff;border-color:#84caff}.alert-row,.info-row{color:#93370d;background:#fffaeb;border:1px solid #fedf89;border-radius:8px;align-items:center;gap:10px;min-width:0;margin-top:14px;padding:12px 14px;font-size:.92rem;font-weight:650;display:flex}.info-row{color:#175cd3;background:#eff8ff;border-color:#b2ddff}.toast{z-index:30;color:#93370d;background:#fffaeb;border:1px solid #fedf89;border-radius:8px;align-items:center;gap:10px;max-width:min(420px,100vw - 28px);min-height:42px;padding:10px 12px;font-size:.88rem;font-weight:750;display:flex;position:fixed;top:58px;right:14px;box-shadow:0 10px 30px #10182824}.toast span{min-width:0}.market-grid{grid-template-columns:repeat(auto-fill,minmax(224px,1fr));gap:10px;margin-top:10px;display:grid}.tick-card{background:#fff;border:1px solid #e4e7ec;border-radius:8px;gap:12px;min-width:0;min-height:214px;padding:14px;transition:border-color .16s,box-shadow .16s,transform .16s;display:grid}.tick-card:hover{border-color:#b2ddff;transform:translateY(-1px);box-shadow:0 8px 28px #10182814}.trend-card-up{box-shadow:inset 3px 0 #12b76a}.trend-card-down{box-shadow:inset 3px 0 #f04438}.tick-card-head,.tick-price-row,.tick-meta{justify-content:space-between;align-items:center;gap:10px;min-width:0;display:flex}.symbol-lockup{grid-template-columns:minmax(0,1fr);align-items:center;min-width:0;display:grid}.symbol-lockup strong,.symbol-lockup small,.tick-meta span{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.symbol-lockup strong{color:#101828;font-size:.98rem;font-weight:850}.symbol-lockup small{color:#667085;margin-top:2px;font-size:.8rem;font-weight:650}.symbol-avatar{color:#3538cd;background:#eef4ff;border-radius:8px;place-items:center;width:40px;height:40px;font-size:.82rem;font-weight:900;display:inline-grid}.freshness{color:#027a48;background:#ecfdf3;border-color:#a6f4c5;min-height:26px;padding:0 8px;font-size:.76rem}.freshness.stale{color:#b54708;background:#fffaeb;border-color:#fedf89}.tick-price{color:#0b1220;overflow-wrap:anywhere;min-width:0;font-size:1.7rem;font-weight:900;line-height:1}.trend-text,.trend-up,.trend-down,.trend-flat{font-weight:850}.trend-up{color:#047857}.trend-down{color:#d92d20}.trend-flat{color:#667085}.mini-chart{width:100%;height:74px;overflow:visible}.mini-chart-line{fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-width:2.4px}.mini-chart-grid{fill:none;stroke:#eef2f6;stroke-width:1px}.mini-chart-empty{fill:none;stroke:#d0d5dd;stroke-dasharray:5 6;stroke-linecap:round;stroke-width:2px}.tick-meta{color:#667085;font-size:.82rem;font-weight:650}.tick-meta span:first-child{min-width:0}.tick-meta span:last-child{color:#344054;flex-shrink:0}.empty-market{color:#667085;background:#fff;border:1px dashed #d0d5dd;border-radius:8px;grid-column:1/-1;place-items:center;gap:10px;min-height:240px;font-weight:750;display:grid}@media (width<=1040px){.connection-panel{align-items:flex-end;padding-top:0}.connection-meta{justify-content:flex-start}}@media (width<=700px){.app-shell{padding:14px 14px 148px}.dashboard-hero{z-index:16;background:#f5f7fa;padding:7px 0;position:sticky;top:0}.hero-header{flex-wrap:nowrap;gap:8px}.eyebrow{text-overflow:ellipsis;white-space:nowrap;gap:5px;font-size:.62rem;overflow:hidden}.connection-panel{flex-wrap:nowrap;flex-shrink:0;gap:7px;width:auto}.session-badge{min-height:30px;padding:2px 9px;font-size:.8rem}.session-badge small{display:none}.status-pill{min-width:70px;min-height:30px}.connection-meta{display:none}.control-band{z-index:18;padding:10px 12px calc(10px + env(safe-area-inset-bottom));border-bottom:0;border-left:0;border-right:0;border-radius:12px 12px 0 0;margin:0;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -10px 28px #1018281a}.group-tabs{overscroll-behavior-x:contain;scrollbar-width:none;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:8px;padding:0 2px;overflow-x:auto}.group-tabs::-webkit-scrollbar{display:none}.group-tab{flex:none;min-height:44px;padding:0 14px}.market-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.tick-price{font-size:1.28rem}.tick-card{gap:8px;min-height:178px;padding:10px}.tick-card-head{align-items:flex-start}.symbol-lockup{grid-template-columns:minmax(0,1fr)}.symbol-avatar{width:32px;height:32px;font-size:.72rem}.symbol-lockup strong{font-size:.82rem}.symbol-lockup small{font-size:.7rem}.freshness{min-height:22px;padding:0 6px;font-size:.68rem}.tick-price-row{flex-direction:column;align-items:flex-start;gap:4px}.tick-price-row .trend-text{align-self:flex-end;font-size:.95rem}.mini-chart{height:56px}.mini-chart-line{stroke-width:2px}.tick-meta{font-size:.72rem}.tick-meta span:first-child{display:none}.tick-meta span:last-child{margin-left:auto}.alert-row,.info-row{align-items:flex-start}.toast{max-width:none;top:58px;left:10px;right:10px}}@media (width>=701px) and (width<=900px){.market-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.session-badge{white-space:nowrap;background:#fff;border:1px solid #d0d5dd;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:1px;min-height:34px;padding:3px 12px;font-size:.9rem;font-weight:850;line-height:1.05;display:inline-flex}.session-badge small{opacity:.85;font-size:.62rem;font-weight:700}.session-regular{color:#027a48;background:#ecfdf3;border-color:#a6f4c5}.session-pre{color:#175cd3;background:#eff8ff;border-color:#b2ddff}.session-after{color:#b54708;background:#fffaeb;border-color:#fedf89}.session-closed{color:#667085;background:#f2f4f7;border-color:#e4e7ec}.search-box{margin-bottom:12px;position:relative}.search-input{color:#667085;background:#fff;border:1px solid #d0d5dd;border-radius:8px;align-items:center;gap:8px;height:40px;padding:0 10px;display:flex}.search-input input{color:#101828;background:0 0;border:0;outline:none;flex:1;min-width:0;font-weight:650}.search-clear{color:#667085;background:#f2f4f7;border:0;border-radius:6px;place-items:center;width:24px;height:24px;display:inline-grid}.search-results{z-index:25;background:#fff;border:1px solid #e4e7ec;border-radius:8px;max-height:320px;margin:0;padding:6px;list-style:none;position:absolute;top:44px;left:0;right:0;overflow-y:auto;box-shadow:0 12px 32px #10182824}.search-results button{text-align:left;background:0 0;border:0;border-radius:6px;align-items:baseline;gap:10px;width:100%;padding:8px 10px;display:flex}.search-results button:hover{background:#f9fafb}.search-results strong{font-weight:850}.search-results span{color:#667085;text-overflow:ellipsis;white-space:nowrap;font-size:.82rem;overflow:hidden}.watch-star{color:#98a2b3;background:#fff;border:1px solid #e4e7ec;border-radius:8px;flex-shrink:0;place-items:center;width:30px;height:30px;display:inline-grid}.watch-star.on{color:#f79009;background:#fffaeb;border-color:#fec84b}.symbol-text{min-width:0}.change-line{justify-content:space-between;align-items:center;gap:8px;min-height:22px;margin-top:-4px;display:flex}.change-tag{color:#667085;background:#f9fafb;border:1px solid #e4e7ec;border-radius:6px;padding:2px 7px;font-size:.72rem;font-weight:750}.ext-change{font-size:.8rem;font-weight:850}.view-heading{color:#475467;margin-top:14px;font-size:.85rem;font-weight:750}.scroll-sentinel{height:1px}@media (width<=700px){.view-heading{margin-top:6px;font-size:.78rem}.search-box{margin-bottom:8px}.search-input{height:38px}}
