:root {
  --bg: #0a0f1c;
  --panel: #0f1729;
  --panel-2: #121b30;
  --line: #22304a;
  --text: #d5e3ff;
  --muted: #90a3c8;
  --accent: #59a7ff;
  --blue-950: #091224;
  --blue-900: #0d1a33;
  --blue-850: #10213f;
  --blue-800: #14294b;
  --blue-750: #17305a;
  --blue-700: #1c3a68;
  --blue-650: #22457a;
  --blue-600: #2b538f;
  --blue-550: #3261a3;
  --blue-500: #3e73bc;
  --blue-450: #4d85cf;
  --blue-400: #5f9be2;
  --blue-350: #7ab1f0;
  --blue-300: #98c6ff;
  --state-base: var(--blue-800);
  --state-active: var(--blue-550);
  --state-live: var(--blue-350);
  --tab-accent: var(--blue-450);
  --tab-gradient-start: var(--blue-700);
  --tab-gradient-end: var(--blue-800);
  --workspace-glow: rgba(68, 109, 179, 0.2);
  --card-border: var(--blue-700);
  --card-bg-start: var(--blue-900);
  --card-bg-end: var(--blue-950);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  background: radial-gradient(circle at top, var(--blue-800), var(--bg));
  color: var(--text);
  font: 14px/1.4 Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.app-shell {
  height: 100vh;
  display: grid;
  --left-panel-width: 220px;
  --chat-panel-width: 290px;
  grid-template-columns: 56px var(--left-panel-width) 1fr var(--chat-panel-width);
  gap: 8px;
  padding: 8px;
}

.app-shell.left-collapsed {
  --left-panel-width: 0px;
}

.app-shell.chat-collapsed {
  --chat-panel-width: 0px;
}

.icon-rail,
.left-panel,
.center-panel,
.chat-panel {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: linear-gradient(180deg, var(--blue-900), var(--blue-950));
}

.app-shell.market-open .schwab-card,
.app-shell.market-open .schwab-metric-card,
.app-shell.market-open .agent-card,
.app-shell.market-open .agent-hero,
.app-shell.market-open .table-wrap,
.app-shell.market-open .ticker-intel-list,
.app-shell.market-open .ticker-intel-report {
  border-color: #3e8d68;
  box-shadow: 0 0 0 1px rgba(95, 189, 138, 0.24);
}

.app-shell.theme-schwab {
  --tab-accent: #63a3ee;
  --tab-gradient-start: #235084;
  --tab-gradient-end: #183a64;
  --workspace-glow: rgba(70, 128, 212, 0.2);
  --card-border: #2f5b8e;
}

.app-shell.theme-holdings {
  --tab-accent: #74b8ff;
  --tab-gradient-start: #2b5f95;
  --tab-gradient-end: #1c436f;
  --workspace-glow: rgba(92, 153, 224, 0.23);
  --card-border: #336495;
}

.app-shell.theme-investments {
  --tab-accent: #6ca9f4;
  --tab-gradient-start: #26598f;
  --tab-gradient-end: #1a3f6a;
  --workspace-glow: rgba(88, 146, 221, 0.22);
  --card-border: #2f5d93;
}

.app-shell.theme-ticker-intel {
  --tab-accent: #88c4ff;
  --tab-gradient-start: #2f68a4;
  --tab-gradient-end: #1f4b79;
  --workspace-glow: rgba(105, 170, 246, 0.25);
  --card-border: #3970a8;
}

.app-shell.theme-time {
  --tab-accent: #7fc3ff;
  --tab-gradient-start: #2c639f;
  --tab-gradient-end: #1d486f;
  --workspace-glow: rgba(97, 164, 239, 0.24);
  --card-border: #376ca2;
}

.app-shell.theme-shopping {
  --tab-accent: #93caff;
  --tab-gradient-start: #3470b0;
  --tab-gradient-end: #255381;
  --workspace-glow: rgba(122, 184, 255, 0.26);
  --card-border: #3d77b1;
}

.icon-rail {
  padding: 10px 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

.brand-dot {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: #1d2c4b;
  border: 1px solid #3a4e78;
  display: grid;
  place-items: center;
  font-weight: 700;
  margin-bottom: 2px;
}

.rail-btn {
  width: 32px;
  height: 32px;
  border-radius: 10px;
  border: 1px solid #4d5e82;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
}

.rail-btn.active,
.rail-btn:hover {
  border-color: #8fa6d3;
  color: #e9f1ff;
}

.left-panel {
  padding: 14px;
  min-width: 0;
  overflow: hidden;
}

.app-shell.left-collapsed .left-panel {
  border-width: 0;
  padding: 0;
  opacity: 0;
  pointer-events: none;
}

.logo {
  margin: 0;
  font-size: 16px;
  text-transform: lowercase;
}

.panel-label {
  margin: 10px 0 8px;
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.menu {
  display: grid;
  gap: 4px;
}

.menu-item {
  text-align: left;
  border: 1px solid transparent;
  border-radius: 8px;
  padding: 8px 10px;
  color: var(--muted);
  background: transparent;
  cursor: pointer;
}

.menu-item.active,
.menu-item:hover {
  color: var(--text);
  border-color: #314266;
  background: #131f35;
}

.center-panel {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.top-tabs {
  display: flex;
  align-items: flex-end;
  gap: 6px;
  padding: 8px 8px 10px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, var(--blue-900), var(--blue-950));
  overflow-x: auto;
  overflow-y: visible;
}

.top-tab {
  border: 1px solid var(--blue-700);
  color: #b7c9ea;
  background: linear-gradient(180deg, var(--blue-850), var(--blue-900));
  border-radius: 10px 10px 0 0;
  padding: 6px 8px 6px 10px;
  cursor: pointer;
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  min-height: 34px;
  max-width: 220px;
  line-height: 1.2;
}

.top-tab.active {
  color: #fff;
  border-color: var(--tab-accent);
  background: linear-gradient(180deg, var(--tab-gradient-start), var(--tab-gradient-end));
  box-shadow: inset 0 1px 0 rgba(177, 214, 255, 0.3);
}

.top-tab-label {
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.2;
}

.top-tab-close {
  border: 0;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: transparent;
  color: #9eb3d9;
  cursor: pointer;
  display: grid;
  place-items: center;
  line-height: 1;
  font-size: 14px;
  padding: 0;
}

.top-tab-close:hover {
  background: rgba(132, 153, 196, 0.18);
  color: #fff;
}

.workspace {
  padding: 12px;
  overflow: auto;
  background: radial-gradient(circle at top left, var(--workspace-glow), rgba(13, 24, 44, 0.15) 42%, transparent 75%);
}

.workspace-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  margin-bottom: 10px;
}

.workspace-actions {
  display: inline-flex;
  gap: 8px;
  align-items: center;
}

.workspace-head h2 {
  margin: 0;
  font-size: 30px;
  line-height: 1.1;
}

.workspace-head p {
  margin: 2px 0 0;
  color: var(--muted);
}

.refresh-btn {
  border: 1px solid var(--blue-650);
  background: var(--blue-900);
  color: #dbe4f7;
  border-radius: 7px;
  padding: 7px 12px;
  box-shadow: 0 0 0 1px rgba(130, 175, 237, 0.2), 0 0 9px rgba(88, 139, 213, 0.18);
  cursor: pointer;
}

.workspace-toggle-btn {
  padding: 7px 10px;
  font-size: 12px;
}

.table-wrap {
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
  background: linear-gradient(180deg, var(--card-bg-start), var(--card-bg-end));
}

.sec-sheet-wrap {
  overflow: auto;
  border-radius: 8px;
  border-color: #2d4d76;
  box-shadow: inset 0 0 0 1px rgba(90, 130, 186, 0.2);
}

.sec-sheet-table {
  min-width: 1320px;
}

.sec-sheet-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
}

.sec-sheet-table th:first-child,
.sec-sheet-table td:first-child {
  position: sticky;
  left: 0;
  z-index: 1;
  background: #0f1f3a;
}

.sec-sheet-table td {
  font-size: 11px;
  vertical-align: top;
}

.sec-sheet-table tbody tr:nth-child(odd) td {
  background: rgba(23, 42, 74, 0.45);
}

.sec-sheet-table tbody tr:hover td {
  background: rgba(58, 92, 145, 0.26);
}

.sec-row-index {
  width: 42px;
  text-align: center;
  color: #9fb8df;
}

.sec-col-symbol {
  font-weight: 700;
  color: #e7f1ff;
}

.sec-header-filter {
  min-width: 170px;
}

.sec-header-filter label {
  display: block;
  margin-bottom: 4px;
}

.sec-header-filter select {
  width: 100%;
  min-width: 150px;
  border: 1px solid #355885;
  border-radius: 6px;
  background: rgba(9, 25, 46, 0.95);
  color: #dbe9ff;
  padding: 4px 6px;
  font-size: 11px;
}

.sec-impact {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 10px;
  font-weight: 700;
  border: 1px solid #476996;
}

.sec-impact.high {
  border-color: #5aa3ff;
  color: #e7f3ff;
  background: rgba(82, 143, 220, 0.32);
}

.sec-impact.medium {
  border-color: #4c7fba;
  color: #d7e8ff;
  background: rgba(58, 99, 150, 0.28);
}

.sec-impact.low {
  border-color: #3f5f8d;
  color: #c5daf7;
  background: rgba(45, 69, 106, 0.3);
}

.sec-hide-row-btn {
  padding: 4px 8px;
}

.sec-sheet-controls {
  margin-bottom: 10px;
}

.sec-source-cell {
  display: flex;
  gap: 8px;
  align-items: center;
}

.sec-readable-btn {
  padding: 3px 8px;
  font-size: 11px;
}

.sec-readable-card {
  margin-top: 10px;
}

.sec-data-row {
  cursor: pointer;
}

.sec-expanded-row td {
  background: rgba(23, 42, 74, 0.82);
  border-top: 1px dashed #3d5f8f;
}

.sec-signal {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 10px;
  font-weight: 700;
  border: 1px solid #486692;
}

.sec-signal-action {
  background: rgba(72, 132, 212, 0.28);
  color: #e6f3ff;
  border-color: #67a1ea;
}

.sec-signal-watch {
  background: rgba(64, 107, 168, 0.26);
  color: #d9eaff;
  border-color: #5f8fcb;
}

.sec-signal-low {
  background: rgba(45, 69, 106, 0.28);
  color: #c8dcfa;
  border-color: #4b6e9f;
}

table {
  width: 100%;
  border-collapse: collapse;
}

th,
td {
  border-bottom: 1px solid #1d2a45;
  padding: 10px;
  text-align: left;
  font-size: 12px;
}

th {
  color: #abc4ec;
  font-weight: 600;
  background: var(--blue-900);
}

td {
  color: #d4e0f6;
}

.ticker-cell {
  font-weight: 600;
  color: #e8f1ff;
}

.up {
  color: var(--blue-300);
}

.value-up {
  color: var(--blue-300) !important;
}

.value-down {
  color: var(--blue-400) !important;
}

.value-flat {
  color: #c7d8f5 !important;
}

.signal-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 3px 8px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border: 1px solid #3a4c6f;
  color: #c4d3ef;
  background: rgba(60, 80, 118, 0.25);
}

