:root{color:#24231f;background:#f4f2ec;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--surface: #fffdf8;--surface-muted: #eeeadf;--line: #d7d0c2;--line-strong: #b8af9e;--text-muted: #6f6a60;--green: #168457;--green-soft: #e6f3ec;--red: #b63f35;--red-soft: #f7e7e4;--amber: #8b642b;--amber-soft: #f4ead7;--charcoal: #2d2b26;--shadow: 0 18px 60px rgba(48, 42, 31, .16)}*{box-sizing:border-box}body{margin:0;min-width:1040px;min-height:100vh;background:#f4f2ec}button,input,select{font:inherit}button{cursor:pointer}#app{min-height:100vh}.terminal-shell{display:flex;flex-direction:column;min-height:100vh;max-height:100vh;overflow:hidden}.terminal-toolbar{display:flex;align-items:center;gap:8px;min-height:42px;padding:5px 12px;background:#fbf8ef;border-bottom:1px solid var(--line)}.brand-lockup{display:flex;align-items:center;justify-content:center;flex:0 0 30px;width:30px;height:30px;color:var(--charcoal)}.symbol-form{display:flex;align-items:center;flex:0 0 auto;gap:6px}.symbol-form input{width:150px;height:30px;padding:0 10px;border:1px solid var(--line-strong);border-radius:6px;background:#fff;color:var(--charcoal);outline:none}.symbol-form input:focus{border-color:var(--green);box-shadow:0 0 0 3px #16845724}.command-button,.mode-switch{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:30px;padding:0 10px;border:1px solid var(--line-strong);border-radius:6px;background:#fff;color:var(--charcoal)}.command-button{background:var(--charcoal);border-color:var(--charcoal);color:#fff}.mode-switch select{border:0;outline:0;color:inherit;background:transparent}.toolbar-spacer{flex:1}.smoke-action-button{border-color:var(--line);background:#fff}.connection-status{display:inline-flex;align-items:center;justify-content:center;flex:0 0 28px;width:28px;height:28px;padding:0;border:0;border-radius:999px;color:var(--text-muted);background:transparent;white-space:nowrap}.connection-status__dot{width:11px;height:11px;border-radius:50%;background:#9b9488}.connection-status.is-connected .connection-status__dot{background:var(--green)}.connection-status.is-connecting .connection-status__dot{background:var(--amber)}.connection-status.is-error .connection-status__dot{background:var(--red)}.stock-tabs{display:flex;flex:1 1 auto;gap:6px;min-width:0;min-height:32px;padding:0 4px;overflow-x:auto;background:transparent;border-bottom:0;scrollbar-width:thin}.stock-tab{position:relative;display:inline-flex;align-items:center;flex:1 1 168px;min-width:96px;max-width:220px;height:30px;border:1px solid var(--line);border-radius:7px;background:var(--surface);overflow:hidden}.stock-tab.is-active{border-color:var(--green);box-shadow:inset 0 0 0 1px #16845740}.stock-tab__main{display:grid;grid-template-columns:minmax(52px,auto) minmax(0,1fr);align-items:center;gap:6px;width:100%;min-width:0;height:100%;padding:0 28px 0 9px;border:0;background:transparent;text-align:left}.stock-tab__symbol{overflow:hidden;font-weight:700;color:var(--charcoal);text-overflow:ellipsis;white-space:nowrap}.stock-tab__name{overflow:hidden;color:var(--text-muted);font-size:12px;text-overflow:ellipsis;white-space:nowrap}.stock-tab__badge{position:absolute;right:24px;top:3px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--red);color:#fff;font-size:11px;line-height:18px;text-align:center}.stock-tab__close{position:absolute;right:3px;top:1px}.session-evidence{display:flex;align-items:center;gap:12px;min-height:38px;padding:0 18px;border-bottom:1px solid var(--line);background:#fbf8ef;color:var(--text-muted);font-size:12px;white-space:nowrap}.status-chip{display:inline-flex;align-items:center;justify-content:center;min-width:72px;height:22px;padding:0 8px;border-radius:999px;font-weight:700;color:var(--text-muted);background:var(--surface-muted)}.status-chip.is-live{color:var(--green);background:var(--green-soft)}.status-chip.is-warm,.status-chip.is-stale,.status-chip.is-closed,.status-chip.is-loading,.status-chip.is-gap{color:var(--amber);background:var(--amber-soft)}.status-chip.is-degraded,.session-evidence__warning{color:var(--red)}.status-chip.is-degraded{background:var(--red-soft)}.icon-button{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--text-muted)}.icon-button:hover{border-color:var(--line);background:var(--surface-muted);color:var(--charcoal)}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.16fr) minmax(420px,.84fr);grid-template-rows:minmax(240px,.92fr) minmax(0,1.08fr);gap:6px;flex:1;min-height:0;padding:6px 8px 8px}.monitor-panel{display:flex;flex-direction:column;min-width:0;min-height:0;border:1px solid var(--line);border-radius:8px;background:var(--surface);overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:10px;height:30px;min-height:30px;padding:0 8px;border-bottom:1px solid var(--line)}.panel-header h2,.modal-header h2{margin:0;color:var(--charcoal);font-size:14px;line-height:1.2;letter-spacing:0}.panel-header p,.modal-header p{margin:4px 0 0;color:var(--text-muted);font-size:12px}.holding-title{display:inline-flex;align-items:baseline;max-width:100%;gap:6px;white-space:nowrap}.holding-title__date{min-width:0;overflow:hidden;color:var(--text-muted);font-size:12px;font-weight:500;text-overflow:ellipsis}.quote-summary{display:inline-flex;align-items:baseline;gap:8px;white-space:nowrap}.quote-summary strong{font-size:16px;line-height:1}.quote-summary span{font-size:12px}.quote-summary__time{flex:0 0 auto;color:var(--text-muted);font-weight:500}.quote-summary__change{min-width:0}.market-chart-panel{min-height:260px}.market-chart{flex:1;min-height:0}.table-scroll{flex:1;min-height:0;overflow:auto}.data-table{width:100%;border-collapse:collapse;font-size:12px}.data-table th,.data-table td{padding:8px 10px;border-bottom:1px solid #ebe6dc;text-align:left;vertical-align:middle}.data-table th{position:sticky;top:0;z-index:1;background:#fbf8ef;color:#5f5a51;font-size:11px;font-weight:700;text-transform:uppercase}.data-table td strong,.data-table td span{display:block}.data-table td span{margin-top:2px;color:var(--text-muted)}.data-table tr.is-highlighted td{background:var(--amber-soft)}.data-table.is-compact td{padding:6px 8px}.data-table td.side-cell{text-align:center}.side-pill{display:inline-flex;align-items:center;justify-content:center;min-width:48px;height:22px;border-radius:999px;font-weight:700;line-height:22px;text-transform:uppercase}.is-up,.side-pill.is-buy{color:var(--red)}.side-pill.is-buy{background:var(--red-soft)}.is-down,.side-pill.is-sell{color:var(--green)}.side-pill.is-sell{background:var(--green-soft)}.side-pill.is-neutral,.is-flat{color:var(--amber)}.side-pill.is-neutral{background:var(--amber-soft)}.broker-depth-control{display:inline-flex;overflow:hidden;border:1px solid #d8d0c4;border-radius:6px;background:#fff}.broker-depth-control button{width:34px;height:22px;border:0;border-right:1px solid #d8d0c4;background:transparent;color:var(--text-muted);font-weight:700}.broker-depth-control button:last-child{border-right:0}.broker-depth-control button.is-active{background:var(--charcoal);color:#fff}.queue-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:4px;flex:1;min-height:0;padding:4px}.queue-table{min-width:0;min-height:0;overflow:auto;border:1px solid #e6dfd4;border-radius:5px}.queue-level-list{display:flex;flex-direction:column;gap:2px;padding:3px}.queue-virtual-spacer{flex:0 0 auto}.queue-level{display:grid;grid-template-columns:minmax(0,1fr) 20px;grid-template-rows:11px minmax(13px,auto);align-items:start;gap:1px 2px;min-width:0;min-height:26px;padding:1px 3px;border:1px solid #ebe6dc;border-radius:4px;background:#fffdf8;overflow:hidden}.queue-level__summary{display:grid;grid-column:1;grid-template-columns:14px 18px minmax(42px,1fr) minmax(42px,auto) 24px;align-items:center;gap:2px;min-width:0;font-size:10px;line-height:11px}.queue-level__side,.queue-level__position,.queue-level__count{font-weight:700}.queue-level.is-ask .queue-level__side,.queue-level.is-ask .queue-level__price{color:var(--green)}.queue-level.is-bid .queue-level__side,.queue-level.is-bid .queue-level__price{color:var(--red)}.queue-level__position,.queue-level__count{color:var(--text-muted)}.queue-level__price,.queue-level__volume,.queue-level__count{text-align:right;white-space:nowrap}.queue-level__brokers{display:grid;grid-column:1 / -1;align-items:start;gap:1px;min-width:0;overflow:hidden}.queue-level__broker{display:inline-grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:2px;width:100%;min-width:0;height:13px;padding:0 2px;border:1px solid #eee8dd;border-radius:3px;background:#fbf8ef;color:var(--charcoal);font-size:9px;line-height:11px}.queue-level__broker-name{overflow:hidden;min-width:0;text-overflow:ellipsis;white-space:nowrap}.queue-level__broker-volume{color:var(--text-muted);white-space:nowrap}.queue-level__expand,.queue-level__expand-spacer{grid-column:2;grid-row:1;width:18px;height:13px}.queue-level__expand{display:inline-flex;align-items:center;justify-content:center;padding:0;border:1px solid #e2dbcf;border-radius:4px;background:#fff;color:var(--text-muted)}.queue-level__expand svg{width:11px;height:11px;transition:transform .12s ease}.queue-level__expand.is-expanded svg{transform:rotate(180deg)}.queue-empty{margin:0;padding:18px 8px;color:var(--text-muted);font-size:12px;text-align:center}.queue-table .data-table{table-layout:fixed}.queue-col-position{width:34px}.queue-col-name{width:auto}.queue-col-price{width:68px}.queue-col-volume{width:72px}.queue-table .data-table td{white-space:nowrap}.queue-table .data-table td:nth-child(2){overflow:hidden;text-overflow:ellipsis}.queue-table .data-table td:nth-child(3),.queue-table .data-table td:nth-child(4){text-align:right}.participant-button{display:inline-flex;align-items:center;gap:6px;max-width:100%;padding:0;border:0;background:transparent;color:var(--charcoal);text-align:left}.participant-button span{overflow:hidden;max-width:340px;text-overflow:ellipsis;white-space:nowrap}.empty-state{display:grid;flex:1;place-items:center;color:var(--text-muted)}.modal-backdrop{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:24px;background:#221f1961}.history-modal{display:flex;flex-direction:column;width:min(760px,100%);max-height:min(720px,calc(100vh - 48px));min-height:420px;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow);overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;border-bottom:1px solid var(--line)}.segmented-control{display:inline-flex;align-self:flex-start;gap:4px;margin:12px 16px;padding:3px;border:1px solid var(--line);border-radius:7px;background:var(--surface-muted)}.segmented-control button{min-width:72px;height:30px;border:0;border-radius:5px;background:transparent;color:var(--text-muted)}.segmented-control button.is-active{background:#fff;color:var(--charcoal);box-shadow:0 1px 3px #29241c24}@media(max-width:1180px){body{min-width:760px}.terminal-toolbar{flex-wrap:wrap}.toolbar-spacer{display:none}.dashboard-grid{grid-template-columns:minmax(0,1fr);grid-template-rows:repeat(4,minmax(300px,1fr));overflow:auto}.terminal-shell{max-height:none;overflow:visible}}@media(max-width:767px){body{min-width:0;min-height:100dvh;overflow-x:hidden}#app{min-width:0;min-height:100dvh}.terminal-shell{min-width:0;min-height:100dvh;max-height:none;overflow:visible}.terminal-toolbar{align-items:flex-start;gap:6px;min-width:0;padding:6px 8px}.brand-lockup{order:1;flex-basis:28px;width:28px;height:30px}.symbol-form{order:2;flex:1 1 220px;min-width:0;gap:5px}.symbol-form input{flex:1 1 auto;width:auto;min-width:0;padding:0 8px}.command-button{flex:0 0 auto;padding:0 8px}.connection-status{order:3;flex-basis:28px}.stock-tabs{order:5;flex:1 0 100%;flex-wrap:nowrap;gap:3px;width:100%;height:26px;min-height:0;padding:0;overflow:hidden}.stock-tab{flex:1 1 72px;min-width:0;max-width:none;height:26px;border-radius:6px}.stock-tab__main{grid-template-columns:minmax(44px,auto) minmax(0,1fr);gap:3px;padding:0 21px 0 6px}.stock-tab__symbol{font-size:11px}.stock-tab__name{font-size:10px}.stock-tab__badge{right:20px;top:4px;min-width:15px;height:15px;padding:0 4px;font-size:9px;line-height:15px}.stock-tab__close{right:0;top:0;width:22px;height:24px}.session-evidence{flex-wrap:wrap;gap:6px;padding:6px 8px;white-space:normal}.dashboard-grid{grid-template-columns:minmax(0,1fr);grid-template-rows:none;grid-auto-rows:auto;gap:5px;width:100%;min-width:0;padding:5px;overflow:visible}.dashboard-grid>.monitor-panel{order:4;width:100%;height:290px;min-width:0;min-height:0}.dashboard-grid>.market-chart-panel{order:1;height:clamp(188px,26dvh,220px)}.dashboard-grid>.broker-queue-panel{order:2;height:358px}.dashboard-grid>.alerts-panel{order:3}.panel-header{gap:6px;height:28px;min-height:28px;padding:0 6px}.panel-header>div{min-width:0}.panel-header h2,.modal-header h2{overflow:hidden;font-size:13px;text-overflow:ellipsis;white-space:nowrap}.quote-summary{flex:1 1 auto;justify-content:flex-end;gap:5px;min-width:0}.quote-summary strong{font-size:14px}.quote-summary span{overflow:hidden;font-size:10px;text-overflow:ellipsis}.market-chart-panel,.market-chart{min-height:0}.table-scroll{overflow-x:hidden;overflow-y:auto}.data-table{table-layout:fixed;font-size:11px;line-height:1.22}.data-table th,.data-table td{overflow:hidden;padding:5px 4px;text-overflow:ellipsis;white-space:nowrap}.data-table th{font-size:10px}.data-table td strong,.data-table td span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.data-table td span{margin-top:1px;font-size:10px}.side-pill{min-width:30px;height:18px;padding:0 4px;font-size:9px;line-height:18px}.broker-depth-control button{width:28px;height:20px;font-size:10px}.queue-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:3px;padding:3px}.queue-table{overflow-x:hidden;overflow-y:auto}.queue-level-list{gap:2px;padding:2px}.queue-level{grid-template-columns:minmax(0,1fr) 18px;grid-template-rows:11px minmax(13px,auto);gap:1px 2px;min-height:26px;padding:1px 2px;border-radius:4px}.queue-level__summary{grid-template-columns:11px 13px minmax(28px,1fr) minmax(24px,auto) 18px;gap:1px;font-size:9px;line-height:11px}.queue-level__brokers{gap:1px}.queue-level__broker{gap:1px;height:13px;padding:0 2px;font-size:9px;line-height:11px}.queue-level__broker-name{max-width:none}.queue-level__broker-volume,.queue-level__count{font-size:9px}.queue-level__expand,.queue-level__expand-spacer{width:16px;height:13px}.queue-level__expand svg{width:10px;height:10px}.queue-empty{padding:14px 4px;font-size:10px}.participant-button{gap:4px;min-width:0}.participant-button svg{flex:0 0 auto;width:12px;height:12px}.participant-button span{max-width:none}.modal-backdrop{align-items:stretch;padding:8px}.history-modal{width:100%;max-height:calc(100dvh - 16px);min-height:0}.modal-header{gap:8px;padding:10px 12px}.segmented-control{margin:8px 12px}.segmented-control button{min-width:58px;height:28px;font-size:11px}}