.signal-pill.bull-strong {
  border-color: var(--blue-350);
  color: #def0ff;
  background: rgba(92, 149, 224, 0.26);
}

.signal-pill.bull {
  border-color: var(--blue-450);
  color: #d5e8ff;
  background: rgba(74, 125, 196, 0.24);
}

.signal-pill.bear-strong {
  border-color: var(--blue-650);
  color: #ccdeff;
  background: rgba(47, 76, 126, 0.3);
}

.signal-pill.bear {
  border-color: var(--blue-700);
  color: #c8daf9;
  background: rgba(34, 58, 96, 0.3);
}

.signal-pill.neutral {
  border-color: #64789f;
  color: #d2ddf5;
  background: rgba(78, 96, 132, 0.25);
}

.ticker-item .signal-pill {
 padding: 2px 6px;
 font-size: 9px;
}

.do-loading,
.do-error {
  padding: 20px;
  color: var(--muted);
}
.do-error strong { color: #aecdff; }
.do-error p { margin: 8px 0 0; }

.do-account { margin-bottom: 16px; }
.do-account-card {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px 16px;
  background: #0e1629;
}
.do-account-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
}
.do-account-email { font-weight: 600; margin-top: 4px; }
.do-account-meta { font-size: 12px; color: var(--muted); margin-top: 4px; }

.settings-block { max-width: 420px; }
.settings-title { margin: 0 0 8px; font-size: 18px; }
.settings-desc {
  color: var(--muted);
  font-size: 12px;
  margin: 0 0 14px;
  line-height: 1.45;
}
.settings-label {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
  margin-bottom: 6px;
}
.settings-input {
  width: 100%;
  border: 1px solid #2b3b5a;
  background: #0e1728;
  color: #dce8ff;
  border-radius: 8px;
  padding: 8px 10px;
  margin-bottom: 10px;
  font: inherit;
}
.settings-save,
.settings-clear {
  border-radius: 8px;
  padding: 8px 14px;
  cursor: pointer;
  font: inherit;
  margin-right: 8px;
}
.settings-save {
  border: 1px solid #3f5f98;
  background: #17305a;
  color: #e9f1ff;
}
.settings-clear {
  border: 1px solid #4d5e82;
  background: transparent;
  color: var(--muted);
}

.chat-panel {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-width: 0;
}

.app-shell.chat-collapsed .chat-panel {
  border-width: 0;
  opacity: 0;
  pointer-events: none;
}

.chat-panel header,
.chat-panel .chat-panel-header {
  padding: 10px 12px;
  border-bottom: 1px solid var(--line);
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.chat-panel-badge {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
  font-weight: 500;
}

.chat-panel-badge.connected {
  color: #79d7a0;
}

.chat-log {
  padding: 10px;
  overflow: auto;
  flex: 1;
  display: grid;
  gap: 10px;
}

.msg {
  border: 1px solid #243450;
  background: #10192b;
  border-radius: 8px;
  padding: 10px 12px;
  color: #bdd0f4;
  line-height: 1.5;
}

.msg.me {
  border-color: #365486;
  background: #13223a;
}

.msg-thinking {
  color: var(--muted);
  font-style: italic;
}

.msg-muted {
  color: var(--muted);
  font-size: 12px;
}

.msg-error {
  border-color: #6b3a3a;
  background: #1a1515;
  color: #e0a0a0;
}

.msg-list {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 6px;
}

.msg-list li {
  margin: 0;
}

.settings-block-second {
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
}

.settings-block a {
  color: var(--accent);
}

.agent-view {
  padding: 14px;
  display: grid;
  gap: 12px;
}

.ticker-intel-layout {
 display: grid;
grid-template-columns: 480px 1fr;
 gap: 12px;
}

.coverage-legend {
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.legend-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid #4c5f88;
  padding: 2px 8px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.legend-chip.good {
  border-color: #2f9f6a;
  color: #b9f1d5;
  background: rgba(30, 107, 72, 0.26);
}

.legend-chip.caution {
  border-color: #c39b45;
  color: #ffe8b6;
  background: rgba(125, 94, 32, 0.3);
}

.legend-chip.risk {
  border-color: #be5f72;
  color: #ffd7df;
  background: rgba(139, 56, 74, 0.28);
}

.ticker-intel-list,
.ticker-intel-report {
 border: 1px solid var(--line);
 border-radius: 12px;
 background: #0d1628;
}

.ticker-intel-list {
 padding: 12px;
}

.ticker-intel-list h4 {
 margin: 0;
 font-size: 14px;
 color: #dce8ff;
}

.ticker-items {
 margin-top: 10px;
 display: grid;
 gap: 6px;
 max-height: 66vh;
 overflow: auto;
 padding-right: 2px;
}

.ticker-list-footer {
  margin-top: 8px;
  display: grid;
  gap: 6px;
}

.ticker-filters {
 display: grid;
 gap: 8px;
 margin-top: 8px;
}

.ticker-filters-inline {
  display: grid;
  grid-template-columns: minmax(180px, 1.35fr) minmax(110px, 1fr) minmax(110px, 1fr);
  gap: 8px;
}

.watchboard-strip {
  border: 1px solid #2b3f63;
  border-radius: 10px;
  padding: 8px;
  background: rgba(18, 32, 54, 0.45);
}

.watchboard-strip-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 6px;
}

.watchboard-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #a9bfeb;
  font-weight: 700;
}

.watchboard-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.watchboard-chip,
.watchboard-refresh-btn {
  border: 1px solid #385581;
  border-radius: 999px;
  background: #122340;
  color: #d7e7ff;
  padding: 5px 9px;
  font-size: 11px;
  cursor: pointer;
}

.watchboard-chip.active {
  border-color: #6ea3ff;
  background: #1a335c;
}

.watchboard-chip:hover,
.watchboard-refresh-btn:hover {
  border-color: #5474af;
  background: #162a4a;
}

.ticker-item {
border: 1px solid var(--blue-700);
 border-radius: 8px;
background: var(--blue-900);
 color: #cfe0ff;
 padding: 8px 10px;
 text-align: left;
 cursor: pointer;
 display: grid;
 gap: 5px;
}

.ticker-item:hover {
border-color: var(--blue-500);
background: var(--blue-850);
}

.ticker-item.active {
border-color: var(--blue-350);
background: linear-gradient(180deg, var(--blue-650) 0%, var(--blue-750) 100%);
 color: #f1f6ff;
box-shadow: 0 0 0 1px rgba(134, 185, 255, 0.22);
}

.ticker-item.tone-strong {
  border-left: 4px solid var(--blue-350);
}

.ticker-item.tone-weak {
  border-left: 4px solid var(--blue-600);
}

.ticker-item.tone-mixed {
  border-left: 4px solid var(--blue-500);
}

.ticker-item-symbol {
 font-weight: 700;
 letter-spacing: 0.03em;
font-size: 12px;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
max-width: 270px;
}

.ticker-item-company {
  display: block;
  margin-top: 2px;
  font-size: 10px;
  color: #9bb0d8;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ticker-item-snapshot {
  display: block;
  font-size: 10px;
  color: #a8bce2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ticker-meta-inline {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.ticker-catalyst-chip {
  display: inline-flex;
  align-items: center;
  border: 1px solid #415f90;
  border-radius: 999px;
  padding: 1px 7px;
  font-size: 10px;
  color: #d8e7ff;
  background: rgba(58, 89, 134, 0.25);
}

.ticker-data-quality {
  margin-left: auto;
  font-size: 10px;
  color: #97b0dc;
}

.ticker-item-top {
 display: flex;
 align-items: center;
 justify-content: space-between;
 gap: 8px;
}

.ticker-score-badge {
  margin-left: auto;
  margin-right: 4px;
  font-size: 10px;
  border-radius: 999px;
  border: 1px solid #4a5f8d;
  padding: 2px 7px;
  color: #d9e7ff;
  background: rgba(68, 91, 131, 0.25);
}

.ticker-item-bottom {
 display: flex;
 align-items: center;
 justify-content: space-between;
 gap: 8px;
 font-size: 12px;
 color: #bdd0f4;
}

.ticker-item-price {
  min-width: 62px;
}

.ticker-item-sparkline {
  width: 78px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  opacity: 0.95;
}

.ticker-sparkline {
  width: 78px;
  height: 18px;
}

.ticker-sparkline-line {
  fill: none;
  stroke: #a8c9ff;
  stroke-width: 1.3;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.ticker-sparkline-dot {
  fill: #cddfff;
}

.ticker-sparkline-empty {
  font-size: 11px;
  color: #8ca2cb;
}

.ticker-item-loc {
  min-width: 76px;
  display: inline-flex;
  justify-content: center;
}

.ticker-loc-wrap {
  width: 74px;
  display: inline-flex;
  align-items: center;
}

.ticker-loc-track {
  width: 74px;
  height: 5px;
  border-radius: 999px;
  background: var(--blue-850);
  position: relative;
  border: 1px solid var(--blue-650);
}

.ticker-loc-dot {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #d4e5ff;
  border: 1px solid var(--blue-500);
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
}

.ticker-loc-empty {
  font-size: 10px;
  color: #8ca2cb;
}

.ticker-item-actions {
  margin-top: 2px;
}

.ticker-compare-btn {
  border: 1px solid var(--blue-650);
  border-radius: 7px;
  background: var(--blue-800);
  color: #d7e8ff;
  padding: 4px 7px;
  font-size: 10px;
  cursor: pointer;
}

.ticker-compare-btn.active {
  border-color: var(--blue-350);
  background: var(--blue-650);
}

.ticker-compare-wrap {
  overflow: auto;
  border: 1px solid #2b4469;
  border-radius: 9px;
}

.ticker-item.live-up .ticker-item-price,
.ticker-item.live-down .ticker-item-price {
  animation: tickerPulse 0.8s ease-out 1;
}

.ticker-item.live-up .ticker-item-price {
  color: var(--blue-300);
}

.ticker-item.live-down .ticker-item-price {
  color: var(--blue-450);
}

.ticker-item.live-up .ticker-sparkline-line,
.ticker-item.live-down .ticker-sparkline-line {
  animation: tickerLineGlow 0.8s ease-out 1;
}

.ticker-item.live-up .ticker-sparkline-line {
  stroke: var(--blue-300);
}

.ticker-item.live-down .ticker-sparkline-line {
  stroke: var(--blue-500);
}

@keyframes tickerPulse {
  0% {
    transform: translateY(0);
    opacity: 1;
  }
  30% {
    transform: translateY(-1px);
    opacity: 0.8;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes tickerLineGlow {
  0% {
    stroke-width: 1.3;
    opacity: 0.75;
  }
  50% {
    stroke-width: 2;
    opacity: 1;
  }
  100% {
    stroke-width: 1.3;
    opacity: 1;
  }
}

.ticker-item-context {
  font-size: 11px;
  color: #d1e0fb;
  line-height: 1.35;
}

.ticker-item-context.muted {
  color: #9fb3d9;
}

.ticker-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.meta-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid #4a5f8d;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.meta-pill.conf-high {
  border-color: #2f9f6a;
  color: #b9f1d5;
  background: rgba(30, 107, 72, 0.26);
}

.meta-pill.conf-medium,
.meta-pill.conf-unknown {
  border-color: #6f84ad;
  color: #dbe8ff;
  background: rgba(70, 92, 131, 0.25);
}

.meta-pill.conf-low {
  border-color: #9d6e77;
  color: #ffd8de;
  background: rgba(122, 64, 78, 0.25);
}

.meta-pill.risk-low {
  border-color: #2f9f6a;
  color: #b9f1d5;
  background: rgba(30, 107, 72, 0.26);
}

.meta-pill.risk-medium {
  border-color: #c39b45;
  color: #ffe8b6;
  background: rgba(125, 94, 32, 0.3);
}

.meta-pill.risk-high {
  border-color: #be5f72;
  color: #ffd7df;
  background: rgba(139, 56, 74, 0.28);
}

.ticker-warning-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.warning-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid #4a5f8d;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.warning-chip.warn-high-risk {
  border-color: #be5f72;
  color: #ffd7df;
  background: rgba(139, 56, 74, 0.28);
}

.warning-chip.warn-earnings {
  border-color: #c39b45;
  color: #ffe8b6;
  background: rgba(125, 94, 32, 0.3);
}

.warning-chip.warn-big-news {
  border-color: #5b8dd4;
  color: #d4e7ff;
  background: rgba(56, 94, 150, 0.28);
}

.decision-overall {
  background: linear-gradient(180deg, #122547 0%, #0d1b34 100%);
}

.decision-score-main {
  margin-top: 10px;
  font-size: 42px;
  font-weight: 800;
  color: #eff5ff;
  line-height: 1;
}

.decision-score-main span {
  font-size: 16px;
  color: #9db5df;
  margin-left: 4px;
}

.decision-rating {
  margin-top: 8px;
  color: #ffd37a;
  letter-spacing: 0.08em;
}

.decision-subscore-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.decision-subscore-grid div {
  border: 1px solid #263d62;
  border-radius: 8px;
  background: #0f1c33;
  padding: 8px;
  display: grid;
  gap: 3px;
}

.decision-subscore-grid span {
  font-size: 11px;
  color: #9eb3d9;
}

.decision-subscore-grid strong {
  font-size: 13px;
  color: #e4eeff;
}

.ticker-priority-list {
  margin-top: 10px;
  display: grid;
  gap: 8px;
}

.ticker-priority-item {
  border: 1px solid #33507e;
  border-radius: 9px;
  background: #11213d;
  color: #d8e8ff;
  font: inherit;
  padding: 9px 10px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  cursor: pointer;
}

.ticker-priority-item:hover {
  border-color: #6395e4;
  background: #16305a;
}

.sort-mode-row {
  display: flex;
  gap: 6px;
}

.sort-mode-btn {
  flex: 1;
  border: 1px solid #36517c;
  border-radius: 8px;
  background: #10203a;
  color: #cfe0ff;
  padding: 7px 8px;
  font-size: 11px;
  cursor: pointer;
}

.sort-mode-btn.active {
  border-color: #6ea3ff;
  background: #183663;
  color: #f1f6ff;
}

.detail-tab-row {
  display: flex;
  gap: 8px;
}

.detail-tab-btn {
  border: 1px solid #36517c;
  border-radius: 8px;
  background: #10203a;
  color: #cfe0ff;
  padding: 7px 10px;
  font-size: 12px;
  cursor: pointer;
}

.detail-tab-btn.active {
  border-color: #6ea3ff;
  background: #183663;
  color: #f1f6ff;
}

.quick-take-bar {
  border: 1px solid #32527c;
  border-radius: 9px;
  background: #0f213f;
  padding: 10px 12px;
  color: #d7e7ff;
}

.quick-take-bar strong {
  color: #9ec4ff;
}

.hidden-section {
  display: none !important;
}

.ticker-intel-report {
 padding: 14px;
 display: grid;
 gap: 12px;
}

.ticker-workspace-modern {
  display: grid;
  gap: 12px;
}

.ticker-workspace-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid #2a3f63;
  border-radius: 12px;
  background: linear-gradient(180deg, #101d36 0%, #0d1628 100%);
  padding: 12px;
}

.ticker-workspace-header h3 {
  margin: 0;
}

.ticker-source-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: flex-end;
}

.ticker-modern-stats {
  border: 1px solid #273c60;
  border-radius: 10px;
  padding: 10px;
  background: #0f1c33;
}

.ticker-snapshot-card {
  border: 1px solid #355485;
  background: linear-gradient(180deg, #12223f 0%, #0f1b32 100%);
}

.ticker-snapshot-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.ticker-snapshot-head h4 {
  margin: 0;
}

.ticker-snapshot-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.ticker-snapshot-pane {
  border: 1px solid #2a4168;
  border-radius: 10px;
  padding: 10px;
  background: #0d1a31;
  display: grid;
  gap: 8px;
}

.ticker-snapshot-pane div {
  display: grid;
  gap: 3px;
}

.ticker-snapshot-pane span {
  color: #9dbbe8;
  font-size: 12px;
}

.ticker-snapshot-pane strong {
  color: #e8f2ff;
  font-size: 13px;
  line-height: 1.35;
}

.ticker-workspace-grid {
  grid-template-columns: 1fr 1fr;
}

.ticker-gradient-brief {
  border-color: #355485;
  background: linear-gradient(180deg, #12223f 0%, #0f1b32 100%);
}

.ticker-report-header {
 display: flex;
 align-items: flex-start;
 justify-content: space-between;
 gap: 12px;
 border: 1px solid #263a59;
 border-radius: 10px;
 background: #0f1b32;
 padding: 12px;
}

.ticker-report-header h3 {
 margin: 0;
 font-size: 20px;
}

.ticker-report-header p {
 margin: 8px 0 0;
 color: var(--muted);
 line-height: 1.5;
 max-width: 760px;
}

.ticker-report-signal {
 display: grid;
 gap: 6px;
 justify-items: end;
}

.ticker-quote-grid {
 display: grid;
 grid-template-columns: repeat(3, minmax(0, 1fr));
 gap: 12px;
}

.ticker-report-grid {
 display: grid;
 grid-template-columns: 1fr 1fr;
 gap: 12px;
}

.ticker-bullets {
 margin: 8px 0 0;
 padding-left: 18px;
 color: #c6d7f5;
 line-height: 1.5;
}

.ticker-news-list {
 margin: 8px 0 0;
 padding-left: 18px;
 display: grid;
 gap: 8px;
}

.ticker-news-list li {
 color: #c6d7f5;
}

.ticker-news-list a {
 color: #9ac4ff;
 text-decoration: none;
}

.ticker-news-list a:hover {
 text-decoration: underline;
}

.ticker-news-list span {
 display: block;
 color: var(--muted);
 font-size: 11px;
 margin-top: 2px;
}

.schwab-view {
  padding: 16px;
  display: grid;
  gap: 14px;
}

.schwab-hero {
  border: 1px solid #2a3b5f;
  border-radius: 12px;
  padding: 16px;
  background: linear-gradient(180deg, #101b32 0%, #0d1629 100%);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.schwab-hero-copy h3 {
  margin: 0;
  font-size: 20px;
}

.schwab-hero-copy p {
  margin: 8px 0 0;
  color: var(--muted);
  max-width: 760px;
  line-height: 1.5;
}

.schwab-status-pill {
  border-radius: 999px;
  border: 1px solid #5c6f98;
  color: #cfdcff;
  font-size: 11px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-weight: 700;
  padding: 7px 10px;
  white-space: nowrap;
}

.schwab-status-pill.connected {
  border-color: #3ea76d;
  color: #7fe0a6;
  background: rgba(38, 111, 72, 0.2);
}

.schwab-status-pill.offline {
  border-color: #8b6272;
  color: #f2b6c9;
  background: rgba(130, 66, 84, 0.2);
}

.schwab-metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 12px;
}

.schwab-metric-card {
  border: 1px solid #243652;
  border-radius: 10px;
  background: #0d1628;
  padding: 12px;
}

.schwab-metric-card h4 {
  margin: 0;
  color: #9fb3da;
  font-size: 12px;
  font-weight: 600;
}

.schwab-metric-value {
  margin-top: 7px;
  color: #e4eeff;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.2;
}

.schwab-metric-value.small {
  font-size: 14px;
  font-weight: 600;
  word-break: break-word;
}

.schwab-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.portfolio-empty-grid {
  margin-top: 12px;
}

.schwab-card {
  border: 1px solid var(--card-border);
  border-radius: 12px;
  background: linear-gradient(180deg, var(--card-bg-start), var(--card-bg-end));
  padding: 14px;
}

.schwab-card h4 {
  margin: 0;
  color: #dce8ff;
  font-size: 14px;
}

.schwab-card-sub {
  margin: 7px 0 0;
  color: var(--muted);
  line-height: 1.45;
}

.schwab-actions {
  margin-top: 12px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.schwab-btn {
  border-radius: 9px;
  padding: 9px 14px;
  border: 1px solid var(--blue-650);
  background: var(--blue-850);
  color: #d6e4ff;
  cursor: pointer;
  font: inherit;
}

.schwab-btn:hover {
  border-color: var(--blue-450);
}

.schwab-btn-primary {
  background: linear-gradient(180deg, var(--blue-600) 0%, var(--blue-700) 100%);
  border-color: var(--blue-400);
  color: #f1f6ff;
  font-weight: 600;
}

.schwab-btn-ghost {
  background: var(--blue-900);
}

.schwab-list {
  margin: 10px 0 0;
  padding-left: 18px;
  color: #c1d2f3;
  line-height: 1.55;
}

.trade-form {
  margin-top: 12px;
  display: grid;
  gap: 8px;
}

.trade-label {
  color: #9fb3da;
  font-size: 12px;
  font-weight: 600;
}

.trade-input {
  border: 1px solid #2d4366;
  background: #0e1a2f;
  color: #d8e6ff;
  border-radius: 8px;
  padding: 8px 10px;
  font: inherit;
}

.trade-input:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.trade-status {
  margin-top: 10px;
  min-height: 20px;
  font-size: 12px;
  color: #b8c9ea;
}

.trade-status.pending {
  color: #bcd8ff;
}

.trade-status.success {
  color: var(--blue-300);
}

.trade-status.error {
  color: var(--blue-450);
}

.trade-funding-hint {
  margin-top: 8px;
  padding: 8px 10px;
  border: 1px solid #5a4768;
  border-radius: 8px;
  background: rgba(102, 58, 86, 0.2);
  color: #f0c6d9;
  font-size: 12px;
}

.trade-funding-hint a {
  color: #ffd9ea;
}

.cart-toolbar {
  display: flex;
  gap: 10px;
  align-items: center;
  margin-bottom: 12px;
  flex-wrap: wrap;
}

.cart-add-input {
  max-width: 220px;
}

.cart-footer {
  margin-top: 12px;
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
}

.cart-auto-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #bfd2f5;
  font-size: 12px;
}

.cart-input-symbol {
  min-width: 96px;
}

.cart-remove-btn {
  padding: 6px 10px;
}

.cart-table th,
.cart-table td {
  white-space: nowrap;
}

.cart-table tr.tone-up td {
  border-left: 2px solid rgba(129, 185, 255, 0.72);
}

.cart-table tr.tone-down td {
  border-left: 2px solid rgba(71, 118, 193, 0.7);
}

.cart-table tr.tone-flat td {
  border-left: 2px solid rgba(108, 147, 211, 0.45);
}

.cart-row-price {
  font-weight: 600;
}

.cart-row-note {
  font-size: 11px;
  color: #9fb4db;
}

.cart-sell-strip {
  margin-bottom: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.cart-sell-label {
  color: #9fb4dc;
  font-size: 12px;
  font-weight: 600;
}

.cart-sell-chip {
  padding: 5px 9px;
  font-size: 11px;
}

.shopping-market-card {
  border: 1px solid var(--blue-700);
  border-radius: 10px;
  padding: 12px 14px;
  background: linear-gradient(180deg, var(--blue-850) 0%, var(--blue-900) 100%);
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.shopping-market-left {
  display: grid;
  gap: 6px;
}

.shopping-market-right {
  min-width: 260px;
}

.market-state-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 5px 10px;
  font-size: 11px;
  font-weight: 700;
  border: 1px solid #4b6289;
  width: fit-content;
}

.market-state-pill.open {
  color: #a9f1c9;
  border-color: #2f8f5c;
  background: rgba(35, 121, 77, 0.22);
}

.market-state-pill.closed {
  color: #cde3ff;
  border-color: var(--blue-650);
  background: rgba(42, 71, 120, 0.3);
}

.shopping-market-clock {
  font-size: 18px;
  font-weight: 700;
  color: #e4eeff;
}

.shopping-market-now {
  color: #9cb0d5;
  font-size: 12px;
}

.market-gate-note {
  border: 1px solid #435b85;
  border-radius: 8px;
  padding: 8px 10px;
  font-size: 12px;
}

.market-gate-note.open {
  color: #a7edc6;
  border-color: #3d8b62;
  background: rgba(45, 128, 84, 0.16);
}

.market-gate-note.closed {
  color: #cde2ff;
  border-color: var(--blue-650);
  background: rgba(42, 71, 120, 0.24);
}

.shopping-quote-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(175px, 1fr));
  gap: 10px;
}

.shopping-quote-grid-pinned {
  margin-top: 6px;
  margin-bottom: 12px;
}

.shopping-pinned-head {
  margin-top: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

.shopping-pinned-title {
  color: #dce8ff;
  font-size: 12px;
  font-weight: 700;
}

.shopping-pinned-sub {
  color: #93a9d1;
  font-size: 11px;
}

.shopping-quote-tile {
  border: 1px solid var(--blue-700);
  background: var(--blue-900);
  border-radius: 10px;
  padding: 8px 9px;
  text-align: left;
  color: #deebff;
  cursor: pointer;
}

.shopping-quote-tile:hover {
  border-color: var(--blue-450);
  background: var(--blue-850);
}

.shopping-quote-top,
.shopping-quote-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}

.shopping-company-name {
  color: #9bb2da;
  font-size: 10px;
  max-width: 110px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.shopping-quote-bottom {
  margin-top: 7px;
  font-size: 13px;
}

.shopping-holding-tile {
  border-color: var(--blue-500);
  background: linear-gradient(180deg, var(--blue-850) 0%, var(--blue-900) 100%);
}

.shopping-holding-meta {
  margin-top: 6px;
  display: block;
  color: #9bb3dd;
  font-size: 11px;
}

.funding-required-card {
  border-color: var(--blue-700);
  background: linear-gradient(180deg, #151f37 0%, #101a2f 100%);
}

.time-table-wrap {
  margin-top: 10px;
  border: 1px solid #253955;
  border-radius: 8px;
  overflow: hidden;
}

.time-table {
  width: 100%;
  border-collapse: collapse;
}

.time-table th,
.time-table td {
  font-size: 11px;
  padding: 7px 8px;
  border-bottom: 1px solid #1f2f4c;
  text-align: left;
}

.time-table th {
  color: #9eb2d9;
  background: #0f1b30;
  font-weight: 600;
}

.time-table td {
  color: #d9e6ff;
}

.time-table tbody tr:hover {
  background: rgba(66, 92, 140, 0.12);
}

.time-zone-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}

.time-zone-pill {
  border: 1px solid #335179;
  background: #101d34;
  color: #c8dcff;
  border-radius: 999px;
  padding: 6px 11px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
}

.time-zone-pill:hover {
  border-color: #4f77ad;
  background: #142546;
}

.time-zone-pill.active {
  color: #e8f2ff;
  border-color: #5b89c8;
  background: linear-gradient(180deg, #1c3c6b 0%, #163458 100%);
}

.time-session-head {
  display: grid;
  gap: 4px;
  margin-top: 8px;
}

.time-session-head strong {
  font-size: 14px;
  color: #e2edff;
}

.time-session-head span {
  font-size: 12px;
  color: #9eb6db;
}

.time-session-track {
  margin-top: 10px;
  border: 1px solid #2e4569;
  height: 11px;
  border-radius: 999px;
  overflow: hidden;
  background: #0d182b;
}

.time-session-progress {
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, #255aa6 0%, #4f9fff 100%);
  transition: width 220ms ease;
}

.time-session-labels {
  margin-top: 8px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.time-session-labels span {
  color: #a4bbde;
  font-size: 11px;
}

.time-session-labels em {
  display: block;
  font-style: normal;
  color: #dce9ff;
  margin-top: 3px;
}

.time-schedule-table {
  margin-top: 8px;
  width: 100%;
  border-collapse: collapse;
}

.time-schedule-table th,
.time-schedule-table td {
  font-size: 11px;
  text-align: left;
  padding: 7px 8px;
  border-bottom: 1px solid #213554;
}

.time-schedule-table th {
  color: #a3b9dc;
  background: #0f1a30;
  font-weight: 700;
}

.time-schedule-table td {
  color: #dbe8ff;
}

.time-playbook-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  color: #9ab2da;
  font-size: 11px;
}

.time-playbook-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 10px;
}

.time-playbook-card {
  border: 1px solid #2b4366;
  background: #0f1c32;
  border-radius: 8px;
  padding: 10px;
}

.time-playbook-card h5 {
  margin: 0;
  color: #e1edff;
  font-size: 13px;
}

.time-playbook-card p {
  margin: 7px 0 8px;
  color: #a8bede;
  font-size: 12px;
  line-height: 1.35;
}

.time-playbook-card ul {
  margin: 0;
  padding-left: 16px;
  display: grid;
  gap: 4px;
}

.time-playbook-card li {
  color: #d3e3ff;
  font-size: 11px;
}

.time-countdown-only {
  margin-top: 14px;
  border: 1px solid #31507a;
  border-radius: 14px;
  background: linear-gradient(180deg, #10213b 0%, #0d1a30 100%);
  padding: 18px 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.time-countdown-large {
  font-size: clamp(44px, 9vw, 110px);
  line-height: 1;
  letter-spacing: 1px;
  font-weight: 800;
  color: #e7f0ff;
}

.agent-hero {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px;
  background: #0e1629;
}

.agent-hero h3 {
  margin: 0;
  font-size: 18px;
}

.agent-hero p {
  margin: 6px 0 0;
  color: var(--muted);
  line-height: 1.45;
}

.agent-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.agent-card {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 12px;
  background: #0d1628;
}

.agent-card h4 {
  margin: 0 0 8px;
  font-size: 13px;
  color: #dce8ff;
}

.agent-list {
  margin: 0;
  padding-left: 18px;
  color: #bdd0f4;
}

.agent-list li {
  margin: 0 0 6px;
}

.prompt-list {
  display: grid;
  gap: 8px;
}

.prompt-btn {
  border: 1px solid #314266;
  color: #c9dbff;
  background: #101b2f;
  border-radius: 8px;
  padding: 8px 10px;
  cursor: pointer;
  text-align: left;
  font: inherit;
}

.prompt-btn:hover {
  border-color: #5474af;
  background: #162640;
}

.chat-form {
  border-top: 1px solid var(--line);
  padding: 10px;
  display: flex;
  gap: 8px;
}

.chat-form input {
  flex: 1;
  border: 1px solid #2b3b5a;
  background: #0e1728;
  color: #dce8ff;
  border-radius: 8px;
  padding: 8px 10px;
}

.chat-form button {
  border: 1px solid #3f5f98;
  background: #17305a;
  color: #e9f1ff;
  border-radius: 8px;
  padding: 8px 12px;
  cursor: pointer;
}

.chat-form button:disabled,
.chat-form input:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

@media (max-width: 1200px) {
  .app-shell {
    --left-panel-width: 200px;
    --chat-panel-width: 0px;
  }

  .chat-panel {
    display: none;
  }
}

@media (max-width: 900px) {
  .agent-grid {
    grid-template-columns: 1fr;
  }

  .schwab-metrics {
    grid-template-columns: 1fr;
  }

  .schwab-grid {
    grid-template-columns: 1fr;
  }

 .ticker-intel-layout {
 grid-template-columns: 1fr;
 }

 .ticker-filters-inline {
 grid-template-columns: 1fr;
 }

 .ticker-report-grid {
 grid-template-columns: 1fr;
 }

 .ticker-quote-grid {
 grid-template-columns: 1fr;
 }

 .ticker-workspace-grid {
 grid-template-columns: 1fr;
 }

 .ticker-workspace-header {
 flex-direction: column;
 }

 .ticker-source-badges {
 justify-content: flex-start;
 }

 .ticker-snapshot-head {
  flex-direction: column;
 }

 .ticker-snapshot-grid {
  grid-template-columns: 1fr;
 }
}
