.quick-links {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.quick-link-card,
.strategy-card,
.strategy-item {
  background: rgba(31, 41, 55, 0.85);
  border: 1px solid var(--panel-border);
  border-radius: 14px;
  padding: 14px;
}

.quick-link-card {
  display: flex;
  flex-direction: column;
  gap: 6px;
  color: var(--text);
}

.quick-link-card:hover {
  background: rgba(51, 65, 85, 0.95);
  text-decoration: none;
}

.compact-table th,
.compact-table td {
  padding-top: 10px;
  padding-bottom: 10px;
}

.list-stack,
.strategy-grid {
  display: grid;
  gap: 12px;
}

.strategy-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.status-panel {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.preview-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.preview-item {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border: 1px solid var(--panel-border);
  border-radius: 12px;
  background: rgba(31, 41, 55, 0.72);
  color: var(--text);
}

.preview-item:hover {
  text-decoration: none;
  background: rgba(51, 65, 85, 0.92);
}

.preview-main,
.preview-side {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.preview-main {
  flex: 1;
  min-width: 0;
}

a.preview-main {
  color: inherit;
  text-decoration: none;
}

.home-tracking-item {
  align-items: stretch;
}

.preview-side {
  align-items: flex-end;
  justify-content: center;
}

.chart-wrap {
  width: 100%;
  overflow: hidden;
}

.mini-chart {
  width: 100%;
  height: 220px;
  display: block;
  background: rgba(15, 23, 42, 0.5);
  border: 1px solid var(--panel-border);
  border-radius: 12px;
  cursor: crosshair;
  touch-action: none;
  user-select: none;
}

.mini-chart .chart-grid line {
  stroke: rgba(148, 163, 184, 0.18);
  stroke-width: 1;
}

.mini-chart .chart-line {
  filter: drop-shadow(0 0 5px rgba(59, 130, 246, 0.18));
}

.mini-chart .chart-focus line {
  stroke: rgba(226, 232, 240, 0.55);
  stroke-width: 1;
  stroke-dasharray: 4 4;
}

.mini-chart .chart-focus circle {
  fill: #f8fafc;
  stroke: #0f172a;
  stroke-width: 2;
}

.mini-chart .chart-focus text {
  fill: #cbd5e1;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.01em;
  paint-order: stroke;
  stroke: rgba(15, 23, 42, 0.78);
  stroke-width: 2px;
  stroke-linejoin: round;
}

.mini-chart .chart-focus-extra {
  fill: #94a3b8;
  font-size: 11px;
}

.status-detail {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.detail-grid {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 10px 14px;
}

.stock-detail-panels .card {
  height: 100%;
}

@media (max-width: 960px) {
  .quick-links,
  .strategy-grid,
  .detail-grid {
    grid-template-columns: 1fr;
  }
}

/* Stock detail V2 visual refresh */
.stock-detail-shell {
  background:
    radial-gradient(circle at 12% 0%, rgba(14, 116, 144, 0.18), transparent 30%),
    radial-gradient(circle at 80% 8%, rgba(37, 99, 235, 0.12), transparent 28%);
}

.stock-detail-main {
  max-width: 1500px;
  width: 100%;
}

.stock-detail-hero {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(520px, 0.9fr);
  gap: 18px;
  align-items: end;
  margin-bottom: 18px;
}

.stock-identity h1 {
  margin: 4px 0 8px;
  font-size: clamp(26px, 3vw, 36px);
  letter-spacing: -0.03em;
}

.stock-quote-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.stock-quote-card {
  border: 1px solid rgba(51, 65, 85, 0.9);
  background: linear-gradient(180deg, rgba(17, 34, 56, 0.92), rgba(10, 20, 35, 0.92));
  border-radius: 15px;
  padding: 13px 14px;
  box-shadow: 0 14px 36px rgba(0, 0, 0, 0.2);
  min-width: 0;
}

.stock-quote-card span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  white-space: nowrap;
}

.stock-quote-card strong {
  display: block;
  margin-top: 8px;
  font-size: clamp(17px, 1.6vw, 24px);
  line-height: 1.1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.stock-quote-card.primary-price strong {
  font-size: clamp(24px, 2.5vw, 34px);
}

.stock-chart-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
  gap: 18px;
  margin-bottom: 18px;
}

.chart-card,
.compact-info-card,
.stock-news-card,
.history-card {
  background: linear-gradient(180deg, rgba(17, 34, 56, 0.94), rgba(8, 18, 32, 0.94));
  border-color: rgba(51, 65, 85, 0.92);
}

.stock-card-header {
  margin-bottom: 12px;
}

.card-kicker {
  margin: 0 0 4px;
  color: #38bdf8;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.chart-tabs {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.chart-tabs button {
  border: 1px solid rgba(51, 65, 85, 0.95);
  background: rgba(15, 23, 42, 0.75);
  color: var(--muted);
  border-radius: 999px;
  padding: 5px 11px;
  font-size: 12px;
}

.chart-tabs button.active {
  color: #e0f2fe;
  border-color: rgba(56, 189, 248, 0.55);
  background: rgba(14, 116, 144, 0.24);
}

.chart-tabs button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.kline-control-stack {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
}

.kline-date-range {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.kline-date-range label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #8fa3bd;
  font-size: 11px;
  font-weight: 850;
}

.kline-date-range input {
  color-scheme: dark;
  width: 126px;
  border: 1px solid rgba(56, 189, 248, 0.28);
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.82);
  color: #dbeafe;
  padding: 5px 9px;
  font-size: 12px;
  font-weight: 800;
  outline: none;
}

.kline-date-range input:focus {
  border-color: rgba(56, 189, 248, 0.75);
  box-shadow: 0 0 0 2px rgba(56, 189, 248, 0.12);
}

.enhanced-chart-wrap {
  border: 1px solid rgba(30, 41, 59, 0.8);
  background: linear-gradient(180deg, #081525, #0b1626);
  border-radius: 15px;
  padding: 2px;
}

.enhanced-chart {
  height: 260px;
  border: none;
  background: transparent;
}

.stock-insight-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-bottom: 18px;
}

.stock-lower-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(330px, 0.75fr);
  gap: 18px;
  align-items: start;
  margin-bottom: 18px;
}

.stock-side-stack {
  display: grid;
  gap: 18px;
}

.compact-info-card .detail-grid {
  grid-template-columns: minmax(92px, 0.75fr) minmax(0, 1fr);
  gap: 8px 12px;
  font-size: 14px;
}

.compact-info-card .detail-grid strong {
  color: #cbd5e1;
}

.stock-news-list {
  display: grid;
  gap: 10px;
}

.stock-news-card .preview-item {
  align-items: flex-start;
  background: rgba(15, 23, 42, 0.62);
  border-color: rgba(51, 65, 85, 0.72);
}

.stock-news-card .preview-item:hover {
  background: rgba(30, 41, 59, 0.72);
}

.stock-news-card .news-title-row {
  align-items: flex-start;
  gap: 8px;
}

.stock-news-card .news-title-row strong {
  flex: 1 1 280px;
  line-height: 1.5;
}

.stock-news-card .badge {
  flex: 0 0 auto;
}

.history-card {
  margin-bottom: 0;
}

@media (max-width: 1180px) {
  .stock-detail-hero,
  .stock-chart-grid,
  .stock-lower-grid {
    grid-template-columns: 1fr;
  }

  .stock-quote-grid,
  .stock-insight-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .stock-quote-grid,
  .stock-insight-grid {
    grid-template-columns: 1fr;
  }

  .enhanced-chart {
    height: 230px;
  }
}

/* Stock detail V2 stronger reference-style overrides */
body[data-page="stock-detail"] {
  background:
    radial-gradient(circle at 13% 0%, rgba(14, 116, 144, 0.22), transparent 30%),
    radial-gradient(circle at 80% 7%, rgba(37, 99, 235, 0.16), transparent 28%),
    linear-gradient(180deg, #07111f 0%, #050b14 100%);
}

body[data-page="stock-detail"] .app-shell {
  grid-template-columns: 220px minmax(0, 1fr);
}

body[data-page="stock-detail"] .sidebar {
  padding: 22px 16px;
  background: rgba(6, 13, 24, 0.78);
  border-right-color: #21344f;
  backdrop-filter: blur(18px);
}

body[data-page="stock-detail"] .brand {
  font-size: 19px;
  font-weight: 850;
  letter-spacing: -0.02em;
}

body[data-page="stock-detail"] .global-stock-search {
  grid-template-columns: 1fr;
  gap: 6px;
}

body[data-page="stock-detail"] .global-stock-search input {
  height: 38px;
  background: #0b1626;
  border-color: #21344f;
}

body[data-page="stock-detail"] .global-stock-search .btn {
  padding: 8px 10px;
  background: #13243b;
  border: 1px solid #21344f;
}

body[data-page="stock-detail"] .nav {
  gap: 4px;
}

body[data-page="stock-detail"] .nav a {
  color: #b7c6d8;
  padding: 11px 12px;
}

body[data-page="stock-detail"] .nav a:hover,
body[data-page="stock-detail"] .nav a.active {
  color: #fff;
  background: #13243b;
}

.stock-detail-main {
  padding: 22px 26px 34px;
}

.stock-detail-hero {
  border: 1px solid rgba(33, 52, 79, 0.72);
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(12, 28, 48, 0.72), rgba(7, 17, 31, 0.18));
  padding: 18px;
  box-shadow: 0 18px 60px rgba(0, 0, 0, 0.24);
}

.stock-identity h1 {
  color: #f8fafc;
  font-weight: 900;
}

.stock-hero-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.stock-hero-tags span {
  border: 1px solid rgba(56, 189, 248, 0.28);
  background: rgba(14, 116, 144, 0.14);
  color: #bae6fd;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 12px;
}

.stock-quote-card {
  background: linear-gradient(180deg, rgba(15, 27, 45, 0.94), rgba(9, 19, 34, 0.94));
  border-color: #21344f;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035), 0 12px 34px rgba(0, 0, 0, 0.22);
}

.stock-quote-card.primary-price {
  border-color: rgba(56, 189, 248, 0.42);
  background: linear-gradient(180deg, rgba(14, 55, 82, 0.8), rgba(9, 23, 40, 0.96));
}

body[data-page="stock-detail"] .card {
  padding: 16px;
  margin-bottom: 0;
  border-radius: 18px;
  border-color: #21344f;
  background: linear-gradient(180deg, rgba(18, 34, 56, 0.92), rgba(10, 20, 35, 0.94));
  box-shadow: 0 16px 50px rgba(0, 0, 0, 0.28);
}

body[data-page="stock-detail"] .card-header {
  margin-bottom: 12px;
}

body[data-page="stock-detail"] .card-header h2 {
  margin: 0;
  font-size: 17px;
  letter-spacing: -0.01em;
}

.enhanced-chart-wrap {
  padding: 0;
  border-color: #20334c;
  background: linear-gradient(180deg, #091527, #0c1727);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.enhanced-chart {
  height: 246px;
  border-radius: 14px;
}

.mini-chart .chart-grid line {
  stroke: rgba(33, 52, 79, 0.95);
}

.mini-chart .chart-focus text {
  fill: #dbeafe;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.01em;
  stroke: rgba(7, 17, 31, 0.86);
  stroke-width: 2px;
}

body[data-page="stock-detail"] .detail-grid {
  color: #cbd5e1;
}

body[data-page="stock-detail"] .detail-grid > div:nth-child(odd) {
  color: #8fa3bd;
}

body[data-page="stock-detail"] .detail-grid > div:nth-child(even) {
  color: #e5eefb;
  text-align: right;
  overflow-wrap: anywhere;
}

.stock-news-card .preview-item {
  border-color: rgba(33, 52, 79, 0.92);
  background: rgba(11, 22, 38, 0.78);
  border-radius: 14px;
}

.stock-news-card .news-title-row {
  display: flex;
  flex-wrap: wrap;
}

.stock-news-card .news-summary {
  margin-top: 4px;
  line-height: 1.55;
}

body[data-page="stock-detail"] table th,
body[data-page="stock-detail"] table td {
  padding: 10px 8px;
}

@media (max-width: 960px) {
  body[data-page="stock-detail"] .app-shell {
    grid-template-columns: 1fr;
  }

  body[data-page="stock-detail"] .sidebar {
    position: static;
    height: auto;
  }

  .stock-detail-main {
    padding: 16px;
  }
}

/* Global financial-console theme refresh */
body:not([data-page="stock-detail"]) {
  background:
    radial-gradient(circle at 12% 0%, rgba(14, 116, 144, 0.18), transparent 30%),
    radial-gradient(circle at 82% 6%, rgba(37, 99, 235, 0.13), transparent 28%),
    linear-gradient(180deg, #07111f 0%, #050b14 100%);
}

body:not([data-page="stock-detail"]) .app-shell {
  grid-template-columns: 220px minmax(0, 1fr);
}

body:not([data-page="stock-detail"]) .sidebar {
  padding: 22px 16px;
  background: rgba(6, 13, 24, 0.78);
  border-right-color: #21344f;
  backdrop-filter: blur(18px);
}

body:not([data-page="stock-detail"]) .brand {
  font-size: 19px;
  font-weight: 850;
  letter-spacing: -0.02em;
}

body:not([data-page="stock-detail"]) .global-stock-search {
  grid-template-columns: 1fr;
  gap: 6px;
}

body:not([data-page="stock-detail"]) .global-stock-search input,
body:not([data-page="stock-detail"]) .form-group input,
body:not([data-page="stock-detail"]) .form-group select,
body:not([data-page="stock-detail"]) .tracking-filter-field select,
body:not([data-page="stock-detail"]) .tracking-filter-field input[type="date"],
body:not([data-page="stock-detail"]) .inline-search-actions input {
  background: #0b1626;
  border-color: #21344f;
  color: #e5eefb;
}

body:not([data-page="stock-detail"]) .global-stock-search .btn {
  padding: 8px 10px;
  background: #13243b;
  border: 1px solid #21344f;
}

body:not([data-page="stock-detail"]) .nav {
  gap: 4px;
}

body:not([data-page="stock-detail"]) .nav a {
  color: #b7c6d8;
  padding: 11px 12px;
}

body:not([data-page="stock-detail"]) .nav a:hover,
body:not([data-page="stock-detail"]) .nav a.active {
  color: #fff;
  background: #13243b;
}

body:not([data-page="stock-detail"]) .main-content {
  max-width: 1500px;
  width: 100%;
  padding: 22px 26px 34px;
}

body:not([data-page="stock-detail"]) .page-header {
  border: 1px solid rgba(33, 52, 79, 0.72);
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(12, 28, 48, 0.72), rgba(7, 17, 31, 0.18));
  padding: 18px;
  box-shadow: 0 18px 60px rgba(0, 0, 0, 0.24);
  align-items: center;
  margin-bottom: 18px;
}

body:not([data-page="stock-detail"]) .page-header h1 {
  color: #f8fafc;
  font-weight: 900;
  letter-spacing: -0.03em;
}

body:not([data-page="stock-detail"]) .page-desc,
body:not([data-page="stock-detail"]) .page-subtitle {
  margin: 0;
  color: #8fa3bd;
  max-width: 880px;
}

body:not([data-page="stock-detail"]) .eyebrow,
body:not([data-page="stock-detail"]) .card-kicker {
  color: #38bdf8;
}

body:not([data-page="stock-detail"]) .card,
body:not([data-page="stock-detail"]) .stat-card,
body:not([data-page="stock-detail"]) .quick-link-card,
body:not([data-page="stock-detail"]) .strategy-card,
body:not([data-page="stock-detail"]) .strategy-item {
  border-radius: 18px;
  border-color: #21344f;
  background: linear-gradient(180deg, rgba(18, 34, 56, 0.92), rgba(10, 20, 35, 0.94));
  box-shadow: 0 16px 50px rgba(0, 0, 0, 0.28);
}

body:not([data-page="stock-detail"]) .card {
  padding: 16px;
}

body:not([data-page="stock-detail"]) .card-header h2,
body:not([data-page="stock-detail"]) .card-header h3 {
  margin: 0 0 6px;
  letter-spacing: -0.01em;
}

body:not([data-page="stock-detail"]) .stat-card {
  padding: 15px;
  background: linear-gradient(180deg, rgba(15, 27, 45, 0.94), rgba(9, 19, 34, 0.94));
  border-color: #21344f;
}

body:not([data-page="stock-detail"]) .stat-label {
  color: #8fa3bd;
  font-size: 12px;
}

body:not([data-page="stock-detail"]) .stat-value {
  margin-top: 8px;
  color: #e5eefb;
  font-size: clamp(20px, 2vw, 30px);
  line-height: 1.08;
}

body:not([data-page="stock-detail"]) .preview-item,
body:not([data-page="stock-detail"]) .list-stack > *:not(.empty-state),
body:not([data-page="stock-detail"]) .note-block,
body:not([data-page="stock-detail"]) .empty-state {
  border-color: rgba(33, 52, 79, 0.92);
  background: rgba(11, 22, 38, 0.72);
}

body:not([data-page="stock-detail"]) .btn-primary {
  background: linear-gradient(135deg, #0ea5e9, #2563eb);
  color: #f8fafc;
}

body:not([data-page="stock-detail"]) .btn-secondary {
  background: #13243b;
  border: 1px solid #21344f;
  color: #dbeafe;
}

body:not([data-page="stock-detail"]) table {
  background: rgba(11, 22, 38, 0.42);
  border-radius: 14px;
  overflow: hidden;
}

body:not([data-page="stock-detail"]) th,
body:not([data-page="stock-detail"]) td {
  border-bottom-color: rgba(33, 52, 79, 0.9);
}

body:not([data-page="stock-detail"]) th {
  color: #8fa3bd;
}

body:not([data-page="stock-detail"]) .badge {
  border: 1px solid rgba(49, 80, 111, 0.95);
}

@media (max-width: 960px) {
  body:not([data-page="stock-detail"]) .app-shell {
    grid-template-columns: 1fr;
  }

  body:not([data-page="stock-detail"]) .sidebar {
    position: static;
    height: auto;
  }

  body:not([data-page="stock-detail"]) .main-content {
    padding: 16px;
  }

  body:not([data-page="stock-detail"]) .page-header {
    align-items: stretch;
  }
}

/* Wide-screen layout fix: use the available viewport width */
.stock-detail-main,
body:not([data-page="stock-detail"]) .main-content {
  max-width: none;
  width: 100%;
}

body:not([data-page="stock-detail"]) .content-grid.two-columns {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body[data-page="home"] .content-grid.two-columns {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body[data-page="home"] .stat-grid.compact-stats,
body[data-page="tracking"] .stat-grid.compact-stats {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

body[data-page="tracking"] .stat-grid.compact-stats {
  grid-template-columns: repeat(7, minmax(0, 1fr));
}

@media (max-width: 1180px) {
  body[data-page="home"] .stat-grid.compact-stats,
  body[data-page="tracking"] .stat-grid.compact-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  body[data-page="home"] .content-grid.two-columns,
  body:not([data-page="stock-detail"]) .content-grid.two-columns,
  body[data-page="home"] .stat-grid.compact-stats,
  body[data-page="tracking"] .stat-grid.compact-stats {
    grid-template-columns: 1fr;
  }
}

/* Tracking include/exclude statistics toggle */
.tracking-excluded-row {
  opacity: 0.58;
}

.tracking-excluded-row td {
  background: rgba(15, 23, 42, 0.22);
}

.btn-warning {
  background: rgba(245, 158, 11, 0.16);
  border: 1px solid rgba(245, 158, 11, 0.45);
  color: #fde68a;
}

.btn-sm {
  padding: 6px 9px;
  font-size: 12px;
  border-radius: 8px;
}

/* Tracking page market-color emphasis: A-share convention, red = stronger/positive, green = weaker/negative */
body[data-page="tracking"] .up,
body[data-page="tracking"] .stat-value.up,
body[data-page="tracking"] td.up {
  color: #f87171 !important;
}

body[data-page="tracking"] .down,
body[data-page="tracking"] .stat-value.down,
body[data-page="tracking"] td.down {
  color: #4ade80 !important;
}

/* GPT-image-2 full UI direction rollout: richer financial dashboard style */
body {
  background:
    radial-gradient(circle at 8% -8%, rgba(14, 165, 233, 0.22), transparent 34%),
    radial-gradient(circle at 78% 2%, rgba(37, 99, 235, 0.16), transparent 32%),
    radial-gradient(circle at 50% 100%, rgba(15, 23, 42, 0.88), transparent 44%),
    linear-gradient(180deg, #07111f 0%, #08111f 52%, #050b14 100%);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(148, 163, 184, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(148, 163, 184, 0.035) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,.7), transparent 78%);
}

body .app-shell {
  grid-template-columns: 228px minmax(0, 1fr);
}

body .sidebar {
  padding: 24px 16px;
  background: linear-gradient(180deg, rgba(5, 13, 25, 0.92), rgba(8, 18, 32, 0.78));
  border-right: 1px solid rgba(56, 189, 248, 0.16);
  box-shadow: 18px 0 60px rgba(0, 0, 0, 0.28);
  backdrop-filter: blur(18px);
}

body .brand {
  position: relative;
  padding-left: 12px;
  font-weight: 900;
  letter-spacing: -0.03em;
}

body .brand::before {
  content: "";
  position: absolute;
  left: 0;
  top: 3px;
  width: 4px;
  height: 22px;
  border-radius: 999px;
  background: linear-gradient(180deg, #38bdf8, #2563eb);
  box-shadow: 0 0 18px rgba(56, 189, 248, 0.55);
}

body .global-stock-search {
  grid-template-columns: 1fr;
  gap: 8px;
  padding: 10px;
  border: 1px solid rgba(33, 52, 79, 0.85);
  border-radius: 15px;
  background: rgba(15, 23, 42, 0.42);
}

body .global-stock-search input,
body .form-group input,
body .form-group select,
body .tracking-filter-field select,
body .tracking-filter-field input[type="date"],
body .inline-search-actions input,
body .global-stock-search input {
  background: rgba(8, 18, 32, 0.92);
  border-color: rgba(56, 189, 248, 0.18);
  color: #e5eefb;
}

body .global-stock-search .btn {
  background: linear-gradient(135deg, rgba(14, 116, 144, 0.3), rgba(37, 99, 235, 0.26));
  border: 1px solid rgba(56, 189, 248, 0.24);
}

body .nav a {
  color: #b7c6d8;
  border: 1px solid transparent;
}

body .nav a:hover,
body .nav a.active {
  color: #f8fafc;
  background: linear-gradient(135deg, rgba(14, 116, 144, 0.22), rgba(37, 99, 235, 0.18));
  border-color: rgba(56, 189, 248, 0.18);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 10px 28px rgba(14, 116, 144, 0.13);
}

body .main-content {
  position: relative;
  z-index: 1;
  padding: 24px 28px 36px;
}

body .page-header,
.stock-detail-hero {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(56, 189, 248, 0.18);
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(14, 116, 144, 0.18), transparent 34%),
    linear-gradient(180deg, rgba(18, 34, 56, 0.88), rgba(8, 18, 32, 0.72));
  box-shadow: 0 20px 70px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

body .page-header::after,
.stock-detail-hero::after {
  content: "";
  position: absolute;
  right: -100px;
  top: -140px;
  width: 330px;
  height: 330px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(56, 189, 248, 0.2), transparent 66%);
}

body .page-header > *,
.stock-detail-hero > * {
  position: relative;
  z-index: 1;
}

body .eyebrow,
body .card-kicker {
  color: #67e8f9;
  text-shadow: 0 0 14px rgba(56, 189, 248, 0.28);
}

body .page-header h1,
.stock-identity h1 {
  color: #f8fafc;
  font-weight: 900;
}

body .card,
body .stat-card,
body .quick-link-card,
body .strategy-card,
body .strategy-item,
.stock-quote-card {
  border: 1px solid rgba(56, 189, 248, 0.16);
  background:
    linear-gradient(180deg, rgba(18, 34, 56, 0.92), rgba(8, 18, 32, 0.94));
  box-shadow: 0 18px 58px rgba(0,0,0,.32), inset 0 1px 0 rgba(255,255,255,.035);
}

body .card:hover,
body .stat-card:hover,
body .preview-item:hover,
body .strategy-item:hover {
  border-color: rgba(56, 189, 248, 0.28);
}

body .stat-card,
.stock-quote-card {
  position: relative;
  overflow: hidden;
}

body .stat-card::after,
.stock-quote-card::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 2px;
  background: linear-gradient(90deg, rgba(56,189,248,.75), rgba(37,99,235,.15), transparent);
}

body .stat-value,
.stock-quote-card strong {
  color: #f8fafc;
  letter-spacing: -0.035em;
}

body .content-grid,
.stock-chart-grid,
.stock-insight-grid,
.stock-lower-grid {
  gap: 18px;
}

body .content-grid.two-columns.top-align > .card:first-child,
body[data-page="backtest"] .content-grid.two-columns.top-align > .card:first-child,
body[data-page="selection"] .content-grid.two-columns.top-align > .card:first-child {
  border-color: rgba(56, 189, 248, 0.24);
}

body[data-page="selection"] .content-grid.two-columns.top-align,
body[data-page="backtest"] .content-grid.two-columns.top-align {
  grid-template-columns: minmax(320px, 0.72fr) minmax(0, 1.28fr);
}

body[data-page="selection"] .selection-filter-form {
  grid-template-columns: minmax(260px, 1.1fr) minmax(200px, .8fr) minmax(160px, .55fr) minmax(160px, .55fr);
  padding: 12px;
  border: 1px solid rgba(33, 52, 79, 0.72);
  border-radius: 15px;
  background: rgba(8, 18, 32, 0.42);
  margin-bottom: 14px;
}

body[data-page="tracking"] .stat-grid.compact-stats {
  grid-template-columns: repeat(7, minmax(0, 1fr));
}

body[data-page="tracking"] .card:nth-of-type(1),
body[data-page="tracking"] .card:nth-of-type(2) {
  background:
    linear-gradient(135deg, rgba(14, 116, 144, 0.13), transparent 36%),
    linear-gradient(180deg, rgba(18, 34, 56, 0.92), rgba(8, 18, 32, 0.94));
}

body[data-page="backtest"] #backtest-detail-section .stat-grid.compact-stats {
  grid-template-columns: repeat(7, minmax(0, 1fr));
}

body[data-page="strategies"] .strategy-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body[data-page="strategies"] .strategy-detail,
body[data-page="strategies"] #strategy-factor-summary {
  padding: 12px;
  border: 1px solid rgba(33, 52, 79, 0.72);
  border-radius: 14px;
  background: rgba(8, 18, 32, 0.46);
}

body[data-page="system"] .content-grid.two-columns {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body[data-page="system"] .status-panel,
body[data-page="backtest"] .status-panel,
body[data-page="selection"] .list-stack {
  gap: 10px;
}

body .preview-item,
body .list-stack > *:not(.empty-state),
body .note-block,
body .empty-state {
  border-color: rgba(33, 52, 79, 0.82);
  background: rgba(8, 18, 32, 0.54);
}

body table {
  background: rgba(8, 18, 32, 0.42);
  border: 1px solid rgba(33, 52, 79, 0.65);
  border-radius: 16px;
  overflow: hidden;
}

body th {
  background: rgba(15, 23, 42, 0.72);
  color: #93a9c4;
}

body td,
body th {
  border-bottom-color: rgba(33, 52, 79, 0.72);
}

body .btn-primary {
  background: linear-gradient(135deg, #0ea5e9, #2563eb);
  color: #fff;
  box-shadow: 0 10px 28px rgba(37, 99, 235, 0.28);
}

body .btn-secondary {
  background: linear-gradient(135deg, rgba(15, 23, 42, 0.95), rgba(30, 41, 59, 0.86));
  border: 1px solid rgba(56, 189, 248, 0.18);
  color: #dbeafe;
}

.enhanced-chart-wrap,
.chart-wrap .mini-chart {
  background:
    linear-gradient(180deg, rgba(8, 18, 32, 0.96), rgba(4, 10, 20, 0.94));
  border-color: rgba(56, 189, 248, 0.16);
}

@media (max-width: 1280px) {
  body[data-page="tracking"] .stat-grid.compact-stats,
  body[data-page="backtest"] #backtest-detail-section .stat-grid.compact-stats,
  body[data-page="strategies"] .strategy-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="selection"] .content-grid.two-columns.top-align,
  body[data-page="backtest"] .content-grid.two-columns.top-align,
  body[data-page="system"] .content-grid.two-columns {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  body .app-shell {
    grid-template-columns: 1fr;
  }

  body .sidebar {
    position: static;
    height: auto;
  }

  body[data-page="tracking"] .stat-grid.compact-stats,
  body[data-page="backtest"] #backtest-detail-section .stat-grid.compact-stats,
  body[data-page="strategies"] .strategy-grid,
  body[data-page="selection"] .selection-filter-form {
    grid-template-columns: 1fr;
  }
}

/* Visible rollout pass: make GPT-image-2 direction unmistakable */
body .app-shell {
  grid-template-columns: 252px minmax(0, 1fr);
}

body .sidebar {
  padding: 26px 18px;
  background:
    linear-gradient(180deg, rgba(3, 10, 22, 0.98), rgba(8, 18, 32, 0.92)),
    radial-gradient(circle at 50% 0%, rgba(56, 189, 248, 0.22), transparent 44%);
}

body .brand {
  margin-bottom: 28px;
  font-size: 21px;
}

body .nav a {
  margin: 2px 0;
  padding: 12px 13px;
  font-weight: 650;
}

body .nav a.active {
  position: relative;
  background: linear-gradient(135deg, rgba(14, 116, 144, 0.36), rgba(37, 99, 235, 0.26));
  border-color: rgba(56, 189, 248, 0.34);
}

body .nav a.active::before {
  content: "";
  position: absolute;
  left: -7px;
  top: 9px;
  bottom: 9px;
  width: 4px;
  border-radius: 999px;
  background: #38bdf8;
  box-shadow: 0 0 18px rgba(56, 189, 248, 0.85);
}

body .main-content {
  padding: 26px 30px 40px;
}

body .page-header,
.stock-detail-hero {
  min-height: 128px;
  align-items: center;
  padding: 22px;
  margin-bottom: 22px;
  background:
    linear-gradient(115deg, rgba(14, 116, 144, 0.30), rgba(37, 99, 235, 0.12) 42%, rgba(8, 18, 32, 0.82)),
    linear-gradient(180deg, rgba(18, 34, 56, 0.96), rgba(8, 18, 32, 0.92));
}

body .page-header h1,
.stock-identity h1 {
  font-size: clamp(30px, 3.2vw, 44px);
}

body .page-desc,
body .page-subtitle,
.stock-detail-hero .page-desc {
  color: #b7c6d8;
  font-size: 15px;
}

body .card,
body .stat-card,
.stock-quote-card {
  border-color: rgba(56, 189, 248, 0.24);
  background:
    linear-gradient(150deg, rgba(14, 116, 144, 0.08), transparent 34%),
    linear-gradient(180deg, rgba(18, 34, 56, 0.96), rgba(8, 18, 32, 0.96));
}

body .card-header {
  position: relative;
  padding-left: 12px;
}

body .card-header::before {
  content: "";
  position: absolute;
  left: 0;
  top: 4px;
  bottom: 6px;
  width: 3px;
  border-radius: 999px;
  background: linear-gradient(180deg, #38bdf8, #2563eb);
  box-shadow: 0 0 12px rgba(56, 189, 248, 0.45);
}

body .stat-grid.compact-stats {
  gap: 14px;
}

body .stat-card {
  min-height: 112px;
}

body .stat-label,
.stock-quote-card span {
  color: #9fb4cf;
  font-weight: 700;
  letter-spacing: .02em;
}

body .stat-value,
.stock-quote-card strong {
  font-size: clamp(24px, 2.25vw, 36px);
  margin-top: 10px;
}

body .content-grid,
.stock-chart-grid,
.stock-insight-grid,
.stock-lower-grid {
  gap: 22px;
  margin-bottom: 22px;
}

body table {
  border-color: rgba(56, 189, 248, 0.18);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
}

body th {
  background: linear-gradient(180deg, rgba(15, 37, 59, 0.96), rgba(15, 23, 42, 0.92));
  color: #b7c6d8;
  font-weight: 750;
}

body tr:hover td {
  background: rgba(14, 116, 144, 0.08);
}

body .preview-item,
body .strategy-item,
body .list-stack > *:not(.empty-state) {
  border-left: 3px solid rgba(56, 189, 248, 0.42);
}

body[data-page="home"] .stat-grid.compact-stats,
body[data-page="selection"] .stat-grid.compact-stats,
body[data-page="strategies"] .stat-grid.compact-stats,
body[data-page="system"] .stat-grid.compact-stats {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (max-width: 960px) {
  body .app-shell {
    grid-template-columns: 1fr;
  }

  body[data-page="home"] .stat-grid.compact-stats,
  body[data-page="selection"] .stat-grid.compact-stats,
  body[data-page="strategies"] .stat-grid.compact-stats,
  body[data-page="system"] .stat-grid.compact-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Structure rollout: real DOM layouts closer to GPT-image-2 previews */
.dashboard-main {
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.dashboard-hero {
  display: grid;
  grid-template-columns: minmax(280px, 0.42fr) minmax(0, 1fr);
  gap: 22px;
  align-items: stretch;
  margin-bottom: 0;
}

.dashboard-hero-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}

.dashboard-hero-copy h1,
.dashboard-hero h1 {
  margin: 4px 0 10px;
  font-size: clamp(32px, 3.6vw, 48px);
}

.dashboard-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 18px;
}

.hero-stats {
  margin: 0;
  align-self: stretch;
}

.hero-stats .stat-card {
  min-height: 128px;
}

.home-dashboard .hero-stats {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.market-core-card {
  border-color: rgba(248, 113, 113, 0.34) !important;
  background:
    linear-gradient(140deg, rgba(248, 113, 113, 0.11), transparent 34%),
    linear-gradient(180deg, rgba(18, 34, 56, 0.96), rgba(8, 18, 32, 0.96)) !important;
}

.dashboard-grid {
  display: grid;
  gap: 22px;
}

.home-market-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.sector-card .preview-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.sector-card .preview-item {
  align-items: flex-start;
}

.tracking-console-card .tracking-preview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.tracking-console-card .preview-item {
  align-items: stretch;
  min-height: 132px;
}

.selection-command-grid {
  display: grid;
  grid-template-columns: minmax(320px, 0.42fr) minmax(0, 1fr);
  gap: 22px;
}

.command-card {
  position: sticky;
  top: 18px;
  align-self: start;
}

.command-card .stack-form {
  display: grid;
  gap: 13px;
}

.strategy-console-card .list-stack,
.selection-results-console .table-wrap {
  min-height: 260px;
}

.selection-results-console {
  margin-top: 0;
}

.selection-results-console .card-header.with-actions,
.tracking-table-console .card-header {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) auto;
  align-items: end;
}

.selection-results-console .table-wrap,
.tracking-table-console .table-wrap {
  max-height: calc(100vh - 330px);
  overflow: auto;
  border-radius: 16px;
}

.tracking-hero {
  grid-template-columns: minmax(260px, 0.28fr) minmax(0, 1fr);
}

.tracking-stat-strip {
  grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
}

.tracking-review-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: 22px;
}

.review-summary-card,
.review-notes-card {
  min-height: 210px;
}

.deep-review-text {
  margin: 10px 0 0;
  white-space: pre-wrap;
  word-break: break-word;
  font: inherit;
  line-height: 1.65;
  color: var(--text-primary);
  background: transparent;
  border: 0;
}

.tracking-table-console {
  margin-top: 0;
}

.tracking-table-console .tracking-filters {
  justify-content: flex-end;
  padding: 10px;
  border: 1px solid rgba(33, 52, 79, 0.72);
  border-radius: 14px;
  background: rgba(8, 18, 32, 0.46);
}

.tracking-date-field {
  min-width: 150px;
}

.date-input-shell {
  position: relative;
  display: block;
  width: 150px;
  min-height: 42px;
  border: 1px solid #1d3554;
  border-radius: 7px;
  background: #071529;
}

.selection-datetime-shell {
  width: 100%;
}

.date-input-shell:focus-within {
  outline: 1px solid rgba(56, 189, 248, 0.7);
  box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.12);
}

.date-input-display {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: #7f95b2;
  font-size: 13px;
  line-height: 1;
  pointer-events: none;
}

.date-input-shell.has-value .date-input-display {
  color: #dce9f8;
}

body[data-page="tracking"] .date-input-shell input[type="date"],
body[data-page="selection"] .date-input-shell input[type="datetime-local"] {
  position: absolute;
  inset: 0;
  width: 100%;
  min-width: 0;
  min-height: 42px;
  padding: 0;
  border: 0;
  border-radius: 7px;
  background: transparent;
  color: transparent !important;
  color-scheme: dark;
  opacity: 0;
  cursor: pointer;
}

.date-input-shell::after {
  content: "";
  position: absolute;
  right: 12px;
  top: 50%;
  width: 14px;
  height: 14px;
  transform: translateY(-50%);
  pointer-events: none;
  opacity: 0.78;
  background: no-repeat center / contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' viewBox='0 0 16 16'%3E%3Cpath stroke='%2397abc5' stroke-linecap='round' stroke-linejoin='round' d='M4.5 2.5v2m7-2v2m-9 1.5h11m-10-3h9a1 1 0 0 1 1 1v8.5a1 1 0 0 1-1 1h-9a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1Z'/%3E%3C/svg%3E");
}

@media (max-width: 1480px) {
  .tracking-console-card .tracking-preview-grid,
  .sector-card .preview-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tracking-stat-strip {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 1180px) {
  .dashboard-hero,
  .selection-command-grid,
  .tracking-hero,
  .tracking-review-grid,
  .home-market-grid {
    grid-template-columns: 1fr;
  }

  .command-card {
    position: static;
  }

  .home-dashboard .hero-stats,
  .tracking-stat-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 760px) {
  .home-dashboard .hero-stats,
  .tracking-stat-strip,
  .tracking-console-card .tracking-preview-grid,
  .sector-card .preview-list,
  .selection-results-console .card-header.with-actions,
  .tracking-table-console .card-header {
    grid-template-columns: 1fr !important;
  }
}

/* Structure rollout phase 2: secondary pages */
.backtest-control-grid {
  display: grid;
  grid-template-columns: minmax(320px, 0.42fr) minmax(0, 1fr);
  gap: 22px;
}

.factor-status-card .status-panel,
.backtest-runs-console .list-stack {
  min-height: 260px;
}

.backtest-detail-console .content-grid.two-columns.top-align {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.strategies-dashboard .stat-grid.compact-stats {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.strategies-list-console .strategy-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.strategy-detail-console,
.factor-analysis-console,
.strategies-list-console {
  margin-top: 0;
}

.system-status-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
  margin-bottom: 22px;
}

.system-status-grid .card {
  min-height: 260px;
}

.hidden-diagnostics-grid {
  opacity: 0.82;
}

@media (max-width: 1180px) {
  .backtest-control-grid,
  .backtest-detail-console .content-grid.two-columns.top-align,
  .strategies-list-console .strategy-grid,
  .system-status-grid {
    grid-template-columns: 1fr;
  }
}

/* Remaining pages structure refinement */

.portfolio-dashboard {
  gap: 18px;
}

.portfolio-stat-strip {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.portfolio-layout-grid {
  display: grid;
  grid-template-columns: minmax(360px, 0.9fr) minmax(520px, 1.3fr);
  gap: 18px;
  align-items: stretch;
}

.portfolio-form {
  display: grid;
  gap: 16px;
}

.portfolio-form .form-grid.two-col {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.portfolio-form textarea {
  resize: vertical;
}

.portfolio-form-message {
  min-height: 20px;
}

.portfolio-detail-card {
  min-height: 460px;
}

.portfolio-action-badge,
.portfolio-plan-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 5px 10px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 13px;
  color: var(--text);
  border: 1px solid rgba(148, 163, 184, .24);
  background: rgba(100, 116, 139, .16);
  white-space: nowrap;
}

.portfolio-action-badge.success,
.portfolio-plan-badge.success {
  color: #86efac;
  border-color: rgba(34, 197, 94, .38);
  background: rgba(22, 101, 52, .25);
}

.portfolio-action-badge.danger,
.portfolio-plan-badge.danger {
  color: #fca5a5;
  border-color: rgba(239, 68, 68, .38);
  background: rgba(127, 29, 29, .25);
}

.portfolio-action-badge.warn,
.portfolio-plan-badge.warn {
  color: #facc15;
  border-color: rgba(234, 179, 8, .38);
  background: rgba(113, 63, 18, .25);
}

.portfolio-action-badge.info,
.portfolio-plan-badge.info {
  color: #67e8f9;
  border-color: rgba(6, 182, 212, .38);
  background: rgba(21, 94, 117, .25);
}

.portfolio-detail {
  display: grid;
  gap: 16px;
}

.portfolio-detail-grid,
.portfolio-plan-grid,
.portfolio-indicator-grid {
  display: grid;
  gap: 12px;
}

.portfolio-detail-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.portfolio-plan-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.portfolio-indicator-grid {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.portfolio-detail-grid > div,
.portfolio-plan-grid > article,
.portfolio-indicator-grid > div {
  border: 1px solid rgba(30, 41, 59, .9);
  border-radius: 12px;
  background: rgba(15, 23, 42, .58);
  padding: 12px;
  min-width: 0;
}

.portfolio-detail-grid span,
.portfolio-plan-grid span,
.portfolio-indicator-grid span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  margin-bottom: 7px;
}

.portfolio-detail-grid strong,
.portfolio-plan-grid strong,
.portfolio-indicator-grid b {
  display: block;
  font-size: 18px;
  white-space: nowrap;
}

.portfolio-plan-grid small {
  display: block;
  color: var(--muted);
  margin-top: 6px;
  line-height: 1.4;
}

.portfolio-advice-block {
  border: 1px solid rgba(30, 41, 59, .9);
  border-radius: 14px;
  background: rgba(15, 23, 42, .42);
  padding: 14px 16px;
}

.portfolio-advice-block h3 {
  margin: 0 0 8px;
  font-size: 15px;
}

.portfolio-advice-block ul {
  margin: 0 0 12px;
  padding-left: 18px;
  color: var(--muted);
  line-height: 1.7;
}

.portfolio-advice-block ul:last-child {
  margin-bottom: 0;
}

.portfolio-outcome-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  align-items: center;
  margin: 8px 0 10px;
  color: var(--muted);
  font-size: 13px;
}

.portfolio-outcome-summary strong {
  color: var(--text);
}

.compact-table table {
  min-width: 680px;
}

.compact-table th,
.compact-table td {
  padding: 8px 10px;
  font-size: 12px;
}

.portfolio-discipline-block {
  border: 1px solid rgba(51, 65, 85, .8);
  border-radius: 14px;
  background: rgba(15, 23, 42, .42);
  padding: 14px 16px;
}

.portfolio-discipline-block.danger {
  border-color: rgba(239, 68, 68, .45);
  background: rgba(127, 29, 29, .18);
}

.portfolio-discipline-block.warn {
  border-color: rgba(234, 179, 8, .38);
  background: rgba(113, 63, 18, .14);
}

.portfolio-discipline-block h3 {
  margin: 0 0 10px;
  font-size: 15px;
}

.portfolio-alert-list {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.portfolio-alert-list li {
  border: 1px solid rgba(51, 65, 85, .72);
  border-radius: 12px;
  padding: 10px 12px;
  background: rgba(15, 23, 42, .58);
}

.portfolio-alert-list li.danger {
  border-color: rgba(239, 68, 68, .42);
}

.portfolio-alert-list li.warn {
  border-color: rgba(234, 179, 8, .36);
}

.portfolio-alert-list li.info {
  border-color: rgba(6, 182, 212, .32);
}

.portfolio-alert-list span {
  display: inline-flex;
  margin-bottom: 6px;
  color: var(--muted);
  font-size: 12px;
}

.portfolio-alert-list strong {
  display: block;
  color: var(--text);
  font-size: 14px;
}

.portfolio-alert-list p {
  margin: 5px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.55;
}

.portfolio-row-alert {
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.35;
  white-space: normal;
}

.portfolio-row-alert.danger {
  color: #fca5a5;
}

.portfolio-row-alert.warn {
  color: #facc15;
}

.portfolio-row-alert.info {
  color: #67e8f9;
}

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

.portfolio-advice-actions span {
  color: var(--muted);
  font-size: 12px;
}

.portfolio-advice-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
}

.portfolio-advice-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(2, 6, 23, .72);
  backdrop-filter: blur(8px);
}

.portfolio-advice-panel {
  position: relative;
  width: min(920px, calc(100vw - 32px));
  max-height: calc(100vh - 48px);
  margin: 24px auto;
  overflow: auto;
  border: 1px solid rgba(51, 65, 85, .95);
  border-radius: 18px;
  background: rgba(15, 23, 42, .98);
  box-shadow: 0 24px 80px rgba(0, 0, 0, .42);
  padding: 20px;
}

.portfolio-advice-panel header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}

.portfolio-advice-panel h2 {
  margin: 0 0 6px;
  font-size: 22px;
}

.portfolio-advice-panel article {
  border-top: 1px solid rgba(51, 65, 85, .72);
  padding-top: 14px;
  margin-top: 14px;
}

.portfolio-advice-panel h3 {
  margin: 0 0 8px;
  font-size: 15px;
}

.portfolio-advice-panel p,
.portfolio-advice-panel li {
  color: var(--muted);
  line-height: 1.7;
}

.portfolio-advice-panel ul {
  margin: 0 0 12px;
  padding-left: 18px;
}

.portfolio-advice-modal-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.portfolio-advice-modal-grid > div {
  border: 1px solid rgba(30, 41, 59, .9);
  border-radius: 12px;
  background: rgba(15, 23, 42, .58);
  padding: 12px;
  min-width: 0;
}

.portfolio-advice-modal-grid span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  margin-bottom: 7px;
}

.portfolio-advice-modal-grid strong {
  display: block;
  font-size: 16px;
  white-space: nowrap;
}

.portfolio-row {
  cursor: pointer;
}

.portfolio-row.selected-row {
  background: rgba(14, 165, 233, .08);
}

@media (max-width: 1180px) {
  .portfolio-stat-strip,
  .portfolio-detail-grid,
  .portfolio-plan-grid,
  .portfolio-indicator-grid,
  .portfolio-advice-modal-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

@media (max-width: 720px) {
  .portfolio-stat-strip,
  .portfolio-form .form-grid.two-col,
  .portfolio-detail-grid,
  .portfolio-plan-grid,
  .portfolio-indicator-grid,
  .portfolio-advice-modal-grid {
    grid-template-columns: 1fr;
  }

  .portfolio-advice-panel {
    width: calc(100vw - 20px);
    max-height: calc(100vh - 20px);
    margin: 10px auto;
    padding: 14px;
  }

  .portfolio-advice-panel header {
    flex-direction: column;
  }
}
.stock-workbench-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 0.34fr);
  gap: 22px;
  align-items: start;
}

.stock-chart-column {
  display: flex;
  flex-direction: column;
  gap: 22px;
  min-width: 0;
}

.stock-workbench-side {
  display: grid;
  gap: 22px;
  position: sticky;
  top: 18px;
}

.stock-news-history-grid {
  grid-template-columns: minmax(0, 1.12fr) minmax(420px, 0.88fr);
  align-items: start;
}

.stock-news-history-grid .history-card {
  height: 100%;
}

.stock-detail-main .stock-chart-grid {
  margin-bottom: 0;
}

.stock-detail-main .stock-insight-grid {
  margin-bottom: 0;
}

.backtest-dashboard,
.strategies-dashboard,
.system-dashboard {
  gap: 22px;
}

.backtest-dashboard .backtest-runs-console,
.backtest-dashboard .backtest-detail-console,
.strategies-dashboard .strategies-list-console,
.strategies-dashboard .strategy-detail-console,
.strategies-dashboard .factor-analysis-console {
  margin-bottom: 0;
}

.system-dashboard .system-status-grid:last-of-type {
  margin-bottom: 0;
}

.system-dashboard .status-panel > *,
.backtest-dashboard .status-panel > * {
  border-left: 3px solid rgba(56, 189, 248, 0.36);
}

@media (max-width: 1320px) {
  .stock-workbench-grid,
  .stock-news-history-grid {
    grid-template-columns: 1fr;
  }

  .stock-workbench-side {
    position: static;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .stock-workbench-side,
  .stock-detail-main .stock-insight-grid {
    grid-template-columns: 1fr;
  }
}

/* Stock detail true terminal/workspace redesign */
.stock-terminal-main {
  padding: 22px 24px 34px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.stock-terminal-hero {
  display: grid;
  grid-template-columns: minmax(300px, 0.36fr) minmax(0, 1fr);
  gap: 18px;
  align-items: stretch;
  padding: 18px;
  border: 1px solid rgba(56, 189, 248, 0.22);
  border-radius: 22px;
  background:
    linear-gradient(120deg, rgba(14, 116, 144, 0.24), transparent 34%),
    linear-gradient(180deg, rgba(18, 34, 56, 0.95), rgba(8, 18, 32, 0.92));
  box-shadow: 0 20px 70px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.04);
}

.stock-title-block {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}

.stock-title-block h1 {
  margin: 4px 0 8px;
  font-size: clamp(32px, 3.6vw, 48px);
  line-height: 1.05;
  letter-spacing: -0.04em;
}

.stock-market-strip {
  display: grid;
  grid-template-columns: 1.15fr repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.stock-market-tile {
  position: relative;
  overflow: hidden;
  min-height: 116px;
  padding: 15px;
  border: 1px solid rgba(56, 189, 248, 0.18);
  border-radius: 16px;
  background:
    linear-gradient(150deg, rgba(14, 116, 144, 0.10), transparent 35%),
    rgba(8, 18, 32, 0.74);
}

.stock-market-tile::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, rgba(56,189,248,.85), rgba(37,99,235,.18), transparent);
}

.stock-market-tile span {
  display: block;
  color: #9fb4cf;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .04em;
}

.stock-market-tile strong {
  display: block;
  margin-top: 12px;
  color: #f8fafc;
  font-size: clamp(22px, 2.3vw, 34px);
  line-height: 1.05;
  letter-spacing: -0.04em;
  overflow: hidden;
  text-overflow: ellipsis;
}

.stock-market-tile.price-tile {
  border-color: rgba(248, 113, 113, 0.34);
  background:
    linear-gradient(140deg, rgba(248, 113, 113, 0.13), transparent 38%),
    rgba(8, 18, 32, 0.78);
}

.stock-terminal-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 0.31fr);
  gap: 18px;
  align-items: start;
}

.stock-primary-column {
  display: flex;
  flex-direction: column;
  gap: 18px;
  min-width: 0;
}

.stock-secondary-row,
.stock-factor-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(260px, 1fr));
  gap: 18px;
  align-items: stretch;
}

.stock-secondary-row {
  grid-template-columns: minmax(0, 1.08fr) minmax(360px, 0.92fr);
}

.stock-terminal-sidebar {
  position: sticky;
  top: 18px;
  display: grid;
  gap: 18px;
}

.stock-terminal-card-head {
  min-height: 42px;
}

.stock-chart-terminal,
.stock-signal-panel,
.stock-side-card,
.terminal-history-card {
  margin-bottom: 0 !important;
}

.terminal-chart-wrap {
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(4, 12, 24, 0.98), rgba(2, 8, 18, 0.96));
  border: 1px solid rgba(56, 189, 248, 0.16);
}

.terminal-chart {
  height: 300px;
}

.kline-terminal-chart .terminal-chart {
  height: 250px;
}

.signal-stack {
  display: grid;
  gap: 12px;
}

.signal-box {
  border: 1px solid rgba(33, 52, 79, 0.78);
  border-radius: 14px;
  padding: 12px;
  background: rgba(8, 18, 32, 0.5);
}

.signal-box h3 {
  margin: 0 0 10px;
  font-size: 14px;
  color: #cbd5e1;
}

.stock-terminal-main .detail-grid {
  grid-template-columns: minmax(96px, 0.72fr) minmax(0, 1fr);
  gap: 8px 12px;
  font-size: 13px;
}

.stock-terminal-main .detail-grid > div:nth-child(odd) {
  color: #8fa3bd;
}

.stock-terminal-main .detail-grid > div:nth-child(even) {
  color: #e5eefb;
  text-align: right;
  overflow-wrap: anywhere;
}

.terminal-news-list {
  max-height: 520px;
  overflow: auto;
  padding-right: 4px;
}

.terminal-news-list .preview-item {
  padding: 11px 12px;
  align-items: flex-start;
}

.terminal-news-list .news-title-row {
  display: grid;
  gap: 8px;
}

.terminal-news-list .news-title-row strong {
  font-size: 13px;
  line-height: 1.45;
}

.terminal-news-list .badge {
  width: fit-content;
}

.terminal-history-card .table-wrap {
  max-height: 320px;
  overflow: auto;
}

@media (max-width: 1380px) {
  .stock-terminal-hero,
  .stock-terminal-grid,
  .stock-secondary-row,
  .stock-factor-row {
    grid-template-columns: 1fr;
  }

  .stock-terminal-sidebar {
    position: static;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 920px) {
  .stock-market-strip,
  .stock-terminal-sidebar {
    grid-template-columns: 1fr;
  }

  .terminal-chart,
  .kline-terminal-chart .terminal-chart {
    height: 240px;
  }
}

/* Stock overview backend-powered top console */
.stock-overview-console {
  display: grid;
  grid-template-columns: minmax(360px, 1.35fr) minmax(150px, 0.38fr) minmax(360px, 1fr);
  gap: 12px;
  align-items: stretch;
}

.quote-console-main,
.overview-score-ring,
.overview-metric-grid article {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(56, 189, 248, 0.18);
  border-radius: 18px;
  background:
    linear-gradient(150deg, rgba(14, 116, 144, 0.10), transparent 35%),
    rgba(8, 18, 32, 0.76);
}

.quote-console-main {
  padding: 18px;
  border-color: rgba(248, 113, 113, 0.30);
}

.quote-price-line {
  display: flex;
  align-items: baseline;
  gap: 16px;
  margin-bottom: 14px;
}

.quote-price-line strong {
  color: #fb7185;
  font-size: clamp(38px, 4.6vw, 58px);
  line-height: 0.95;
  letter-spacing: -0.06em;
}

.quote-change {
  font-weight: 900;
  font-size: 15px;
}

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

.quote-sub-grid span {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(15, 23, 42, 0.58);
  color: #8fa3bd;
  font-size: 12px;
}

.quote-sub-grid b {
  color: #e5eefb;
  font-weight: 850;
  white-space: nowrap;
}

.overview-score-ring {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 166px;
  border-radius: 999px;
  aspect-ratio: 1 / 1;
  margin: auto;
  background:
    radial-gradient(circle at center, rgba(15, 23, 42, 0.94) 55%, transparent 57%),
    conic-gradient(from 180deg, rgba(34, 211, 238, .95), rgba(56, 189, 248, .4), rgba(30, 41, 59, .9));
}

.overview-score-ring span,
.overview-score-ring em {
  color: #8fa3bd;
  font-style: normal;
  font-size: 12px;
  font-weight: 800;
}

.overview-score-ring strong {
  color: #67e8f9;
  font-size: 40px;
  line-height: 1;
  letter-spacing: -0.04em;
  margin: 8px 0 6px;
}

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

.overview-metric-grid article {
  min-height: 78px;
  padding: 12px;
}

.overview-metric-grid span {
  display: block;
  color: #8fa3bd;
  font-size: 12px;
  font-weight: 800;
  margin-bottom: 10px;
}

.overview-metric-grid strong {
  display: block;
  color: #e5eefb;
  font-size: 17px;
  line-height: 1.1;
  overflow-wrap: anywhere;
}

.overview-metric-grid strong.up,
.quote-change.up {
  color: #fb7185;
}

.overview-metric-grid strong.down,
.quote-change.down {
  color: #34d399;
}

@media (max-width: 1480px) {
  .stock-overview-console {
    grid-template-columns: 1fr;
  }

  .overview-score-ring {
    width: 176px;
  }
}

@media (max-width: 760px) {
  .quote-sub-grid,
  .overview-metric-grid {
    grid-template-columns: 1fr;
  }
}

/* Stock detail top quote readability + full-session intraday polish */
.quote-console-main {
  padding: 20px 22px;
}

.quote-sub-grid {
  gap: 12px;
}

.quote-sub-grid span {
  min-height: 46px;
  align-items: center;
  padding: 11px 13px;
  font-size: 14px;
  font-weight: 750;
}

.quote-sub-grid b {
  font-size: 15px;
  font-weight: 950;
  letter-spacing: -0.01em;
}

.quote-price-line strong {
  font-size: clamp(44px, 5vw, 68px);
}

.quote-change {
  font-size: 18px;
}

.stock-overview-console {
  grid-template-columns: minmax(520px, 1.45fr) minmax(170px, 0.36fr) minmax(420px, 1fr);
}

.chart-session-gap {
  stroke: rgba(148, 163, 184, 0.18) !important;
  stroke-dasharray: 4 6;
}

.chart-zero-line {
  stroke: rgba(226, 232, 240, 0.62) !important;
  stroke-dasharray: 5 5;
}

.intraday-axis-label {
  fill: #9fb4cf;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: -0.01em;
}

.intraday-zero-label {
  fill: rgba(226, 232, 240, 0.72);
  font-weight: 800;
}

.intraday-time-label {
  font-size: 10.5px;
}

.intraday-terminal-chart::before {
  content: "09:30-15:00 全交易时段";
  position: absolute;
  right: 18px;
  bottom: 10px;
  color: rgba(148, 163, 184, 0.45);
  font-size: 11px;
  font-weight: 800;
  pointer-events: none;
}

@media (max-width: 1480px) {
  .stock-overview-console {
    grid-template-columns: 1fr;
  }
}

/* Strategy score factor breakdown in stock overview */
.overview-score-panel {
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 10px;
  min-width: 190px;
  align-content: start;
}

.overview-score-panel .overview-score-ring {
  width: 168px;
  min-height: 168px;
}

.overview-factor-pills {
  display: grid;
  gap: 7px;
}

.factor-score-pill {
  position: relative;
  overflow: hidden;
  padding: 8px 9px 7px;
  border: 1px solid rgba(56, 189, 248, 0.15);
  border-radius: 11px;
  background: rgba(8, 18, 32, 0.72);
}

.factor-score-row {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: center;
  margin-bottom: 6px;
}

.factor-score-row span {
  color: #9fb4cf;
  font-size: 12px;
  font-weight: 850;
}

.factor-score-row strong {
  color: #e5eefb;
  font-size: 14px;
  font-weight: 950;
}

.factor-score-pill i {
  display: block;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, #38bdf8, #67e8f9);
  box-shadow: 0 0 14px rgba(56, 189, 248, 0.28);
}

.factor-score-pill.strong i {
  background: linear-gradient(90deg, #fb7185, #fca5a5);
}

.factor-score-pill.weak i {
  background: linear-gradient(90deg, #22c55e, #86efac);
}

@media (max-width: 1480px) {
  .overview-score-panel {
    grid-template-columns: 190px minmax(0, 1fr);
    grid-template-rows: auto;
    align-items: center;
  }

  .overview-factor-pills {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .overview-score-panel,
  .overview-factor-pills {
    grid-template-columns: 1fr;
  }
}

/* Move factor breakdown to the right side of strategy score */
.stock-overview-console {
  grid-template-columns: minmax(500px, 1.22fr) minmax(470px, 0.92fr) minmax(420px, 0.86fr);
}

.overview-score-panel {
  grid-template-columns: 154px minmax(0, 1fr);
  grid-template-rows: auto;
  align-items: center;
  min-width: 470px;
  overflow: hidden;
}

.strategy-factor-caption {
  grid-column: 2;
  align-self: end;
  margin-bottom: -4px;
  color: #67e8f9;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.overview-factor-pills {
  grid-column: 2;
  align-self: stretch;
  align-content: center;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  max-height: none;
  overflow: visible;
  padding-right: 0;
}

.factor-score-pill {
  min-width: 0;
  padding: 8px 10px 7px;
}

@media (max-width: 1480px) {
  .stock-overview-console {
    grid-template-columns: 1fr;
  }

  .overview-score-panel {
    grid-template-columns: 190px minmax(0, 1fr);
    min-width: 0;
  }

  .strategy-factor-caption,
  .overview-factor-pills {
    grid-column: 2;
  }

  .overview-factor-pills {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    max-height: none;
    overflow: visible;
  }
}

@media (max-width: 760px) {
  .overview-score-panel,
  .overview-factor-pills {
    grid-template-columns: 1fr;
  }

  .strategy-factor-caption,
  .overview-factor-pills {
    grid-column: 1;
  }
}

/* Compact stock overview quote row: prevent vertical label wrapping */
.quote-console-main {
  padding: 18px 20px;
}

.quote-price-line {
  margin-bottom: 12px;
}

.quote-price-line strong {
  font-size: clamp(40px, 4.3vw, 62px);
}

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

.quote-sub-grid span {
  min-height: 38px;
  padding: 8px 10px;
  font-size: 13px;
  white-space: nowrap;
}

.quote-sub-grid span:nth-child(6) {
  grid-column: 1 / -1;
}

.quote-sub-grid span:nth-child(6) b {
  overflow: visible;
  text-overflow: clip;
}

.quote-sub-grid b {
  font-size: 14px;
}

.overview-score-panel .overview-score-ring {
  width: 154px;
  min-height: 154px;
  grid-row: 1 / 3;
}

.overview-score-ring strong {
  font-size: 36px;
}

.overview-metric-grid article {
  min-height: 66px;
  padding: 10px 12px;
}

.overview-metric-grid span {
  margin-bottom: 8px;
}

.factor-score-pill {
  padding: 8px 10px 7px;
}

.factor-score-row {
  margin-bottom: 5px;
}

.factor-score-row span,
.factor-score-row strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 1180px) {
  .quote-sub-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .quote-sub-grid span {
    white-space: normal;
  }
}

/* Selection center productized result console */
body[data-page="selection"] .selection-command-grid {
  grid-template-columns: minmax(300px, 0.34fr) minmax(0, 1fr);
}

body[data-page="selection"] .command-card {
  border-color: rgba(248, 113, 113, 0.28);
  background:
    linear-gradient(150deg, rgba(248, 113, 113, 0.10), transparent 34%),
    linear-gradient(180deg, rgba(18, 34, 56, 0.97), rgba(8, 18, 32, 0.96));
}

body[data-page="selection"] .strategy-console-card {
  min-height: 100%;
}

.selection-result-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin: 0 0 18px;
}

.selection-result-cards.empty-state {
  display: block;
  padding: 18px;
  border: 1px dashed rgba(56, 189, 248, 0.22);
  border-radius: 16px;
  background: rgba(8, 18, 32, 0.48);
}

.selection-stock-card {
  position: relative;
  overflow: hidden;
  min-height: 218px;
  padding: 16px;
  border: 1px solid rgba(56, 189, 248, 0.22);
  border-radius: 18px;
  background:
    radial-gradient(circle at 18% 0%, rgba(56, 189, 248, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(15, 32, 54, 0.96), rgba(8, 18, 32, 0.94));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}

.selection-stock-card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, #38bdf8, rgba(37,99,235,.25), transparent);
}

.selection-stock-head,
.selection-stock-score-row,
.selection-stock-meta,
.selection-stock-prices {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.selection-stock-head a {
  display: block;
  color: #e5f3ff;
  font-size: 18px;
  font-weight: 900;
}

.selection-stock-head span,
.selection-stock-meta,
.selection-stock-prices,
.selection-card-note,
.selection-card-risk,
.selection-factor-mini {
  color: #9fb4cf;
  font-size: 12px;
}

.selection-stock-head em {
  color: #67e8f9;
  font-style: normal;
  font-size: 22px;
  font-weight: 950;
}

.selection-stock-score-row {
  margin: 14px 0 10px;
}

.selection-stock-score-row strong {
  color: #f8fafc;
  font-size: 38px;
  line-height: 1;
  letter-spacing: -0.06em;
}

.selection-stock-score-row span {
  font-size: 16px;
  font-weight: 900;
}

.selection-stock-meta,
.selection-stock-prices {
  padding: 9px 0;
  border-top: 1px solid rgba(56, 189, 248, 0.12);
}

.selection-factor-mini {
  margin-top: 10px;
  padding: 9px 10px;
  border-radius: 11px;
  background: rgba(15, 23, 42, 0.62);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.selection-card-note,
.selection-card-risk {
  margin-top: 8px;
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.selection-card-risk {
  color: #fbbf24;
}

.trade-plan-block {
  margin: 8px 0;
  padding: 8px 10px;
  border: 1px solid rgba(80, 227, 194, 0.28);
  border-radius: 6px;
  background: rgba(80, 227, 194, 0.07);
  color: var(--text-primary);
}

.selection-detail-table {
  max-height: 420px !important;
}

.selection-filter-form {
  margin: 4px 0 16px;
  padding: 12px;
  border: 1px solid rgba(56, 189, 248, 0.14);
  border-radius: 16px;
  background: rgba(8, 18, 32, 0.48);
}

@media (max-width: 1380px) {
  .selection-result-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
  .selection-result-cards,
  body[data-page="selection"] .selection-command-grid {
    grid-template-columns: 1fr;
  }
}

/* Tracking review card console: desktop uses table, mobile uses cards */
.tracking-record-cards {
  display: none;
}

.tracking-record-cards.empty-state {
  display: none;
  padding: 18px;
  border: 1px dashed rgba(56, 189, 248, 0.22);
  border-radius: 16px;
  background: rgba(8, 18, 32, 0.48);
}

.tracking-record-card {
  min-height: 176px;
  padding: 15px;
  border: 1px solid rgba(56, 189, 248, 0.20);
  border-radius: 18px;
  background:
    linear-gradient(150deg, rgba(14, 116, 144, 0.10), transparent 34%),
    linear-gradient(180deg, rgba(15, 32, 54, 0.96), rgba(8, 18, 32, 0.94));
}

.tracking-record-head,
.tracking-record-foot {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.tracking-record-head a {
  display: block;
  color: #e5f3ff;
  font-size: 16px;
  font-weight: 900;
}

.tracking-record-head span,
.tracking-record-foot span:first-child {
  color: #9fb4cf;
  font-size: 12px;
}

.tracking-record-head em {
  font-style: normal;
  font-size: 22px;
  font-weight: 950;
  white-space: nowrap;
}

.tracking-record-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 14px 0;
}

.tracking-record-grid span {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 7px 8px;
  border-radius: 10px;
  background: rgba(15, 23, 42, 0.58);
  color: #8fa3bd;
  font-size: 12px;
}

.tracking-record-grid b {
  color: #e5eefb;
  font-weight: 900;
}

.tracking-detail-table {
  max-height: 440px !important;
}

body[data-page="tracking"] .tracking-detail-table thead th {
  position: sticky;
  top: 0;
  z-index: 3;
  background: #071529;
  box-shadow: 0 1px 0 var(--table-line), 0 10px 18px rgba(2, 8, 23, 0.38);
}

body[data-page="tracking"] .tracking-detail-table thead th:first-child {
  border-top-left-radius: 12px;
}

body[data-page="tracking"] .tracking-detail-table thead th:last-child {
  border-top-right-radius: 12px;
}

@media (max-width: 820px) {
  .tracking-detail-table {
    max-height: none !important;
  }
}

/* Selection command center: run + strategy + latest status */
body[data-page="selection"] .selection-command-grid {
  grid-template-columns: minmax(300px, 0.34fr) minmax(360px, 0.43fr) minmax(330px, 0.33fr);
  align-items: stretch;
}

.selection-strategy-panel,
.selection-run-status-card,
.command-card {
  min-height: 335px;
}

.selection-strategy-panel #strategy-summary .strategy-item {
  padding-bottom: 12px;
}

.selection-factor-bars {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.selection-factor-bars.empty-state {
  padding: 14px;
  border: 1px dashed rgba(56, 189, 248, 0.18);
  border-radius: 14px;
  background: rgba(8, 18, 32, 0.42);
}

.selection-factor-bar div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 6px;
  color: #9fb4cf;
  font-size: 13px;
  font-weight: 850;
}

.selection-factor-bar b {
  color: #e5eefb;
}

.selection-factor-bar i {
  display: block;
  height: 7px;
  border-radius: 999px;
  background: linear-gradient(90deg, #2563eb, #38bdf8);
  box-shadow: 0 0 14px rgba(56, 189, 248, 0.28);
}

.selection-run-status-card {
  border-color: rgba(34, 197, 94, 0.24) !important;
}

.selection-run-status-grid {
  display: grid;
  grid-template-columns: 132px minmax(0, 1fr);
  gap: 18px;
  align-items: center;
}

.selection-success-ring {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 124px;
  height: 124px;
  border-radius: 999px;
  background:
    radial-gradient(circle at center, rgba(15, 23, 42, .96) 56%, transparent 58%),
    conic-gradient(from 180deg, #22c55e, #38bdf8, rgba(30, 41, 59, .95));
}

.selection-success-ring strong {
  color: #f8fafc;
  font-size: 30px;
  line-height: 1;
}

.selection-success-ring span {
  margin-top: 7px;
  color: #9fb4cf;
  font-size: 12px;
  font-weight: 850;
}

.selection-run-metrics {
  display: grid;
  gap: 9px;
}

.selection-run-metrics div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 10px;
  border-radius: 11px;
  background: rgba(15, 23, 42, 0.56);
}

.selection-run-metrics span {
  color: #8fa3bd;
  font-size: 12px;
  font-weight: 800;
}

.selection-run-metrics b {
  color: #e5eefb;
  font-size: 13px;
  text-align: right;
}

.selection-history-mini {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid rgba(56, 189, 248, 0.14);
}

.selection-history-mini svg {
  display: block;
  width: 100%;
  height: 88px;
  margin-top: 8px;
}

@media (max-width: 1520px) {
  body[data-page="selection"] .selection-command-grid {
    grid-template-columns: minmax(300px, 0.42fr) minmax(0, 1fr);
  }

  .selection-run-status-card {
    grid-column: 1 / -1;
  }
}

@media (max-width: 900px) {
  body[data-page="selection"] .selection-command-grid,
  .selection-run-status-grid {
    grid-template-columns: 1fr;
  }
}

/* Selection run panel terminal styling */
.selection-run-panel {
  padding: 18px !important;
  border-color: rgba(14, 165, 233, 0.42) !important;
  box-shadow:
    0 0 0 1px rgba(14, 165, 233, 0.10),
    0 18px 50px rgba(2, 8, 23, 0.36),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.selection-run-panel .card-header,
.selection-run-panel .card-header::before {
  display: none;
}

.selection-run-title {
  display: flex;
  align-items: center;
  gap: 9px;
  margin-bottom: 18px;
}

.selection-run-title h2 {
  margin: 0;
  color: #e5f3ff;
  font-size: 18px;
}

.run-title-icon {
  display: grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 7px;
  color: #7dd3fc;
  font-size: 10px;
  background: linear-gradient(180deg, rgba(14, 165, 233, .40), rgba(37, 99, 235, .18));
  box-shadow: 0 0 16px rgba(14, 165, 233, .36);
}

.selection-terminal-form {
  display: grid;
  gap: 17px;
}

.terminal-form-row {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 13px;
  align-items: center;
}

.terminal-form-row > label,
.score-row-head label {
  color: #9fb4cf;
  font-size: 13px;
  font-weight: 850;
}

.selection-terminal-form select,
.selection-terminal-form input[type="number"],
.input-with-unit,
.time-display {
  min-height: 40px;
  border: 1px solid rgba(56, 189, 248, 0.22);
  border-radius: 8px;
  background: rgba(4, 14, 28, 0.72);
  color: #dbeafe;
}

.selection-terminal-form select,
.selection-terminal-form input[type="number"] {
  width: 100%;
  padding: 0 12px;
}

.visually-hidden-select {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 1px !important;
  height: 1px !important;
}

.instrument-segments {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  min-height: 40px;
  border: 1px solid rgba(56, 189, 248, 0.20);
  border-radius: 8px;
  overflow: hidden;
  background: rgba(4, 14, 28, 0.72);
}

.board-segments {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.instrument-segments button {
  border: 0;
  border-right: 1px solid rgba(56, 189, 248, 0.14);
  background: transparent;
  color: #8fa3bd;
  font-size: 12px;
  font-weight: 850;
  cursor: pointer;
}

.instrument-segments button:last-child {
  border-right: 0;
}

.instrument-segments button.active {
  color: #e0f2fe;
  background: linear-gradient(180deg, rgba(14, 165, 233, 0.30), rgba(37, 99, 235, 0.20));
  box-shadow: inset 0 0 0 1px rgba(56, 189, 248, 0.40);
}

.input-with-unit {
  display: flex;
  align-items: center;
}

.input-with-unit input {
  border: 0 !important;
  background: transparent !important;
  min-height: 38px !important;
}

.input-with-unit span {
  padding-right: 12px;
  color: #9fb4cf;
  font-size: 13px;
  font-weight: 850;
}

.score-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 9px;
}

.score-row-head {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr) 56px;
  gap: 13px;
  align-items: center;
}

.score-row-head input[type="number"] {
  grid-column: 3;
  text-align: center;
}

.score-range {
  width: 100%;
  accent-color: #38bdf8;
}

.score-scale {
  display: flex;
  justify-content: space-between;
  color: #64748b;
  font-size: 12px;
  padding: 0 2px;
}

.time-display {
  display: flex;
  align-items: center;
  padding: 0 12px;
  color: #cbd5e1;
  font-size: 13px;
}

.terminal-actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 118px;
  gap: 10px;
  margin-top: 3px;
}

.run-main-btn {
  min-height: 48px;
  font-size: 15px;
  box-shadow: 0 12px 28px rgba(14, 165, 233, .28);
}

@media (max-width: 760px) {
  .terminal-form-row,
  .score-row-head,
  .terminal-actions {
    grid-template-columns: 1fr;
  }

  .score-row-head input[type="number"] {
    grid-column: auto;
  }
}

/* Nudge selection run action area downward */
.selection-run-panel .terminal-actions {
  margin-top: 28px;
}

.selection-run-panel .time-row {
  margin-bottom: 2px;
}

/* Equalize selection command top three cards by tallest strategy panel */
body[data-page="selection"] .selection-command-grid {
  align-items: stretch;
}

body[data-page="selection"] .selection-command-grid > .card {
  height: 100%;
  min-height: 0;
  align-self: stretch;
}

body[data-page="selection"] .command-card,
body[data-page="selection"] .selection-run-panel {
  position: relative;
  top: auto;
  display: flex;
  flex-direction: column;
}

body[data-page="selection"] .selection-terminal-form {
  flex: 1;
}

body[data-page="selection"] .selection-run-status-card {
  display: flex;
  flex-direction: column;
}

body[data-page="selection"] .selection-history-mini {
  margin-top: auto;
}

/* Move selection score distribution upward inside latest-run card */
body[data-page="selection"] .selection-run-status-card .selection-history-mini {
  margin-top: 22px;
}

body[data-page="selection"] .selection-run-status-card {
  justify-content: flex-start;
}

body[data-page="selection"] .selection-history-mini svg {
  height: 116px;
}

/* Backtest and strategies product cards */
.backtest-runs-console #backtest-runs-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.backtest-run-card {
  padding: 15px;
  border: 1px solid rgba(56, 189, 248, 0.20);
  border-radius: 18px;
  background:
    linear-gradient(150deg, rgba(14, 116, 144, 0.10), transparent 34%),
    linear-gradient(180deg, rgba(15, 32, 54, 0.96), rgba(8, 18, 32, 0.94));
}

.backtest-run-head,
.backtest-run-foot {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.backtest-run-head strong {
  display: block;
  color: #e5f3ff;
  font-size: 17px;
}

.backtest-run-head span,
.backtest-run-foot .muted {
  color: #9fb4cf;
  font-size: 12px;
}

.backtest-progress-track {
  height: 8px;
  margin: 14px 0;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.82);
}

.backtest-progress-track i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #2563eb, #38bdf8, #67e8f9);
  box-shadow: 0 0 16px rgba(56, 189, 248, 0.32);
}

.backtest-run-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 14px;
}

.backtest-run-metrics span {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 8px;
  border-radius: 10px;
  background: rgba(15, 23, 42, 0.58);
  color: #8fa3bd;
  font-size: 12px;
}

.backtest-run-metrics b {
  color: #e5eefb;
}

.strategy-factor-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin: 14px 0 18px;
}

.strategy-factor-cards.empty-state {
  display: block;
  padding: 16px;
  border: 1px dashed rgba(56, 189, 248, 0.20);
  border-radius: 16px;
}

.strategy-factor-card {
  padding: 15px;
  border: 1px solid rgba(56, 189, 248, 0.20);
  border-radius: 18px;
  background: rgba(8, 18, 32, 0.66);
}

.strategy-factor-card.strong {
  border-color: rgba(248, 113, 113, 0.30);
}

.strategy-factor-card.weak {
  border-color: rgba(34, 197, 94, 0.30);
}

.factor-card-head,
.factor-card-metrics {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.factor-card-head strong {
  color: #e5f3ff;
  font-size: 16px;
}

.factor-card-meta {
  margin: 8px 0 12px;
  color: #9fb4cf;
  font-size: 12px;
}

.factor-card-metrics span {
  display: grid;
  gap: 3px;
  color: #8fa3bd;
  font-size: 12px;
}

.factor-card-metrics b {
  color: #e5eefb;
}

.strategy-factor-card p {
  margin: 12px 0 0;
  color: #9fb4cf;
  font-size: 12px;
  line-height: 1.5;
}

.strategy-factor-table {
  max-height: 380px;
  overflow: auto;
}

@media (max-width: 1280px) {
  .backtest-runs-console #backtest-runs-list,
  .strategy-factor-cards {
    grid-template-columns: 1fr;
  }
}

/* System status monitoring console polish */
body[data-page="system"] .system-status-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: stretch;
}

body[data-page="system"] .system-status-grid > .card {
  min-height: 260px;
}

body[data-page="system"] .status-panel {
  display: grid;
  gap: 10px;
}

body[data-page="system"] .status-panel > div:not(.empty-state):not(.error-box),
body[data-page="system"] .task-run-item {
  padding: 11px 12px;
  border: 1px solid rgba(56, 189, 248, 0.14);
  border-radius: 13px;
  background: rgba(8, 18, 32, 0.48);
}

body[data-page="system"] .task-run-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(140px, 0.26fr);
  gap: 12px;
}

body[data-page="system"] .task-run-side {
  text-align: right;
}

body[data-page="system"] .task-run-side strong {
  display: block;
  color: #e5f3ff;
}

body[data-page="system"] .hidden-diagnostics-grid {
  opacity: .72;
}

@media (max-width: 1100px) {
  body[data-page="system"] .system-status-grid,
  body[data-page="system"] .task-run-item {
    grid-template-columns: 1fr;
  }

  body[data-page="system"] .task-run-side {
    text-align: left;
  }
}

/* Backtest center layout aligned to financial terminal reference */
.backtest-terminal-control {
  padding: 18px 20px !important;
  border-color: rgba(14, 165, 233, 0.48) !important;
  background:
    linear-gradient(120deg, rgba(14, 165, 233, 0.18), transparent 45%),
    linear-gradient(180deg, rgba(15, 32, 54, .98), rgba(8, 18, 32, .96)) !important;
}

.backtest-terminal-form {
  display: grid;
  grid-template-columns: minmax(210px, 1.2fr) repeat(2, minmax(160px, .8fr)) minmax(110px, .46fr) minmax(110px, .46fr) minmax(130px, .55fr) 150px;
  gap: 16px;
  align-items: end;
}

.terminal-form-field {
  display: grid;
  gap: 7px;
}

.terminal-form-field label {
  color: #9fb4cf;
  font-size: 12px;
  font-weight: 850;
}

.backtest-terminal-form select,
.backtest-terminal-form input,
.backtest-terminal-form .input-with-unit {
  min-height: 42px;
  border: 1px solid rgba(56, 189, 248, 0.24);
  border-radius: 8px;
  background: rgba(4, 14, 28, 0.72);
  color: #dbeafe;
}

.backtest-terminal-form select,
.backtest-terminal-form input {
  width: 100%;
  padding: 0 12px;
}

body[data-page="backtest"] .backtest-terminal-form input[type="date"] {
  color-scheme: dark;
}

body[data-page="backtest"] .backtest-terminal-form input[type="date"]::-webkit-calendar-picker-indicator {
  opacity: 0.96;
  filter: invert(1) brightness(1.8);
  cursor: pointer;
}

.backtest-run-button {
  min-height: 46px;
  box-shadow: 0 14px 32px rgba(14, 165, 233, .32);
}

.backtest-advanced-settings {
  grid-column: 1 / -1;
  border-top: 1px solid rgba(56, 189, 248, 0.18);
  padding-top: 10px;
}

.backtest-advanced-settings summary {
  width: fit-content;
  cursor: pointer;
  color: #9fb4cf;
  font-size: 12px;
  font-weight: 850;
  user-select: none;
}

.backtest-advanced-settings summary:hover {
  color: #dbeafe;
}

.backtest-advanced-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: minmax(210px, 0.9fr) minmax(250px, 1.15fr) minmax(250px, 1.15fr) repeat(3, minmax(150px, 1fr));
  gap: 12px;
  align-items: stretch;
}

.backtest-preset-button {
  min-height: 100%;
  white-space: normal;
  line-height: 1.35;
}

.backtest-execution-summary {
  margin: 14px 0;
}

.backtest-execution-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 8px 0 10px;
}

.backtest-adjusted-toggle {
  align-items: flex-start;
  border: 1px solid rgba(56, 189, 248, 0.20);
  border-radius: 10px;
  padding: 12px;
  background: rgba(4, 14, 28, 0.48);
}

.backtest-adjusted-toggle.wide {
  grid-column: auto;
}

.backtest-adjusted-toggle b,
.backtest-adjusted-toggle small {
  display: block;
}

.backtest-adjusted-toggle small {
  margin-top: 3px;
  color: #9fb4cf;
  line-height: 1.45;
}

.backtest-terminal-foot {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-top: 12px;
}

.backtest-workbench-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(360px, .55fr);
  gap: 18px;
}

.backtest-runs-console #backtest-runs-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.backtest-detail-console .stat-grid.compact-stats {
  grid-template-columns: repeat(7, minmax(0, 1fr));
}

.backtest-analysis-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(360px, .65fr);
  gap: 18px;
  margin-top: 18px;
}

.backtest-equity-card,
.backtest-recent-card,
.backtest-trades-console {
  padding: 0;
}

.backtest-equity-chart-wrap {
  min-height: 300px;
  border: 1px solid rgba(56, 189, 248, 0.16);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(4, 12, 24, .96), rgba(2, 8, 18, .94));
  overflow: hidden;
}

.backtest-equity-chart-wrap svg {
  width: 100%;
  height: 300px;
  display: block;
}

.compact-table-wrapper {
  max-height: 300px;
  overflow: auto;
}

.backtest-trades-console {
  margin-top: 18px;
}

.backtest-trades-console .table-wrapper {
  max-height: 430px;
  overflow: auto;
}

@media (max-width: 1500px) {
  .backtest-terminal-form,
  .backtest-workbench-grid,
  .backtest-analysis-grid {
    grid-template-columns: 1fr 1fr;
  }

  .backtest-run-button,
  .return-field,
  .backtest-runs-console,
  .backtest-detail-console,
  .backtest-trades-console {
    grid-column: 1 / -1;
  }

  .backtest-detail-console .stat-grid.compact-stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .backtest-terminal-form,
  .backtest-workbench-grid,
  .backtest-analysis-grid,
  .backtest-runs-console #backtest-runs-list {
    grid-template-columns: 1fr;
  }
}

/* Backtest metric cards should be visible as dashboard layer */
.backtest-detail-console {
  display: block;
}

.backtest-detail-console[style*="display: none"] {
  opacity: .72;
}

.backtest-detail-console .stat-grid.compact-stats {
  margin-bottom: 18px;
}

.backtest-detail-console .stat-card {
  min-height: 118px;
  border-color: rgba(56, 189, 248, 0.24);
}

body[data-page="backtest"] .stat-card .stat-value span.up,
body[data-page="backtest"] .stat-value.up {
  color: #fb7185;
}

body[data-page="backtest"] .stat-card .stat-value span.down,
body[data-page="backtest"] .stat-value.down {
  color: #34d399;
}

/* Backtest red-box completion: active cards, metrics layer, recent runs */
body[data-page="backtest"] .backtest-detail-console {
  display: block !important;
}

body[data-page="backtest"] .backtest-runs-console #backtest-runs-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body[data-page="backtest"] .backtest-run-card {
  min-height: 128px;
  border-color: rgba(56, 189, 248, 0.30);
}

body[data-page="backtest"] .backtest-run-card.running,
body[data-page="backtest"] .backtest-run-card.queued {
  border-color: rgba(251, 191, 36, 0.42);
  background:
    linear-gradient(135deg, rgba(251, 191, 36, 0.10), transparent 38%),
    linear-gradient(180deg, rgba(15, 32, 54, 0.96), rgba(8, 18, 32, 0.94));
}

body[data-page="backtest"] .backtest-run-card.success {
  border-color: rgba(34, 197, 94, 0.30);
}

body[data-page="backtest"] .backtest-detail-console > .card-header {
  margin-bottom: 14px;
}

body[data-page="backtest"] .backtest-detail-console .stat-grid.compact-stats {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 12px;
}

body[data-page="backtest"] .backtest-detail-console .stat-card {
  min-height: 104px;
  padding: 14px;
}

body[data-page="backtest"] .backtest-detail-console .stat-value {
  font-size: clamp(21px, 1.8vw, 30px);
}

.backtest-recent-runs-panel {
  display: grid;
  gap: 8px;
  margin-bottom: 16px;
}

.backtest-recent-runs-panel.empty-state {
  padding: 14px;
  border: 1px dashed rgba(56, 189, 248, 0.18);
  border-radius: 14px;
}

.recent-backtest-row {
  display: grid;
  grid-template-columns: minmax(96px, 1fr) minmax(106px, 0.9fr) minmax(120px, 1.1fr) 76px 72px;
  gap: 8px;
  align-items: center;
  width: 100%;
  min-height: 38px;
  padding: 8px 10px;
  border: 1px solid rgba(56, 189, 248, 0.14);
  border-radius: 10px;
  background: rgba(8, 18, 32, 0.50);
  color: #9fb4cf;
  text-align: left;
  cursor: pointer;
}

.recent-backtest-row:disabled {
  cursor: default;
  opacity: .68;
}

.recent-backtest-row span:first-child {
  color: #dbeafe;
  font-weight: 850;
}

.recent-backtest-row .recent-trade-strategy {
  color: #67e8f9;
  font-weight: 760;
}

.recent-backtest-row span,
.recent-backtest-row strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
}

.compact-sub-header {
  margin-top: 10px;
  margin-bottom: 8px;
}

@media (max-width: 1500px) {
  body[data-page="backtest"] .backtest-detail-console .stat-grid.compact-stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  body[data-page="backtest"] .backtest-runs-console #backtest-runs-list,
  body[data-page="backtest"] .backtest-detail-console .stat-grid.compact-stats,
  .recent-backtest-row {
    grid-template-columns: 1fr;
  }
}

/* Full implementation for backtest reference red-box modules */
body[data-page="backtest"] .backtest-runs-console #backtest-runs-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

body[data-page="backtest"] .backtest-run-card {
  position: relative;
  overflow: hidden;
  min-height: 162px;
  padding: 15px;
}

body[data-page="backtest"] .backtest-run-card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, #38bdf8, rgba(37,99,235,.25), transparent);
}

body[data-page="backtest"] .backtest-run-card.queued::before {
  background: linear-gradient(90deg, #fbbf24, rgba(251,191,36,.25), transparent);
}

body[data-page="backtest"] .backtest-run-card.success::before {
  background: linear-gradient(90deg, #22c55e, rgba(34,197,94,.18), transparent);
}

body[data-page="backtest"] .backtest-run-card.idle {
  opacity: .72;
  border-style: dashed;
}

.backtest-run-state-line {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 7px;
  color: #9fb4cf;
  font-size: 12px;
  font-weight: 850;
}

.run-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #64748b;
  box-shadow: 0 0 10px rgba(100, 116, 139, .45);
}

.run-dot.running {
  background: #22c55e;
  box-shadow: 0 0 14px rgba(34, 197, 94, .65);
}

.run-dot.queued {
  background: #fbbf24;
  box-shadow: 0 0 14px rgba(251, 191, 36, .65);
}

.run-dot.success {
  background: #38bdf8;
  box-shadow: 0 0 14px rgba(56, 189, 248, .55);
}

body[data-page="backtest"] .backtest-run-metrics {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body[data-page="backtest"] .backtest-workbench-grid {
  grid-template-columns: 1fr;
}

body[data-page="backtest"] .backtest-detail-console {
  padding-top: 18px;
}

body[data-page="backtest"] .backtest-analysis-grid {
  grid-template-columns: minmax(0, 1.2fr) minmax(360px, .48fr);
}

body[data-page="backtest"] .backtest-recent-card {
  border: 1px solid rgba(56, 189, 248, 0.18);
  border-radius: 18px;
  padding: 14px;
  background: rgba(8, 18, 32, 0.38);
}

body[data-page="backtest"] .recent-backtest-row {
  min-height: 42px;
}

@media (max-width: 1180px) {
  body[data-page="backtest"] .backtest-runs-console #backtest-runs-list,
  body[data-page="backtest"] .backtest-analysis-grid {
    grid-template-columns: 1fr;
  }
}

/* Split backtest detail from one giant container into independent modules */
body[data-page="backtest"] .split-detail-console {
  display: flex !important;
  flex-direction: column;
  gap: 18px;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.backtest-detail-title-card {
  margin-bottom: 0 !important;
}

body[data-page="backtest"] .backtest-metric-strip {
  margin: 0;
}

body[data-page="backtest"] .backtest-analysis-grid {
  margin-top: 0;
}

body[data-page="backtest"] .backtest-equity-card,
body[data-page="backtest"] .backtest-recent-card,
body[data-page="backtest"] .backtest-trades-console {
  padding: 18px !important;
  margin: 0 !important;
}

body[data-page="backtest"] .backtest-trades-console {
  margin-top: 0 !important;
}

body[data-page="backtest"] .backtest-detail-console > .card-header {
  display: none;
}

/* Backtest cards restyled like reference screenshot */
body[data-page="backtest"] .backtest-runs-console {
  padding: 18px !important;
}

body[data-page="backtest"] .backtest-runs-console .card-header {
  margin-bottom: 12px;
}

body[data-page="backtest"] .backtest-run-card {
  min-height: 142px;
  padding: 16px 18px;
  border-radius: 12px;
  background:
    radial-gradient(circle at 20% 0%, rgba(34, 211, 238, 0.12), transparent 36%),
    linear-gradient(180deg, rgba(10, 31, 54, 0.96), rgba(5, 18, 34, 0.96));
}

body[data-page="backtest"] .backtest-run-card.queued {
  background:
    radial-gradient(circle at 20% 0%, rgba(251, 191, 36, 0.14), transparent 36%),
    linear-gradient(180deg, rgba(30, 32, 35, 0.96), rgba(9, 20, 34, 0.96));
}

body[data-page="backtest"] .backtest-run-head {
  align-items: flex-start;
}

body[data-page="backtest"] .backtest-run-head strong {
  margin-top: 8px;
  font-size: 14px;
}

body[data-page="backtest"] .backtest-run-head span:not(.badge) {
  display: block;
  margin-top: 6px;
  font-size: 12px;
}

.backtest-progress-percent {
  color: #22d3ee;
  font-size: 24px;
  font-weight: 950;
  line-height: 1;
}

body[data-page="backtest"] .backtest-run-card.queued .backtest-progress-percent {
  color: #fbbf24;
}

body[data-page="backtest"] .backtest-progress-track {
  height: 8px;
  margin: 16px 0 12px;
  background: rgba(15, 23, 42, 0.80);
}

body[data-page="backtest"] .backtest-progress-track i {
  background: linear-gradient(90deg, #0ea5e9, #22d3ee);
}

body[data-page="backtest"] .backtest-run-card.queued .backtest-progress-track i {
  background: repeating-linear-gradient(135deg, #fbbf24 0 8px, #b7791f 8px 16px);
}

body[data-page="backtest"] .backtest-run-foot.compact {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(56, 189, 248, 0.12);
}

body[data-page="backtest"] .backtest-metric-strip .stat-card {
  min-height: 112px;
  border-radius: 12px;
  background:
    radial-gradient(circle at 18% 0%, rgba(56, 189, 248, 0.10), transparent 34%),
    linear-gradient(180deg, rgba(10, 31, 54, 0.96), rgba(5, 18, 34, 0.96));
}

body[data-page="backtest"] .backtest-metric-strip .stat-label {
  font-size: 13px;
}

body[data-page="backtest"] .backtest-metric-strip .stat-value {
  margin-top: 12px;
  font-size: clamp(24px, 2.2vw, 36px);
}

body[data-page="backtest"] #backtest-stat-total-return,
body[data-page="backtest"] #backtest-stat-avg-return,
body[data-page="backtest"] #backtest-stat-max-drawdown,
body[data-page="backtest"] #backtest-stat-win-rate {
  font-weight: 950;
}

@media (max-width: 900px) {
  body[data-page="backtest"] .backtest-run-foot.compact {
    grid-template-columns: 1fr;
  }
}

/* Backtest cleanup: remove redundant headers and split task cards */
body[data-page="backtest"] .backtest-task-grid {
  display: block;
}

body[data-page="backtest"] .backtest-task-cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

body[data-page="backtest"] .backtest-task-cards.empty-state {
  padding: 18px;
  border: 1px dashed rgba(56, 189, 248, 0.22);
  border-radius: 16px;
  background: rgba(8, 18, 32, 0.48);
}

body[data-page="backtest"] .backtest-task-cards .backtest-run-card {
  margin: 0;
}

.backtest-run-id-inline {
  display: block;
  margin: -4px 0 0;
  font-size: 12px;
}

body[data-page="backtest"] .backtest-metric-strip {
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
}

body[data-page="backtest"] .backtest-detail-title-card,
body[data-page="backtest"] #backtest-stat-status {
  display: none !important;
}

@media (max-width: 1180px) {
  body[data-page="backtest"] .backtest-task-cards,
  body[data-page="backtest"] .backtest-metric-strip {
    grid-template-columns: 1fr 1fr !important;
  }
}

@media (max-width: 760px) {
  body[data-page="backtest"] .backtest-task-cards,
  body[data-page="backtest"] .backtest-metric-strip {
    grid-template-columns: 1fr !important;
  }
}

/* Backtest metric/card cleanup + stronger interactive crosshair */
body[data-page="backtest"] .backtest-metric-strip {
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
}

body[data-page="backtest"] #backtest-equity-chart [data-chart-hit-area] {
  cursor: crosshair;
  pointer-events: all;
}

body[data-page="backtest"] #backtest-equity-chart .chart-focus line {
  stroke: rgba(226, 232, 240, 0.58);
  stroke-width: 1.1;
  stroke-dasharray: 4 4;
  vector-effect: non-scaling-stroke;
}

body[data-page="backtest"] #backtest-equity-chart .chart-focus circle {
  fill: #f8fafc;
  stroke: #38bdf8;
  stroke-width: 2.2;
  filter: drop-shadow(0 0 8px rgba(56, 189, 248, 0.75));
}

body[data-page="backtest"] #backtest-equity-chart .chart-focus [data-focus-bg] {
  fill: rgba(2, 8, 23, 0.82);
  stroke: rgba(56, 189, 248, 0.30);
  stroke-width: 1;
}

body[data-page="backtest"] #backtest-equity-chart .chart-focus-info {
  fill: #e5f3ff;
  font-size: 12px;
  font-weight: 800;
}

@media (max-width: 1180px) {
  body[data-page="backtest"] .backtest-metric-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 760px) {
  body[data-page="backtest"] .backtest-metric-strip {
    grid-template-columns: 1fr !important;
  }
}

/* Backtest metrics: one-row strip and hide technical run id */
body[data-page="backtest"] .backtest-run-id-inline {
  display: none !important;
}

body[data-page="backtest"] .backtest-metric-strip {
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 12px;
}

body[data-page="backtest"] .backtest-metric-strip .stat-card {
  min-width: 0;
  min-height: 112px;
}

@media (max-width: 1180px) {
  body[data-page="backtest"] .backtest-metric-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 760px) {
  body[data-page="backtest"] .backtest-metric-strip {
    grid-template-columns: 1fr !important;
  }
}

/* Backtest metric strip: six cards in one row */
body[data-page="backtest"] .backtest-metric-strip {
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
}

@media (max-width: 1380px) {
  body[data-page="backtest"] .backtest-metric-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 760px) {
  body[data-page="backtest"] .backtest-metric-strip {
    grid-template-columns: 1fr !important;
  }
}

/* Backtest equity chart: use more vertical space */
body[data-page="backtest"] .backtest-equity-card {
  min-height: 560px;
  display: flex;
  flex-direction: column;
}

body[data-page="backtest"] .backtest-equity-chart-wrap {
  flex: 1;
  min-height: 430px;
}

body[data-page="backtest"] .backtest-equity-chart-wrap svg {
  height: 430px;
}

@media (max-width: 900px) {
  body[data-page="backtest"] .backtest-equity-card {
    min-height: 420px;
  }

  body[data-page="backtest"] .backtest-equity-chart-wrap,
  body[data-page="backtest"] .backtest-equity-chart-wrap svg {
    min-height: 320px;
    height: 320px;
  }
}

/* Backtest title should be a compact title bar, not a hero card */
body[data-page="backtest"] .backtest-title-bar {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  padding: 4px 4px 8px;
  margin: 0;
  min-height: auto;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

body[data-page="backtest"] .backtest-title-bar h1 {
  margin: 4px 0 8px;
  font-size: clamp(30px, 3vw, 44px);
  line-height: 1.05;
  letter-spacing: -0.04em;
}

body[data-page="backtest"] .backtest-title-bar .page-subtitle {
  max-width: 760px;
  margin: 0;
}

body[data-page="backtest"] .backtest-title-bar .header-actions {
  align-self: center;
}

@media (max-width: 820px) {
  body[data-page="backtest"] .backtest-title-bar {
    display: grid;
    align-items: start;
  }
}

/* Strategies page terminal redesign */
body[data-page="strategies"] .strategies-title-bar {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-end;
  padding: 4px 4px 8px;
}

body[data-page="strategies"] .strategies-title-bar h1 {
  margin: 4px 0 8px;
  font-size: clamp(30px, 3vw, 44px);
  line-height: 1.05;
  letter-spacing: -0.04em;
}

.strategies-workbench-grid {
  display: grid;
  grid-template-columns: minmax(360px, 0.62fr) minmax(0, 1fr);
  gap: 18px;
  align-items: stretch;
}

body[data-page="strategies"] .strategies-list-console,
body[data-page="strategies"] .strategy-detail-console {
  margin: 0 !important;
}

body[data-page="strategies"] .strategy-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

body[data-page="strategies"] .strategy-card {
  position: relative;
  padding: 16px;
  border: 1px solid rgba(56, 189, 248, 0.20);
  border-radius: 16px;
  background:
    radial-gradient(circle at 18% 0%, rgba(56, 189, 248, 0.12), transparent 32%),
    linear-gradient(180deg, rgba(10, 31, 54, 0.96), rgba(5, 18, 34, 0.96));
  cursor: default;
}

body[data-page="strategies"] .strategy-card.selected {
  border-color: rgba(34, 211, 238, 0.58);
  box-shadow: 0 0 0 1px rgba(34, 211, 238, 0.12), 0 0 26px rgba(14, 165, 233, 0.14);
}

.strategy-card-topline,
.strategy-card-foot {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.strategy-card-topline {
  margin-bottom: 10px;
  color: #8fa3bd;
  font-size: 12px;
  font-weight: 850;
}

.strategy-status-dot {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: #64748b;
}

.strategy-status-dot.runtime_ready {
  background: #22c55e;
  box-shadow: 0 0 14px rgba(34, 197, 94, .55);
}

.strategy-card-meta,
.strategy-card-foot span {
  color: #9fb4cf;
  font-size: 12px;
}

body[data-page="strategies"] .strategy-card h3 {
  margin: 0;
  font-size: 17px;
}

.strategy-detail-terminal {
  display: grid;
  gap: 16px;
}

.strategy-detail-hero-line {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 16px;
  border: 1px solid rgba(56, 189, 248, 0.18);
  border-radius: 16px;
  background: rgba(8, 18, 32, 0.56);
}

.strategy-detail-hero-line strong {
  display: block;
  color: #e5f3ff;
  font-size: 26px;
  line-height: 1.08;
}

.strategy-detail-hero-line span:not(.badge) {
  display: block;
  margin-top: 8px;
  color: #9fb4cf;
  font-size: 12px;
}

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

.strategy-detail-metrics span {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(15, 23, 42, 0.58);
  color: #8fa3bd;
  font-size: 12px;
  font-weight: 800;
}

.strategy-detail-metrics b {
  color: #e5eefb;
}

.strategy-core-factors {
  padding: 12px;
  border-radius: 14px;
  background: rgba(14, 116, 144, 0.10);
  color: #c7d2fe;
  font-size: 13px;
  line-height: 1.6;
}

body[data-page="strategies"] .strategy-factor-cards {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

body[data-page="strategies"] .strategy-factor-card {
  min-height: 168px;
}

@media (max-width: 1420px) {
  .strategies-workbench-grid,
  body[data-page="strategies"] .strategy-factor-cards {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 820px) {
  body[data-page="strategies"] .strategies-title-bar,
  .strategy-detail-hero-line {
    display: grid;
  }

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

/* Strategy management page rebuilt against quant-console reference */
body[data-page="strategies"] .strategy-quant-main {
  padding: 14px 18px 24px;
}

.strategy-quant-frame {
  min-height: calc(100vh - 32px);
  border: 1px solid rgba(59, 130, 246, 0.28);
  border-radius: 24px;
  overflow: hidden;
  background:
    radial-gradient(circle at 26% 12%, rgba(14, 165, 233, 0.15), transparent 34%),
    linear-gradient(180deg, rgba(12, 31, 55, 0.98), rgba(3, 15, 30, 0.98));
  box-shadow: 0 28px 80px rgba(0,0,0,.32), inset 0 1px 0 rgba(255,255,255,.05);
}

.strategy-quant-titlebar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 18px 22px;
  border-bottom: 1px solid rgba(148, 163, 184, 0.18);
  background: rgba(15, 35, 61, 0.74);
}

.strategy-quant-titlebar h1 {
  margin: 0;
  color: #f8fbff;
  font-size: 21px;
  letter-spacing: -0.02em;
}

.strategy-quant-titlebar span {
  color: #9cc8ff;
  font-size: 14px;
}

.strategy-quant-board {
  padding: 18px 18px 22px;
}

.strategy-quant-topnav {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 14px;
}

.strategy-quant-topnav h2 {
  margin: 3px 0 4px;
  color: #eaf6ff;
  font-size: 25px;
}

.strategy-quant-topnav p:not(.eyebrow) {
  margin: 0;
  color: #8ea4bf;
}

.strategy-summary-strip {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-bottom: 14px;
}

.strategy-summary-strip .stat-card {
  min-height: 90px;
  padding: 14px;
}

.strategy-hero-card-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 14px;
}

.strategy-hero-card {
  position: relative;
  min-height: 178px;
  padding: 15px;
  border: 1px solid rgba(37, 99, 235, .42);
  border-radius: 10px;
  background:
    linear-gradient(145deg, rgba(8, 32, 55, .98), rgba(5, 20, 37, .96));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
  cursor: pointer;
  transition: border-color .18s ease, transform .18s ease, box-shadow .18s ease;
}

.strategy-hero-card:hover,
.strategy-hero-card.selected {
  border-color: rgba(34, 211, 238, .86);
  transform: translateY(-1px);
  box-shadow: 0 0 0 1px rgba(34, 211, 238, .16), 0 0 22px rgba(14, 165, 233, .18);
}

.strategy-hero-card.selected::after {
  content: '★';
  position: absolute;
  right: 13px;
  top: 38px;
  color: #facc15;
  font-size: 14px;
}

.strategy-hero-status-row {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: center;
  margin-bottom: 12px;
}

.strategy-id-chip {
  color: #d8e9ff;
  font-size: 15px;
  font-weight: 900;
}

.strategy-hero-card h3 {
  margin: 0 0 9px;
  color: #f3f8ff;
  font-size: 15px;
}

.strategy-hero-state {
  display: flex;
  align-items: center;
  gap: 7px;
  color: #5eead4;
  font-size: 12px;
  font-weight: 800;
}

.strategy-hero-card dl {
  display: grid;
  gap: 6px;
  margin: 14px 0 8px;
}

.strategy-hero-card dl div {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.strategy-hero-card dt,
.strategy-hero-card dd {
  margin: 0;
  font-size: 12px;
}

.strategy-hero-card dt { color: #8fa3bd; }
.strategy-hero-card dd { color: #dbeafe; font-weight: 800; }

.strategy-sparkline {
  width: 100%;
  height: 48px;
  margin-top: 2px;
}

.strategy-sparkline polyline {
  fill: none;
  stroke: #22d3ee;
  stroke-width: 2;
  filter: drop-shadow(0 0 6px rgba(34, 211, 238, .42));
}

.strategy-detail-matrix {
  border: 1px solid rgba(59, 130, 246, 0.20);
  border-radius: 12px;
  padding: 14px;
  background: rgba(5, 19, 36, .58);
  margin-bottom: 14px;
}

.strategy-detail-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
  color: #e5f3ff;
  font-size: 16px;
}

.strategy-detail-header strong span {
  color: #dbeafe;
}

.strategy-detail-columns {
  display: grid;
  grid-template-columns: 1.05fr .95fr 1.05fr;
  gap: 12px;
}

.strategy-matrix-card {
  min-height: 235px;
  padding: 14px;
  border: 1px solid rgba(59, 130, 246, 0.24);
  border-radius: 10px;
  background: rgba(7, 25, 45, 0.76);
}

.compact-card-header {
  margin-bottom: 10px !important;
}

.compact-card-header h3 {
  margin: 0;
  color: #eaf6ff;
  font-size: 15px;
}

body[data-page="strategies"] .strategy-factor-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 12px;
}

.strategy-weight-row {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr) 42px;
  gap: 10px;
  align-items: center;
  color: #c8d8ee;
  font-size: 12px;
}

.strategy-weight-row div {
  height: 10px;
  border-radius: 999px;
  background: rgba(30, 58, 91, .82);
  overflow: hidden;
}

.strategy-weight-row i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #22d3ee, #06b6d4);
  box-shadow: 0 0 12px rgba(34, 211, 238, .36);
}

.strategy-weight-row b {
  color: #dbeafe;
  text-align: right;
}

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

.strategy-param-list div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 10px 12px;
  border-bottom: 1px solid rgba(148, 163, 184, .10);
  color: #9fb4cf;
  font-size: 12px;
}

.strategy-param-list b {
  color: #4ade80;
}

.strategy-note-box {
  margin-top: 12px;
  padding: 12px;
  border: 1px solid rgba(245, 158, 11, .18);
  border-radius: 10px;
  background: rgba(245, 158, 11, .08);
}

.strategy-note-box strong {
  color: #fde68a;
  font-size: 13px;
}

.strategy-note-box p,
.strategy-note-box small {
  color: #cbd5e1;
  line-height: 1.6;
}

.strategy-detail-metrics.compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 12px;
}

.strategy-readiness-list {
  display: grid;
  gap: 10px;
}

.strategy-readiness-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 68px 64px;
  gap: 10px;
  align-items: center;
  padding: 10px 12px;
  border-radius: 10px;
  background: rgba(15, 35, 59, .65);
  color: #cbd5e1;
  font-size: 12px;
}

.strategy-readiness-item b {
  color: #4ade80;
  font-size: 12px;
}

.strategy-readiness-item.warn b {
  color: #fbbf24;
}

.strategy-readiness-item em {
  color: #93a4b8;
  font-style: normal;
  text-align: right;
}

.strategy-warning-note {
  margin-top: 2px;
  padding: 12px;
  border: 1px solid rgba(245, 158, 11, .18);
  border-radius: 10px;
  background: rgba(245, 158, 11, .08);
  color: #fcd34d;
  font-size: 12px;
  line-height: 1.55;
}

.strategy-table-console {
  margin: 0 !important;
  border-radius: 12px !important;
}

.strategy-table-search {
  min-width: 190px;
  padding: 9px 12px;
  border: 1px solid rgba(59, 130, 246, .25);
  border-radius: 8px;
  color: #7f94ad;
  font-size: 12px;
  background: rgba(3, 15, 30, .56);
}

body[data-page="strategies"] tr.selected-row td {
  background: rgba(14, 165, 233, 0.08);
}

@media (max-width: 1480px) {
  .strategy-hero-card-grid,
  .strategy-summary-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .strategy-detail-columns {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 820px) {
  .strategy-quant-titlebar,
  .strategy-quant-topnav,
  .strategy-detail-header {
    display: grid;
  }

  .strategy-hero-card-grid,
  .strategy-summary-strip {
    grid-template-columns: 1fr;
  }
}

/* Strategy registry cards: horizontal selector and remove duplicate default stat */
body[data-page="strategies"] .strategy-summary-strip {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

body[data-page="strategies"] .strategy-hero-card-grid {
  display: grid !important;
  grid-auto-flow: column;
  grid-auto-columns: minmax(300px, 1fr);
  grid-template-columns: none !important;
  gap: 12px;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 2px 2px 12px;
  scroll-snap-type: x proximity;
  scrollbar-color: rgba(34, 211, 238, 0.52) rgba(15, 23, 42, 0.52);
}

body[data-page="strategies"] .strategy-hero-card {
  scroll-snap-align: start;
  min-width: 300px;
}

body[data-page="strategies"] .strategy-hero-card-grid::after {
  content: '';
  width: 1px;
}

@media (min-width: 1481px) {
  body[data-page="strategies"] .strategy-hero-card-grid {
    grid-auto-columns: calc((100% - 36px) / 4);
  }
}

@media (max-width: 820px) {
  body[data-page="strategies"] .strategy-summary-strip {
    grid-template-columns: 1fr !important;
  }

  body[data-page="strategies"] .strategy-hero-card-grid {
    grid-auto-columns: minmax(260px, 86vw);
  }
}

/* Strategy factor rows: show CI / coverage / missing / sample */
body[data-page="strategies"] .strategy-factor-cards .factor-metric-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  padding: 10px 0 12px;
  border-bottom: 1px solid rgba(148, 163, 184, 0.12);
}

body[data-page="strategies"] .strategy-factor-cards .factor-metric-row:last-child {
  border-bottom: 0;
}

body[data-page="strategies"] .factor-metric-main {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr) 44px;
  gap: 10px;
  align-items: center;
}

body[data-page="strategies"] .factor-metric-detail {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 7px;
  padding-left: 68px;
}

body[data-page="strategies"] .factor-metric-detail span {
  display: flex;
  justify-content: space-between;
  gap: 6px;
  padding: 6px 8px;
  border-radius: 8px;
  background: rgba(15, 35, 59, 0.54);
  color: #88a4c2;
  font-size: 11px;
  font-weight: 800;
}

body[data-page="strategies"] .factor-metric-detail b {
  color: #dbeafe;
}

body[data-page="strategies"] .factor-metric-row.strong .factor-metric-detail span:first-child b {
  color: #4ade80;
}

body[data-page="strategies"] .factor-metric-row.weak .factor-metric-detail span:first-child b {
  color: #34d399;
}

body[data-page="strategies"] .factor-metric-row.neutral .factor-metric-detail span:first-child b {
  color: #67e8f9;
}

@media (max-width: 760px) {
  body[data-page="strategies"] .factor-metric-main {
    grid-template-columns: 52px minmax(0, 1fr) 40px;
  }

  body[data-page="strategies"] .factor-metric-detail {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding-left: 0;
  }
}

/* Fix strategy factor metric row layout after adding CI details */
body[data-page="strategies"] .strategy-factor-cards .strategy-weight-row.factor-metric-row {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 10px !important;
  align-items: stretch !important;
}

body[data-page="strategies"] .strategy-factor-cards .strategy-weight-row.factor-metric-row > span,
body[data-page="strategies"] .strategy-factor-cards .strategy-weight-row.factor-metric-row > b,
body[data-page="strategies"] .strategy-factor-cards .strategy-weight-row.factor-metric-row > div:not(.factor-metric-main):not(.factor-metric-detail) {
  display: none !important;
}

body[data-page="strategies"] .strategy-factor-cards .factor-metric-main {
  display: grid !important;
  grid-template-columns: 72px minmax(0, 1fr) 46px !important;
  gap: 12px !important;
  align-items: center !important;
  width: 100%;
}

body[data-page="strategies"] .strategy-factor-cards .factor-metric-main span {
  color: #dbeafe;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.25;
}

body[data-page="strategies"] .strategy-factor-cards .factor-metric-main div {
  display: block !important;
  height: 10px !important;
  min-width: 0;
  border-radius: 999px;
  background: rgba(30, 58, 91, .82);
  overflow: hidden;
}

body[data-page="strategies"] .strategy-factor-cards .factor-metric-main i {
  display: block !important;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #22d3ee, #06b6d4);
  box-shadow: 0 0 12px rgba(34, 211, 238, .36);
}

body[data-page="strategies"] .strategy-factor-cards .factor-metric-main b {
  color: #eaf6ff;
  font-size: 12px;
  text-align: right;
}

body[data-page="strategies"] .strategy-factor-cards .factor-metric-detail {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 8px !important;
  padding-left: 84px !important;
  width: 100%;
}

@media (max-width: 760px) {
  body[data-page="strategies"] .strategy-factor-cards .factor-metric-main {
    grid-template-columns: 62px minmax(0, 1fr) 42px !important;
  }

  body[data-page="strategies"] .strategy-factor-cards .factor-metric-detail {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    padding-left: 0 !important;
  }
}

/* Strategy factor metrics final isolation: no legacy row leakage */
body[data-page="strategies"] .strategy-factor-cards .factor-metric-row {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 10px !important;
  padding: 12px 0 14px !important;
  border-bottom: 1px solid rgba(148, 163, 184, 0.12) !important;
}

body[data-page="strategies"] .strategy-factor-cards .factor-metric-row:last-child {
  border-bottom: 0 !important;
}

body[data-page="strategies"] .strategy-factor-cards .factor-metric-row .factor-metric-main {
  display: grid !important;
  grid-template-columns: 76px minmax(0, 1fr) 48px !important;
  gap: 12px !important;
  align-items: center !important;
}

body[data-page="strategies"] .strategy-factor-cards .factor-metric-row .factor-metric-main span {
  color: #dbeafe !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1.25 !important;
}

body[data-page="strategies"] .strategy-factor-cards .factor-metric-row .factor-metric-main div {
  display: block !important;
  height: 10px !important;
  border-radius: 999px !important;
  background: rgba(30, 58, 91, .82) !important;
  overflow: hidden !important;
}

body[data-page="strategies"] .strategy-factor-cards .factor-metric-row .factor-metric-main i {
  display: block !important;
  height: 100% !important;
  border-radius: inherit !important;
  background: linear-gradient(90deg, #22d3ee, #06b6d4) !important;
}

body[data-page="strategies"] .strategy-factor-cards .factor-metric-row .factor-metric-main b {
  color: #eaf6ff !important;
  font-size: 12px !important;
  text-align: right !important;
}

body[data-page="strategies"] .strategy-factor-cards .factor-metric-row .factor-metric-detail {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 8px !important;
  padding-left: 88px !important;
}

body[data-page="strategies"] .strategy-factor-cards .factor-metric-row .factor-metric-detail span {
  display: flex !important;
  justify-content: space-between !important;
  gap: 6px !important;
  min-height: 30px !important;
  padding: 7px 9px !important;
  border-radius: 8px !important;
  background: rgba(15, 35, 59, 0.74) !important;
  color: #88a4c2 !important;
  font-size: 11px !important;
  font-weight: 800 !important;
}

body[data-page="strategies"] .strategy-factor-cards .factor-metric-row .factor-metric-detail b {
  color: #dbeafe !important;
}

@media (max-width: 760px) {
  body[data-page="strategies"] .strategy-factor-cards .factor-metric-row .factor-metric-main {
    grid-template-columns: 64px minmax(0, 1fr) 42px !important;
  }

  body[data-page="strategies"] .strategy-factor-cards .factor-metric-row .factor-metric-detail {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    padding-left: 0 !important;
  }
}

/* System page rebuilt as ops monitoring console */
body[data-page="system"] .system-ops-main {
  padding: 14px 18px 24px;
}

.system-ops-frame {
  min-height: calc(100vh - 32px);
  border: 1px solid rgba(59, 130, 246, 0.25);
  border-radius: 24px;
  padding: 18px;
  background:
    radial-gradient(circle at 18% 8%, rgba(14, 165, 233, .16), transparent 30%),
    radial-gradient(circle at 72% 2%, rgba(34, 197, 94, .08), transparent 26%),
    linear-gradient(180deg, rgba(7, 25, 45, .98), rgba(3, 15, 30, .98));
  box-shadow: 0 28px 80px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.05);
}

.system-ops-titlebar {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 18px;
  margin-bottom: 16px;
  padding: 4px 4px 10px;
}

.system-ops-titlebar h1 {
  margin: 3px 0 6px;
  color: #f8fbff;
  font-size: clamp(30px, 3vw, 44px);
  line-height: 1.05;
  letter-spacing: -0.04em;
}

.system-ops-titlebar p:not(.eyebrow) {
  margin: 0;
  color: #8fa3bd;
}

.system-hero-monitor {
  display: grid;
  grid-template-columns: .72fr 1.08fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}

.system-health-card,
.system-latest-card,
.system-sentiment-card,
.system-note-card {
  padding: 16px;
  border: 1px solid rgba(59, 130, 246, 0.22);
  border-radius: 16px;
  background: rgba(7, 25, 45, 0.72);
}

.system-health-head {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 8px;
}

.system-health-orb {
  display: grid;
  place-items: center;
  width: 74px;
  height: 74px;
  border-radius: 999px;
  color: #dcfce7;
  font-weight: 950;
  letter-spacing: .08em;
  background: radial-gradient(circle, rgba(34,197,94,.38), rgba(14, 116, 144, .10));
  border: 1px solid rgba(74, 222, 128, .48);
  box-shadow: 0 0 28px rgba(34,197,94,.20);
}

.system-health-orb.error {
  color: #fee2e2;
  background: radial-gradient(circle, rgba(239,68,68,.35), rgba(127,29,29,.12));
  border-color: rgba(248,113,113,.52);
}

.system-health-head strong {
  display: block;
  color: #f8fbff;
  font-size: 22px;
}

.system-health-head span {
  color: #9fb4cf;
}

.system-health-meta,
.freshness-grid,
.sentiment-quality-hero {
  display: grid;
  gap: 8px;
  margin-top: 16px;
}

.system-health-meta {
  grid-template-columns: 1fr;
}

.system-health-meta span,
.freshness-item,
.sentiment-quality-hero div {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding: 9px 10px;
  border-radius: 10px;
  background: rgba(15, 35, 59, .60);
  color: #8fa3bd;
  font-size: 12px;
  font-weight: 800;
}

.system-health-meta b,
.freshness-item b,
.sentiment-quality-hero b {
  color: #e5f3ff;
}

.freshness-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.system-cache-note {
  margin-top: 12px;
  color: #67e8f9;
  font-size: 12px;
  font-weight: 800;
}

.sentiment-quality-hero {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.sentiment-flow {
  display: flex;
  align-items: center;
  gap: 9px;
  margin: 14px 0 10px;
  color: #cbd5e1;
  font-size: 12px;
  font-weight: 850;
}

.sentiment-flow i {
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, rgba(34,211,238,.65), rgba(59,130,246,.08));
}

.system-ops-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(360px, .9fr);
  gap: 14px;
  align-items: start;
  margin-bottom: 14px;
}

.system-section-note {
  color: #7dd3fc;
  font-size: 12px;
  font-weight: 900;
}

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

.system-task-card {
  min-height: 156px;
  padding: 13px;
  border: 1px solid rgba(59, 130, 246, 0.18);
  border-radius: 13px;
  background: rgba(3, 15, 30, .48);
}

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

.system-task-card-head strong {
  color: #e5f3ff;
  font-size: 13px;
  line-height: 1.35;
}

.system-task-schedule {
  display: inline-flex;
  padding: 5px 8px;
  border-radius: 999px;
  background: rgba(14, 116, 144, .16);
  color: #67e8f9;
  font-size: 11px;
  font-weight: 900;
}

.system-task-times {
  display: grid;
  gap: 4px;
  margin: 10px 0;
  color: #8fa3bd;
  font-size: 11px;
}

.system-task-card p {
  margin: 0;
  color: #94a3b8;
  font-size: 11px;
  line-height: 1.45;
}

.system-run-list {
  display: grid;
  gap: 10px;
  max-height: 620px;
  overflow-y: auto;
  padding-right: 4px;
}

.system-run-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 150px;
  gap: 12px;
  padding: 12px;
  border: 1px solid rgba(59, 130, 246, 0.18);
  border-radius: 13px;
  background: rgba(3, 15, 30, .48);
}

.system-run-item aside {
  display: grid;
  align-content: center;
  gap: 5px;
  padding-left: 12px;
  border-left: 1px solid rgba(148, 163, 184, .12);
}

.system-run-item aside strong {
  color: #e5f3ff;
  font-size: 13px;
}

.system-run-item aside span {
  color: #8fa3bd;
  font-size: 11px;
}

.system-note-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.system-gap-callout {
  padding: 13px;
  border-radius: 13px;
  background: rgba(14, 116, 144, .12);
  border: 1px solid rgba(34, 211, 238, .18);
}

.system-gap-callout strong {
  color: #e5f3ff;
}

.system-gap-callout p,
.system-gap-list span {
  color: #9fb4cf;
  line-height: 1.55;
}

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

.muted-diagnostics .status-panel + .status-panel {
  margin-top: 10px;
}

@media (max-width: 1500px) {
  .system-hero-monitor,
  .system-ops-grid,
  .system-note-grid {
    grid-template-columns: 1fr;
  }

  .system-task-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
  .system-ops-titlebar,
  .system-run-item {
    display: grid;
  }

  .system-task-grid,
  .freshness-grid,
  .sentiment-quality-hero {
    grid-template-columns: 1fr;
  }

  .system-run-item aside {
    padding-left: 0;
    border-left: 0;
    border-top: 1px solid rgba(148, 163, 184, .12);
    padding-top: 10px;
  }
}

/* System page cards like monitoring reference: top status + baseline summary */
.system-top-metric-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 14px;
}

.system-top-metric-card {
  min-height: 128px;
  padding: 16px;
  border: 1px solid rgba(59, 130, 246, .24);
  border-radius: 12px;
  background:
    radial-gradient(circle at 18% 10%, rgba(34, 211, 238, .10), transparent 34%),
    linear-gradient(180deg, rgba(9, 31, 55, .92), rgba(5, 20, 37, .95));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}

.top-metric-head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(148, 163, 184, .12);
}

.top-metric-icon {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 9px;
  color: #22d3ee;
  border: 1px solid rgba(34, 211, 238, .30);
  background: rgba(14, 116, 144, .12);
  font-weight: 950;
}

.top-metric-head span {
  display: block;
  color: #8fa3bd;
  font-size: 12px;
  font-weight: 850;
}

.top-metric-head b {
  display: block;
  margin-top: 4px;
  color: #e5f3ff;
  font-size: 16px;
  line-height: 1.2;
}

.top-metric-head b.ok { color: #4ade80; }
.top-metric-head b.error { color: #f87171; }

.top-metric-body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 92px;
  gap: 12px;
  align-items: end;
  margin-top: 12px;
}

.top-metric-body div {
  display: grid;
  gap: 8px;
  color: #94a3b8;
  font-size: 12px;
}

.system-tiny-spark {
  width: 92px;
  height: 34px;
}

.system-tiny-spark polyline {
  fill: none;
  stroke: #22d3ee;
  stroke-width: 2;
  filter: drop-shadow(0 0 5px rgba(34, 211, 238, .45));
}

.system-baseline-console {
  margin-bottom: 14px !important;
}

.system-baseline-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 10px;
}

.baseline-card {
  min-height: 188px;
  padding: 13px;
  border: 1px solid rgba(59, 130, 246, .18);
  border-radius: 10px;
  background: rgba(4, 18, 34, .64);
}

.baseline-card-head {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #9fb4cf;
  font-size: 12px;
  font-weight: 900;
}

.baseline-card-head span {
  color: #22d3ee;
  font-size: 16px;
}

.baseline-card strong {
  display: block;
  margin: 14px 0 8px;
  color: #22f0d2;
  font-size: 22px;
  line-height: 1;
}

.baseline-card .system-tiny-spark {
  width: 100%;
  height: 34px;
  margin-bottom: 9px;
}

.baseline-progress {
  height: 7px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(30, 58, 91, .72);
}

.baseline-progress i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #22d3ee, #2dd4bf);
  box-shadow: 0 0 12px rgba(34, 211, 238, .38);
}

.baseline-card p {
  margin: 11px 0 2px;
  color: #b6c7dd;
  font-size: 12px;
  font-weight: 850;
}

.baseline-card small {
  color: #7f94ad;
  font-size: 11px;
}

@media (max-width: 1680px) {
  .system-baseline-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 1280px) {
  .system-top-metric-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .system-baseline-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .system-top-metric-grid,
  .system-baseline-grid {
    grid-template-columns: 1fr;
  }
}

/* System task monitor merge: schedule + latest run in one section */
body[data-page="system"] .merged-task-monitor {
  grid-template-columns: 1fr !important;
}

body[data-page="system"] .merged-task-monitor .system-task-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

body[data-page="system"] .system-task-result {
  min-height: 18px;
  margin: 8px 0;
  color: #dbeafe;
  font-size: 11px;
  font-weight: 850;
}

body[data-page="system"] .merged-task-monitor .system-task-card {
  min-height: 174px;
}

@media (max-width: 1680px) {
  body[data-page="system"] .merged-task-monitor .system-task-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1180px) {
  body[data-page="system"] .merged-task-monitor .system-task-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  body[data-page="system"] .merged-task-monitor .system-task-grid {
    grid-template-columns: 1fr;
  }
}

/* System page: remove decorative fake sparklines */
body[data-page="system"] .system-tiny-spark {
  display: none !important;
}

body[data-page="system"] .top-metric-body.no-spark {
  grid-template-columns: 1fr;
  margin-top: 14px;
}

body[data-page="system"] .top-metric-body.no-spark div {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  display: grid;
  gap: 8px;
}

body[data-page="system"] .top-metric-body.no-spark span {
  padding: 8px 10px;
  border-radius: 8px;
  background: rgba(15, 35, 59, 0.58);
}

body[data-page="system"] .baseline-card {
  min-height: 160px;
}

body[data-page="system"] .baseline-card strong {
  margin-bottom: 16px;
}

body[data-page="system"] .baseline-progress {
  margin-bottom: 12px;
}

/* Strategy page: remove decorative fake sparkline from strategy cards */
body[data-page="strategies"] .strategy-sparkline {
  display: none !important;
}

body[data-page="strategies"] .strategy-card-note {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid rgba(148, 163, 184, 0.12);
  color: #8fa3bd;
  font-size: 12px;
  line-height: 1.5;
  min-height: 38px;
}

body[data-page="strategies"] .strategy-hero-card {
  min-height: 178px;
}

/* Home page final portal layout */
body[data-page="home"] .home-portal-main {
  padding: 14px 18px 24px;
}

.home-portal-frame {
  min-height: calc(100vh - 32px);
  border: 1px solid rgba(59, 130, 246, 0.24);
  border-radius: 24px;
  padding: 18px;
  background:
    radial-gradient(circle at 18% 6%, rgba(14, 165, 233, .17), transparent 32%),
    radial-gradient(circle at 68% 4%, rgba(239, 68, 68, .08), transparent 25%),
    linear-gradient(180deg, rgba(7, 25, 45, .98), rgba(3, 15, 30, .98));
  box-shadow: 0 28px 80px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.05);
}

.home-portal-hero {
  display: grid;
  grid-template-columns: minmax(340px, .9fr) 280px minmax(420px, 1.1fr);
  gap: 14px;
  align-items: stretch;
  margin-bottom: 14px;
}

.home-hero-left,
.home-market-gauge,
.home-market-snapshot-grid article {
  border: 1px solid rgba(59, 130, 246, 0.22);
  border-radius: 18px;
  background: rgba(7, 25, 45, 0.72);
}

.home-hero-left {
  padding: 22px;
}

.home-hero-left h1 {
  margin: 4px 0 10px;
  color: #f8fbff;
  font-size: clamp(34px, 3.6vw, 56px);
  line-height: 1.02;
  letter-spacing: -0.05em;
}

.home-market-gauge {
  display: grid;
  place-items: center;
  align-content: center;
  gap: 8px;
  text-align: center;
  padding: 18px;
  background:
    radial-gradient(circle, rgba(239, 68, 68, .16), transparent 58%),
    rgba(7, 25, 45, 0.72);
}

.home-market-gauge span,
.home-market-snapshot-grid span {
  color: #8fa3bd;
  font-size: 12px;
  font-weight: 900;
}

.home-market-gauge strong {
  color: #f87171;
  font-size: 54px;
  line-height: 1;
  letter-spacing: -0.06em;
}

.home-market-gauge b {
  color: #e5f3ff;
  font-size: 13px;
}

.home-market-gauge small,
.home-market-snapshot-grid small {
  color: #8fa3bd;
  font-size: 11px;
  line-height: 1.45;
}

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

.home-market-snapshot-grid article {
  display: grid;
  align-content: center;
  gap: 10px;
  padding: 16px;
}

.home-market-snapshot-grid strong {
  color: #e5f3ff;
  font-size: 22px;
  line-height: 1.08;
}

.home-portal-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .38fr);
  gap: 14px;
  align-items: start;
}

.home-tracking-console,
.home-side-column .card {
  margin: 0 !important;
}

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

.home-tracking-card {
  border: 1px solid rgba(59, 130, 246, 0.18);
  border-radius: 16px;
  background: rgba(3, 15, 30, 0.50);
  overflow: hidden;
}

.home-tracking-card-main {
  display: grid;
  gap: 12px;
  padding: 14px;
  color: inherit;
  text-decoration: none;
}

.home-tracking-card-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.home-tracking-card-head strong {
  display: block;
  color: #f8fbff;
  font-size: 16px;
}

.home-tracking-card-head span,
.home-tracking-card small {
  color: #8fa3bd;
  font-size: 12px;
}

.home-tracking-card-head em {
  display: inline-grid;
  place-items: center;
  min-width: 34px;
  height: 28px;
  border-radius: 999px;
  color: #dcfce7;
  background: rgba(34, 197, 94, .14);
  font-style: normal;
  font-weight: 900;
}

.home-tracking-return {
  font-size: 32px;
  font-weight: 950;
  letter-spacing: -0.04em;
}

.home-tracking-meta,
.home-tracking-price-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.home-tracking-price-row {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.home-tracking-meta span,
.home-tracking-price-row span {
  padding: 8px;
  border-radius: 10px;
  background: rgba(15, 35, 59, .54);
  color: #8fa3bd;
  font-size: 11px;
  font-weight: 800;
}

.home-tracking-price-row b {
  display: block;
  margin-top: 3px;
  color: #e5f3ff;
}

.home-side-column {
  display: grid;
  gap: 14px;
}

.home-sector-list {
  display: grid;
  gap: 9px;
}

.home-sector-row {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr) 118px;
  gap: 10px;
  align-items: center;
  padding: 10px;
  border-radius: 12px;
  background: rgba(3, 15, 30, 0.46);
  color: inherit;
  text-decoration: none;
}

.sector-rank {
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border-radius: 8px;
  color: #22d3ee;
  background: rgba(14, 116, 144, .18);
  font-weight: 950;
}

.sector-name strong,
.sector-flow b {
  display: block;
  color: #e5f3ff;
  font-size: 13px;
}

.sector-name small,
.sector-flow small {
  display: block;
  margin-top: 4px;
  color: #8fa3bd;
  font-size: 11px;
  line-height: 1.3;
}

.sector-flow {
  text-align: right;
}

@media (max-width: 1580px) {
  .home-portal-hero,
  .home-portal-grid {
    grid-template-columns: 1fr;
  }

  .home-tracking-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .home-market-snapshot-grid,
  .home-tracking-card-grid,
  .home-tracking-price-row {
    grid-template-columns: 1fr;
  }
}

/* Home page aligned to provided market overview reference */
body[data-page="home"] .home-ref-main {
  padding: 14px 18px 24px;
}

.home-ref-frame {
  min-height: calc(100vh - 32px);
  border: 1px solid rgba(59, 130, 246, .24);
  border-radius: 24px;
  overflow: hidden;
  background:
    radial-gradient(circle at 22% 0%, rgba(14, 165, 233, .14), transparent 30%),
    linear-gradient(180deg, rgba(7, 25, 45, .98), rgba(2, 12, 24, .98));
  box-shadow: 0 28px 80px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.05);
}

.home-ref-titlebar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 19px 22px;
  border-bottom: 1px solid rgba(148, 163, 184, .14);
  background: rgba(15, 35, 61, .74);
}

.home-ref-titlebar h1 {
  margin: 0;
  color: #f8fbff;
  font-size: 21px;
}

.home-ref-titlebar span {
  color: #9cc8ff;
  font-size: 14px;
}

.home-ref-tickerbar {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
  padding: 10px 18px;
  border-bottom: 1px solid rgba(148, 163, 184, .10);
  background: rgba(3, 15, 30, .62);
}

.home-index-tape {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
  color: #8fa3bd;
  font-size: 12px;
  font-weight: 850;
}

.home-index-tape b {
  color: #f87171;
  margin-left: 6px;
}

.home-ref-actions {
  display: flex;
  gap: 8px;
}

.home-ref-section-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 12px;
  padding: 16px 18px 10px;
}

.home-ref-section-head h2 {
  margin: 4px 0 0;
  color: #eaf6ff;
  font-size: 24px;
}

.home-ref-section-head > span {
  color: #8fa3bd;
  font-size: 12px;
}

.home-ref-market-cards {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  padding: 0 18px 12px;
}

.home-ref-market-card {
  min-height: 146px;
  padding: 15px;
  border: 1px solid rgba(59, 130, 246, .22);
  border-radius: 10px;
  background: rgba(8, 29, 52, .74);
}

.home-ref-card-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #a9bdd5;
  font-size: 13px;
  font-weight: 900;
}

.home-ref-card-head i {
  color: #64748b;
  font-style: normal;
}

.home-ref-market-card strong {
  display: block;
  margin: 12px 0 8px;
  color: #ef4444;
  font-size: 31px;
  line-height: 1;
  letter-spacing: -0.04em;
}

.home-ref-market-card b {
  color: #f87171;
  font-size: 13px;
}

.home-ref-market-card small {
  display: block;
  margin-top: 9px;
  color: #8fa3bd;
  font-size: 12px;
  line-height: 1.45;
}

.home-strength-bar,
.home-breadth-bars {
  position: relative;
  height: 8px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(30, 58, 91, .75);
  margin-top: 12px;
}

.home-strength-bar i {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, #facc15, #ef4444);
}

.home-breadth-bars {
  display: flex;
  gap: 2px;
}

.home-breadth-bars i.up {
  background: #ef4444;
}

.home-breadth-bars i.down {
  background: #22c55e;
}

.home-limit-split {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.home-limit-split span {
  padding: 8px;
  border-radius: 8px;
  background: rgba(15, 35, 59, .56);
  color: #8fa3bd;
  font-size: 12px;
}

.home-limit-split b {
  display: block;
  margin-top: 4px;
}

.home-ref-sector-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  padding: 0 18px 12px;
}

.home-ref-sector-grid .card,
.home-ref-tracking-console {
  margin: 0 !important;
  border-radius: 10px !important;
}

.home-sector-table {
  display: grid;
}

.home-sector-table-head,
.home-sector-table-row {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr) 130px 82px;
  gap: 10px;
  align-items: center;
  padding: 9px 10px;
  border-bottom: 1px solid rgba(148, 163, 184, .08);
}

.home-sector-table-head {
  color: #8fa3bd;
  font-size: 12px;
  font-weight: 900;
}

.home-sector-table-row {
  color: inherit;
  text-decoration: none;
}

.sector-rank {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 6px;
  color: #fff;
  background: linear-gradient(180deg, #ef4444, #b91c1c);
  font-weight: 950;
}

.sector-name strong,
.sector-flow,
.sector-pct {
  color: #e5f3ff;
  font-size: 13px;
  font-weight: 900;
}

.sector-name small {
  display: block;
  margin-top: 3px;
  color: #8fa3bd;
  font-size: 11px;
}

.sector-flow,
.sector-pct {
  text-align: right;
}

.home-ref-tracking-console {
  margin: 0 18px 18px !important;
}

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

.score-pill {
  display: inline-grid;
  place-items: center;
  min-width: 38px;
  height: 26px;
  padding: 0 9px;
  border-radius: 7px;
  color: #dff6ff;
  background: linear-gradient(180deg, rgba(14,165,233,.85), rgba(2,132,199,.75));
  font-weight: 950;
}

@media (max-width: 1500px) {
  .home-ref-market-cards,
  .home-ref-sector-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .home-ref-titlebar,
  .home-ref-tickerbar,
  .home-ref-section-head {
    display: grid;
  }

  .home-ref-market-cards,
  .home-ref-sector-grid {
    grid-template-columns: 1fr;
  }
}

/* Home reference layout: soften rank and score badges back to subtle style */
body[data-page="home"] .home-sector-table .sector-rank {
  width: auto;
  height: auto;
  min-width: 0;
  border-radius: 0;
  background: transparent !important;
  color: #7dd3fc !important;
  font-weight: 900;
  box-shadow: none;
}

body[data-page="home"] .home-tracking-table .score-pill {
  display: inline;
  min-width: 0;
  height: auto;
  padding: 0;
  border-radius: 0;
  background: transparent !important;
  color: #7dd3fc;
  font-weight: 900;
  box-shadow: none;
}

/* Home portal rollback typography fix: override later reference-table styles */
body[data-page="home"] .home-portal-frame {
  font-family: inherit;
}

body[data-page="home"] .home-portal-frame .home-market-snapshot-grid strong,
body[data-page="home"] .home-portal-frame .home-tracking-return,
body[data-page="home"] .home-portal-frame .home-market-gauge strong {
  font-family: inherit;
  letter-spacing: -0.04em;
}

body[data-page="home"] .home-portal-frame .home-sector-row {
  display: grid !important;
  grid-template-columns: 28px minmax(0, 1fr) 118px !important;
  gap: 10px !important;
  align-items: center !important;
  padding: 10px !important;
  border-radius: 12px !important;
  border-bottom: 0 !important;
  background: rgba(3, 15, 30, 0.46) !important;
  color: inherit !important;
  text-decoration: none !important;
}

body[data-page="home"] .home-portal-frame .home-sector-row .sector-rank {
  display: grid !important;
  place-items: center !important;
  width: 26px !important;
  height: 26px !important;
  min-width: 26px !important;
  border-radius: 8px !important;
  color: #22d3ee !important;
  background: rgba(14, 116, 144, .18) !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  box-shadow: none !important;
}

body[data-page="home"] .home-portal-frame .home-sector-row .sector-name strong,
body[data-page="home"] .home-portal-frame .home-sector-row .sector-flow b {
  display: block !important;
  color: #e5f3ff !important;
  font-size: 13px !important;
  font-weight: 850 !important;
  line-height: 1.25 !important;
}

body[data-page="home"] .home-portal-frame .home-sector-row .sector-name small,
body[data-page="home"] .home-portal-frame .home-sector-row .sector-flow small {
  display: block !important;
  margin-top: 4px !important;
  color: #8fa3bd !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  line-height: 1.3 !important;
}

body[data-page="home"] .home-portal-frame .home-sector-row .sector-flow {
  text-align: right !important;
}

body[data-page="home"] .home-portal-frame .home-tracking-card-head strong {
  font-size: 16px !important;
  font-weight: 850 !important;
  color: #f8fbff !important;
}

body[data-page="home"] .home-portal-frame .home-tracking-card-head span,
body[data-page="home"] .home-portal-frame .home-tracking-card small {
  font-size: 12px !important;
  font-weight: 500 !important;
  color: #8fa3bd !important;
}

body[data-page="home"] .home-portal-frame .home-tracking-price-row span,
body[data-page="home"] .home-portal-frame .home-tracking-meta span {
  font-size: 11px !important;
  font-weight: 800 !important;
}

/* Home: card layout pass only, keep existing typography tone */
body[data-page="home"] .home-card-layout-frame {
  padding: 0;
  overflow: hidden;
}

body[data-page="home"] .home-card-titlebar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 18px 22px;
  border-bottom: 1px solid rgba(148, 163, 184, 0.14);
  background: rgba(15, 35, 61, 0.68);
}

body[data-page="home"] .home-card-titlebar h1 {
  margin: 0;
}

body[data-page="home"] .home-card-titlebar span {
  color: #9fb4cf;
}

body[data-page="home"] .home-market-console-card {
  margin: 14px !important;
  border-radius: 16px !important;
}

body[data-page="home"] .home-card-actions {
  margin: 0;
}

body[data-page="home"] .home-card-market-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 14px;
}

body[data-page="home"] .home-card-market-item {
  display: grid;
  gap: 8px;
  min-height: 136px;
  padding: 14px;
  border: 1px solid rgba(59, 130, 246, 0.20);
  border-radius: 12px;
  background: rgba(3, 15, 30, 0.42);
}

body[data-page="home"] .home-card-market-item span {
  color: #9fb4cf;
}

body[data-page="home"] .home-card-market-item strong {
  color: #e5f3ff;
}

body[data-page="home"] .home-card-market-item.market-strength-item strong {
  color: #f87171;
}

body[data-page="home"] .home-card-market-item b,
body[data-page="home"] .home-card-market-item small {
  color: #8fa3bd;
}

body[data-page="home"] .home-card-sector-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 14px;
}

body[data-page="home"] .home-market-timing-section {
  margin-bottom: 14px;
  padding: 14px;
  border: 1px solid rgba(59, 130, 246, 0.20);
  border-radius: 12px;
  background: rgba(3, 15, 30, 0.42);
}

body[data-page="home"] .home-market-timing-section > .card-header {
  padding: 0 0 12px;
}

body[data-page="home"] .home-market-timing-grid {
  display: grid;
  grid-template-columns: minmax(210px, 0.58fr) minmax(0, 1.42fr);
  gap: 12px;
}

body[data-page="home"] .home-market-timing-main {
  display: grid;
  gap: 7px;
  align-content: center;
  min-height: 118px;
  padding: 14px;
  border: 1px solid rgba(148, 163, 184, 0.14);
  border-radius: 10px;
  background: rgba(6, 18, 32, 0.52);
}

body[data-page="home"] .home-market-timing-main.risk_on {
  border-color: rgba(248, 113, 113, 0.32);
  background: linear-gradient(135deg, rgba(127, 29, 29, 0.18), rgba(6, 18, 32, 0.58));
}

body[data-page="home"] .home-market-timing-main.cautious {
  border-color: rgba(251, 191, 36, 0.34);
  background: linear-gradient(135deg, rgba(113, 63, 18, 0.16), rgba(6, 18, 32, 0.58));
}

body[data-page="home"] .home-market-timing-main.defensive {
  border-color: rgba(34, 197, 94, 0.32);
  background: linear-gradient(135deg, rgba(20, 83, 45, 0.16), rgba(6, 18, 32, 0.58));
}

body[data-page="home"] .home-market-timing-main span,
body[data-page="home"] .home-market-timing-main small,
body[data-page="home"] .home-market-timing-signal span,
body[data-page="home"] .home-market-timing-signal small {
  color: #8fa3bd;
  font-size: 11px;
  font-weight: 760;
}

body[data-page="home"] .home-market-timing-main strong {
  color: #e5f3ff;
  font-size: 34px;
  line-height: 1;
}

body[data-page="home"] .home-market-timing-main b {
  color: #cbd5e1;
  font-size: 14px;
}

body[data-page="home"] .home-market-timing-signals {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
  gap: 9px;
}

body[data-page="home"] .home-market-timing-signal {
  display: grid;
  gap: 7px;
  min-height: 118px;
  padding: 12px;
  border: 1px solid rgba(148, 163, 184, 0.14);
  border-radius: 10px;
  background: rgba(6, 18, 32, 0.50);
}

body[data-page="home"] .home-market-timing-signal strong {
  color: #cbd5e1;
  font-size: 24px;
  line-height: 1;
}

body[data-page="home"] .home-market-timing-signal b {
  width: fit-content;
  min-height: 20px;
  padding: 2px 7px;
  border-radius: 6px;
  color: #cbd5e1;
  background: rgba(148, 163, 184, 0.10);
  font-size: 11px;
  font-weight: 900;
}

body[data-page="home"] .home-market-timing-signal.positive strong {
  color: #fca5a5;
}

body[data-page="home"] .home-market-timing-signal.positive b {
  color: #fca5a5;
  background: rgba(239, 68, 68, 0.12);
}

body[data-page="home"] .home-market-timing-signal.negative strong {
  color: #86efac;
}

body[data-page="home"] .home-market-timing-signal.negative b {
  color: #86efac;
  background: rgba(34, 197, 94, 0.10);
}

body[data-page="home"] .home-market-timing-signal.neutral strong {
  color: #fbbf24;
}

body[data-page="home"] .home-market-timing-signal.neutral b {
  color: #fbbf24;
  background: rgba(245, 158, 11, 0.10);
}

body[data-page="home"] .home-market-timing-reasons {
  margin-top: 10px;
}

body[data-page="home"] .home-market-timing-reason-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

body[data-page="home"] .home-market-timing-reason-list span {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 3px 8px;
  border: 1px solid rgba(59, 130, 246, 0.18);
  border-radius: 7px;
  color: #b6c7dc;
  background: rgba(15, 23, 42, 0.46);
  font-size: 11px;
  font-weight: 780;
}

body[data-page="home"] .home-market-timing-risk {
  margin-top: 7px;
  color: #fbbf24;
  font-size: 11px;
  line-height: 1.45;
}

body[data-page="home"] .home-market-timing-coverage {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 8px;
}

body[data-page="home"] .home-market-timing-coverage span {
  display: inline-flex;
  align-items: center;
  min-height: 21px;
  padding: 2px 7px;
  border: 1px solid rgba(148, 163, 184, 0.16);
  border-radius: 6px;
  color: #8fa3bd;
  background: rgba(15, 23, 42, 0.40);
  font-size: 10px;
  font-weight: 780;
}

body[data-page="home"] .home-market-timing-coverage span.ready {
  border-color: rgba(34, 197, 94, 0.24);
  color: #86efac;
  background: rgba(34, 197, 94, 0.08);
}

body[data-page="home"] .home-market-timing-coverage span.pending {
  border-color: rgba(245, 158, 11, 0.30);
  color: #fbbf24;
  background: rgba(245, 158, 11, 0.08);
}

body[data-page="home"] .home-market-timing-coverage span.future {
  border-color: rgba(59, 130, 246, 0.22);
  color: #93c5fd;
  background: rgba(59, 130, 246, 0.08);
}

body[data-page="home"] .home-market-timing-coverage span.missing {
  border-color: rgba(148, 163, 184, 0.18);
  color: #94a3b8;
}

body[data-page="home"] .home-card-sector-grid .sector-card {
  padding: 14px;
  border: 1px solid rgba(59, 130, 246, 0.20);
  border-radius: 12px;
  background: rgba(3, 15, 30, 0.42);
}

body[data-page="home"] .home-hot-theme-section {
  margin-bottom: 14px;
  padding: 14px;
  border: 1px solid rgba(59, 130, 246, 0.20);
  border-radius: 12px;
  background: rgba(3, 15, 30, 0.42);
}

body[data-page="home"] .home-hot-theme-section > .card-header {
  padding: 0 0 12px;
}

body[data-page="home"] .home-hot-theme-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

body[data-page="home"] .home-hot-theme-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
  min-width: 0;
  padding: 11px;
  border: 1px solid rgba(148, 163, 184, 0.12);
  border-radius: 8px;
  background: rgba(6, 18, 32, 0.48);
}

body[data-page="home"] .hot-theme-rank {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 6px;
  color: #fca5a5;
  background: rgba(239, 68, 68, 0.13);
  font-size: 12px;
  font-weight: 900;
}

body[data-page="home"] .hot-theme-title-row {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

body[data-page="home"] .hot-theme-title-row strong {
  color: #e5f3ff;
  font-size: 14px;
}

body[data-page="home"] .hot-theme-title-row span {
  padding: 2px 6px;
  border-radius: 6px;
  color: #7dd3fc;
  background: rgba(14, 165, 233, 0.12);
  font-size: 10px;
  font-weight: 850;
}

body[data-page="home"] .hot-theme-news,
body[data-page="home"] .hot-theme-stocks {
  margin-top: 5px;
  color: #8fa3bd;
  font-size: 11px;
  line-height: 1.35;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

body[data-page="home"] .hot-theme-metrics {
  display: grid;
  justify-items: end;
  gap: 2px;
  max-width: 150px;
  white-space: nowrap;
}

body[data-page="home"] .hot-theme-metrics b {
  color: #f87171;
  font-size: 20px;
  line-height: 1;
}

body[data-page="home"] .hot-theme-metrics span,
body[data-page="home"] .hot-theme-metrics small {
  color: #8fa3bd;
  font-size: 10px;
  font-weight: 750;
}

body[data-page="home"] .hot-theme-metrics small.up {
  color: #fca5a5;
}

body[data-page="home"] .hot-theme-metrics small.down {
  color: #86efac;
}

body[data-page="home"] .home-short-emotion-section {
  margin-bottom: 14px;
  padding: 14px;
  border: 1px solid rgba(59, 130, 246, 0.20);
  border-radius: 12px;
  background: rgba(3, 15, 30, 0.42);
}

body[data-page="home"] .home-short-emotion-section > .card-header {
  padding: 0 0 12px;
}

body[data-page="home"] .home-emotion-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

body[data-page="home"] .home-emotion-panel {
  min-width: 0;
  padding: 12px;
  border: 1px solid rgba(148, 163, 184, 0.14);
  border-radius: 10px;
  background: rgba(6, 18, 32, 0.48);
}

body[data-page="home"] .home-emotion-panel-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 10px;
}

body[data-page="home"] .home-emotion-panel-head h3 {
  margin: 0;
  color: #e5f3ff;
  font-size: 15px;
}

body[data-page="home"] .home-emotion-panel-head span {
  color: #8fa3bd;
  font-size: 12px;
  font-weight: 750;
}

body[data-page="home"] .home-emotion-list {
  min-width: 0;
}

body[data-page="home"] .home-emotion-subsection + .home-emotion-subsection {
  margin-top: 12px;
}

body[data-page="home"] .home-emotion-subhead {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  margin: 0 0 7px;
}

body[data-page="home"] .home-emotion-subhead strong {
  color: #e5f3ff;
  font-size: 13px;
  font-weight: 900;
}

body[data-page="home"] .home-emotion-subhead span {
  color: #8fa3bd;
  font-size: 11px;
  font-weight: 750;
}

body[data-page="home"] .home-emotion-table-wrap {
  overflow-x: auto;
  border: 1px solid rgba(148, 163, 184, 0.12);
  border-radius: 8px;
}

body[data-page="home"] .home-emotion-table {
  width: 100%;
  min-width: 620px;
  border-collapse: collapse;
}

body[data-page="home"] .home-emotion-table th,
body[data-page="home"] .home-emotion-table td {
  padding: 8px 9px;
  border-bottom: 1px solid rgba(148, 163, 184, 0.10);
  text-align: left;
  vertical-align: middle;
  font-size: 12px;
  line-height: 1.35;
  white-space: nowrap;
}

body[data-page="home"] .home-emotion-table th {
  color: #8fa3bd;
  background: rgba(15, 23, 42, 0.72);
  font-size: 11px;
  font-weight: 850;
}

body[data-page="home"] .home-emotion-table tbody tr:hover {
  background: rgba(15, 35, 61, 0.58);
}

body[data-page="home"] .home-emotion-table tbody tr:last-child td {
  border-bottom: 0;
}

body[data-page="home"] .home-emotion-table .muted {
  margin-top: 2px;
  color: #8fa3bd;
  font-size: 11px;
}

body[data-page="home"] .emotion-stock-link {
  color: #e5f3ff;
  font-size: 13px;
  font-weight: 850;
  text-decoration: none;
}

body[data-page="home"] .emotion-stock-link:hover {
  color: #7dd3fc;
}

body[data-page="home"] .emotion-rank,
body[data-page="home"] .emotion-height-badge,
body[data-page="home"] .emotion-status-badge {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 2px 7px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 900;
}

body[data-page="home"] .emotion-rank {
  color: #93c5fd;
  background: rgba(59, 130, 246, 0.12);
}

body[data-page="home"] .emotion-height-badge,
body[data-page="home"] .emotion-status-badge {
  color: #f87171;
  background: rgba(239, 68, 68, 0.12);
  border: 1px solid rgba(239, 68, 68, 0.28);
}

body[data-page="home"] .emotion-tags {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 4px;
}

body[data-page="home"] .emotion-risk-tag {
  display: inline-flex;
  align-items: center;
  min-height: 20px;
  padding: 2px 6px;
  border: 1px solid rgba(245, 158, 11, 0.38);
  border-radius: 6px;
  color: #fbbf24;
  background: rgba(245, 158, 11, 0.10);
  font-size: 10px;
  font-weight: 850;
  white-space: nowrap;
}

body[data-page="home"] .emotion-risk-tag.muted-tag {
  border-color: rgba(148, 163, 184, 0.18);
  color: #8fa3bd;
  background: rgba(148, 163, 184, 0.08);
}

body[data-page="home"] .home-card-tracking-section {
  padding-top: 2px;
}

body[data-page="home"] .home-card-tracking-section .home-tracking-card-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 1500px) {
  body[data-page="home"] .home-card-market-grid,
  body[data-page="home"] .home-card-sector-grid,
  body[data-page="home"] .home-market-timing-grid,
  body[data-page="home"] .home-hot-theme-list,
  body[data-page="home"] .home-emotion-grid,
  body[data-page="home"] .home-card-tracking-section .home-tracking-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  body[data-page="home"] .home-card-titlebar,
  body[data-page="home"] .home-market-console-card > .card-header.with-actions {
    display: grid;
  }

  body[data-page="home"] .home-card-market-grid,
  body[data-page="home"] .home-card-sector-grid,
  body[data-page="home"] .home-market-timing-grid,
  body[data-page="home"] .home-hot-theme-list,
  body[data-page="home"] .home-emotion-grid,
  body[data-page="home"] .home-card-tracking-section .home-tracking-card-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="home"] .home-market-timing-signals {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="home"] .emotion-tags {
    justify-content: flex-start;
  }
}

/* Home market cards: compact metrics + dedicated quote time card */
body[data-page="home"] .home-card-market-grid {
  grid-template-columns: 0.9fr 0.95fr 0.95fr 0.92fr !important;
}

body[data-page="home"] .home-card-market-item {
  min-height: 128px;
}

body[data-page="home"] .home-card-market-item.home-market-time-card {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 10px;
  align-content: stretch;
  min-height: 128px;
  padding: 15px 18px 13px;
}

body[data-page="home"] .market-time-title {
  color: #cbd5e1;
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
}

body[data-page="home"] .market-time-title em {
  color: #6b7f99;
  font-size: 10px;
  font-style: normal;
}

body[data-page="home"] .home-market-time-card .market-time-body {
  display: grid;
  grid-template-columns: minmax(88px, 0.42fr) minmax(120px, 1fr);
  align-items: center;
  gap: 22px;
  min-height: 92px;
}

body[data-page="home"] .home-market-time-card .market-time-info {
  display: grid;
  align-content: center;
  gap: 4px;
  min-width: 0;
}

body[data-page="home"] .home-market-time-card strong {
  margin: 1px 0 0;
  font-size: clamp(24px, 1.75vw, 32px);
  color: #7dd3fc !important;
  letter-spacing: 0;
  line-height: 1.05;
}

body[data-page="home"] .home-market-time-card b {
  display: block;
  width: fit-content;
  padding: 0;
  border-radius: 999px;
  color: #38bdf8 !important;
  background: transparent !important;
  font-size: 15px;
  font-weight: 900;
  white-space: nowrap;
}

body[data-page="home"] .home-market-time-card b.trading {
  color: #38bdf8 !important;
  background: rgba(14, 165, 233, 0.14);
}

body[data-page="home"] .home-market-time-card b.paused {
  color: #fbbf24 !important;
  background: rgba(245, 158, 11, 0.14);
}

body[data-page="home"] .home-market-time-card b.closed {
  color: #94a3b8 !important;
  background: rgba(148, 163, 184, 0.12);
}

body[data-page="home"] #home-market-date,
body[data-page="home"] #home-market-weekday {
  display: block;
  color: #8fa3bd;
  font-size: 13px;
  line-height: 1.25;
}

body[data-page="home"] #home-market-countdown {
  display: block;
  color: #7dd3fc;
  font-weight: 850;
  font-size: 13px;
  line-height: 1;
  margin-top: 0;
  white-space: nowrap;
}

body[data-page="home"] .home-market-time-card small + small {
  margin-top: 0;
}

body[data-page="home"] .market-time-clock {
  position: relative;
  width: clamp(82px, 5.2vw, 104px);
  height: clamp(82px, 5.2vw, 104px);
  border-radius: 999px;
  border: 1px solid rgba(56, 189, 248, 0.38);
  background:
    radial-gradient(circle at center, rgba(14, 165, 233, 0.16), transparent 48%),
    repeating-conic-gradient(from 0deg, rgba(56, 189, 248, .50) 0 2deg, transparent 2deg 30deg);
  box-shadow: inset 0 0 18px rgba(14, 165, 233, .18), 0 0 14px rgba(14, 165, 233, .08);
}

body[data-page="home"] .market-time-clock::before {
  content: '';
  position: absolute;
  inset: 10px;
  border-radius: inherit;
  background: #06182c;
}

body[data-page="home"] .market-time-clock::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 50%;
  width: 8px;
  height: 8px;
  margin: -4px 0 0 -4px;
  border-radius: 999px;
  background: #e0f2fe;
}

body[data-page="home"] .clock-hand {
  position: absolute;
  left: 50%;
  bottom: 50%;
  z-index: 2;
  width: 3px;
  transform-origin: bottom center;
  border-radius: 999px;
  background: #e0f2fe;
}

body[data-page="home"] .clock-hand.hour {
  height: 28px;
}

body[data-page="home"] .clock-hand.minute {
  height: 40px;
  background: #ef4444;
}

@media (max-width: 1500px) {
  body[data-page="home"] .home-card-market-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 860px) {
  body[data-page="home"] .home-card-market-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Home market visualization: strength heatmap + breadth stacked bar */
body[data-page="home"] .market-strength-heat {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 5px;
  margin: 4px 0 2px;
}

body[data-page="home"] .market-strength-heat i {
  display: block;
  height: 12px;
  border-radius: 3px;
  background: rgba(148, 163, 184, 0.26);
}

body[data-page="home"] .market-strength-heat.hot i {
  background: linear-gradient(180deg, rgba(248, 113, 113, 0.95), rgba(185, 28, 28, 0.82));
  box-shadow: 0 0 10px rgba(239, 68, 68, 0.18);
}

body[data-page="home"] .market-strength-heat.cool i {
  background: linear-gradient(180deg, rgba(74, 222, 128, 0.92), rgba(21, 128, 61, 0.80));
  box-shadow: 0 0 10px rgba(34, 197, 94, 0.16);
}

body[data-page="home"] .market-strength-heat.hot i:nth-child(1),
body[data-page="home"] .market-strength-heat.cool i:nth-child(1) { opacity: .46; }
body[data-page="home"] .market-strength-heat.hot i:nth-child(2),
body[data-page="home"] .market-strength-heat.cool i:nth-child(2) { opacity: .62; }
body[data-page="home"] .market-strength-heat.hot i:nth-child(3),
body[data-page="home"] .market-strength-heat.cool i:nth-child(3) { opacity: .78; }
body[data-page="home"] .market-strength-heat.hot i:nth-child(4),
body[data-page="home"] .market-strength-heat.cool i:nth-child(4) { opacity: .90; }

body[data-page="home"] .market-breadth-item strong {
  margin-bottom: 0;
}

body[data-page="home"] .market-breadth-bar {
  display: flex;
  height: 12px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(15, 23, 42, 0.72);
  border: 1px solid rgba(148, 163, 184, 0.12);
}

body[data-page="home"] .market-breadth-bar i {
  display: block;
  min-width: 2px;
  height: 100%;
}

body[data-page="home"] .market-breadth-bar .up {
  background: #ef4444;
}

body[data-page="home"] .market-breadth-bar .flat {
  background: #e5e7eb;
}

body[data-page="home"] .market-breadth-bar .down {
  background: #22c55e;
}

/* Home market strength: thermometer heat bar with yesterday delta */
body[data-page="home"] .market-strength-thermo {
  display: grid;
  gap: 6px;
  margin: 2px 0 0;
}

body[data-page="home"] .thermo-track {
  position: relative;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, #d6cd45 0%, #f59e0b 45%, #ef4444 58%, #be123c 100%);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.10);
}

body[data-page="home"] .market-strength-thermo.cool .thermo-track {
  background: linear-gradient(90deg, #16a34a 0%, #22c55e 52%, #d6cd45 100%);
}

body[data-page="home"] .thermo-track i {
  position: absolute;
  top: 50%;
  width: 2px;
  height: 20px;
  border-radius: 999px;
  background: #f8fafc;
  transform: translate(-50%, -50%);
  box-shadow: 0 0 0 3px rgba(15, 23, 42, .72), 0 0 10px rgba(248, 250, 252, .65);
}

body[data-page="home"] .thermo-scale {
  display: flex;
  justify-content: space-between;
  color: #8fa3bd;
  font-size: 11px;
  line-height: 1;
}

body[data-page="home"] #home-market-strength-change {
  color: #8fa3bd;
}

body[data-page="home"] .market-strength-thermo.hot + b + #home-market-strength-change {
  color: #f87171;
}

body[data-page="home"] .market-strength-thermo.cool + b + #home-market-strength-change {
  color: #4ade80;
}

/* Backtest chart polish: professional axes, grid and focused line rendering */
body[data-page="backtest"] #backtest-equity-chart .chart-grid line {
  stroke: rgba(148, 163, 184, 0.14);
  stroke-width: 1;
  vector-effect: non-scaling-stroke;
}

body[data-page="backtest"] #backtest-equity-chart .chart-grid line.vertical {
  stroke: rgba(148, 163, 184, 0.08);
}

body[data-page="backtest"] #backtest-equity-chart .zero-line {
  stroke: rgba(226, 232, 240, 0.45);
  stroke-width: 1.2;
  stroke-dasharray: 6 5;
  vector-effect: non-scaling-stroke;
}

body[data-page="backtest"] #backtest-equity-chart .chart-axis-labels text {
  fill: #7f95b2;
  font-size: 11px;
  font-weight: 750;
  letter-spacing: 0.01em;
}

body[data-page="backtest"] #backtest-equity-chart .equity-line {
  stroke-width: 2.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  vector-effect: non-scaling-stroke;
}

body[data-page="backtest"] #backtest-equity-chart .equity-line.glow {
  opacity: 0.28;
  stroke-width: 7;
  filter: url(#backtestLineGlow);
}

body[data-page="backtest"] #backtest-equity-chart .chart-point {
  opacity: 0.9;
  stroke: rgba(2, 8, 23, 0.88);
  stroke-width: 1.2;
  vector-effect: non-scaling-stroke;
}

body[data-page="backtest"] #backtest-equity-chart .chart-point.latest {
  stroke: #f8fafc;
  stroke-width: 1.8;
  filter: drop-shadow(0 0 8px rgba(56, 189, 248, 0.55));
}

body[data-page="backtest"] #backtest-equity-chart .chart-focus-info.strong {
  fill: #ffffff;
  font-size: 13px;
}

/* Backtest chart compact height + trades pagination */
body[data-page="backtest"] .backtest-equity-card {
  min-height: 460px;
}

body[data-page="backtest"] .backtest-equity-chart-wrap {
  min-height: 340px;
}

body[data-page="backtest"] .backtest-equity-chart-wrap svg {
  height: 340px;
}

body[data-page="backtest"] .backtest-trades-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 16px 16px;
  border-top: 1px solid rgba(56, 189, 248, 0.12);
}

body[data-page="backtest"] .backtest-trades-pagination .actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* Backtest chart fill: stretch plot to consume the full chart panel */
body[data-page="backtest"] .backtest-equity-card {
  min-height: 640px;
}

body[data-page="backtest"] .backtest-equity-chart-wrap {
  flex: 1 1 auto;
  min-height: 560px;
}

body[data-page="backtest"] .backtest-equity-chart-wrap svg {
  width: 100%;
  height: 100%;
  min-height: 560px;
}

body[data-page="backtest"] .backtest-trades-pagination .trades-page-size {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #9fb4cf;
  font-size: 12px;
  font-weight: 800;
}

body[data-page="backtest"] .backtest-trades-pagination select {
  height: 30px;
  border: 1px solid rgba(56, 189, 248, 0.28);
  border-radius: 8px;
  background: rgba(4, 14, 28, 0.9);
  color: #dbeafe;
  padding: 0 8px;
}

/* Backtest chart height: 60% of the tall fill version */
body[data-page="backtest"] .backtest-equity-card {
  min-height: 440px;
}

body[data-page="backtest"] .backtest-equity-chart-wrap {
  min-height: 336px;
}

body[data-page="backtest"] .backtest-equity-chart-wrap svg {
  min-height: 336px;
}

/* Backtest recent runs: fixed 20-item scroll list, no more button */
body[data-page="backtest"] .backtest-recent-runs-panel {
  max-height: 560px;
  overflow-y: auto;
  padding-right: 4px;
}

/* Backtest themed inner scrollbars */
body[data-page="backtest"] .table-wrapper,
body[data-page="backtest"] .compact-table-wrapper,
body[data-page="backtest"] .backtest-recent-runs-panel {
  scrollbar-width: thin;
  scrollbar-color: rgba(56, 189, 248, 0.55) rgba(8, 18, 32, 0.88);
}

body[data-page="backtest"] .table-wrapper::-webkit-scrollbar,
body[data-page="backtest"] .compact-table-wrapper::-webkit-scrollbar,
body[data-page="backtest"] .backtest-recent-runs-panel::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

body[data-page="backtest"] .table-wrapper::-webkit-scrollbar-track,
body[data-page="backtest"] .compact-table-wrapper::-webkit-scrollbar-track,
body[data-page="backtest"] .backtest-recent-runs-panel::-webkit-scrollbar-track {
  background: rgba(8, 18, 32, 0.92);
  border-left: 1px solid rgba(56, 189, 248, 0.12);
  border-radius: 999px;
}

body[data-page="backtest"] .table-wrapper::-webkit-scrollbar-thumb,
body[data-page="backtest"] .compact-table-wrapper::-webkit-scrollbar-thumb,
body[data-page="backtest"] .backtest-recent-runs-panel::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, rgba(56, 189, 248, 0.85), rgba(14, 116, 144, 0.82));
  border: 2px solid rgba(8, 18, 32, 0.92);
  border-radius: 999px;
  box-shadow: 0 0 10px rgba(56, 189, 248, 0.28);
}

body[data-page="backtest"] .table-wrapper::-webkit-scrollbar-thumb:hover,
body[data-page="backtest"] .compact-table-wrapper::-webkit-scrollbar-thumb:hover,
body[data-page="backtest"] .backtest-recent-runs-panel::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, rgba(125, 211, 252, 0.95), rgba(34, 211, 238, 0.86));
}

body[data-page="backtest"] .table-wrapper::-webkit-scrollbar-corner,
body[data-page="backtest"] .compact-table-wrapper::-webkit-scrollbar-corner,
body[data-page="backtest"] .backtest-recent-runs-panel::-webkit-scrollbar-corner {
  background: rgba(8, 18, 32, 0.92);
}

/* Backtest trade score details */
body[data-page="backtest"] .backtest-score-help {
  width: 18px;
  height: 18px;
  margin-left: 6px;
  color: #bae6fd;
  border-color: rgba(56, 189, 248, 0.35);
  background: rgba(14, 116, 144, 0.24);
  font-size: 11px;
  font-weight: 900;
  vertical-align: middle;
}

/* Backtest recent runs: show about five rows while keeping 20 loaded */
body[data-page="backtest"] .backtest-recent-runs-panel {
  max-height: 300px;
  overflow-y: auto;
}

/* Backtest chart baseline: highlight neutral line in amber */
body[data-page="backtest"] #backtest-equity-chart .zero-line {
  stroke: rgba(250, 204, 21, 0.92);
  stroke-width: 1.6;
  stroke-dasharray: 7 5;
  filter: drop-shadow(0 0 6px rgba(250, 204, 21, 0.35));
}

/* Backtest queue semantics: only the first active card is running, others wait */
body[data-page="backtest"] .backtest-run-card.waiting {
  border-color: rgba(251, 191, 36, 0.42);
  background:
    radial-gradient(circle at 20% 0%, rgba(251, 191, 36, 0.12), transparent 36%),
    linear-gradient(180deg, rgba(30, 32, 35, 0.96), rgba(9, 20, 34, 0.96));
}

body[data-page="backtest"] .backtest-run-card.waiting .backtest-progress-percent {
  color: #fbbf24;
}

body[data-page="backtest"] .backtest-run-card.waiting .backtest-progress-track i {
  background: repeating-linear-gradient(135deg, #fbbf24 0 8px, #b7791f 8px 16px);
}

body[data-page="backtest"] .run-dot.waiting {
  background: #fbbf24;
  box-shadow: 0 0 12px rgba(251, 191, 36, 0.55);
}

/* Global dark theme polish: scrollbars and native form controls */
html,
body,
* {
  scrollbar-width: thin;
  scrollbar-color: rgba(56, 189, 248, 0.58) rgba(8, 18, 32, 0.88);
}

*::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

*::-webkit-scrollbar-track {
  background: rgba(8, 18, 32, 0.92);
  border-radius: 999px;
}

*::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, rgba(56, 189, 248, 0.86), rgba(14, 116, 144, 0.82));
  border: 2px solid rgba(8, 18, 32, 0.92);
  border-radius: 999px;
  box-shadow: 0 0 10px rgba(56, 189, 248, 0.26);
}

*::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, rgba(125, 211, 252, 0.96), rgba(34, 211, 238, 0.88));
}

*::-webkit-scrollbar-corner {
  background: rgba(8, 18, 32, 0.92);
}

input[type="number"] {
  color-scheme: dark;
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  opacity: 0.95;
  filter: invert(72%) sepia(41%) saturate(797%) hue-rotate(151deg) brightness(102%) contrast(95%);
  background: rgba(8, 18, 32, 0.92);
  border-left: 1px solid rgba(56, 189, 248, 0.20);
  cursor: pointer;
}

input[type="date"]::-webkit-calendar-picker-indicator,
select {
  color-scheme: dark;
}

body[data-page="backtest"] .backtest-terminal-form .backtest-adjusted-toggle input[type="checkbox"] {
  appearance: none;
  width: 16px;
  min-width: 16px;
  max-width: 16px;
  height: 16px;
  min-height: 16px;
  padding: 0;
  margin-top: 2px;
  flex: 0 0 16px;
  border: 1px solid rgba(125, 211, 252, .52);
  border-radius: 4px;
  background: rgba(2, 8, 18, .88);
  box-shadow: inset 0 0 0 1px rgba(2, 8, 18, .42);
}

body[data-page="backtest"] .backtest-terminal-form .backtest-adjusted-toggle input[type="checkbox"]:checked {
  border-color: rgba(14, 165, 233, .95);
  background: linear-gradient(135deg, #38bdf8, #2563eb);
}

body[data-page="backtest"] .backtest-terminal-form .backtest-adjusted-toggle input[type="checkbox"]:checked::after {
  content: "";
  display: block;
  width: 8px;
  height: 4px;
  margin: 4px 0 0 3px;
  border-left: 2px solid #f8fafc;
  border-bottom: 2px solid #f8fafc;
  transform: rotate(-45deg);
}

body[data-page="backtest"] .backtest-advanced-grid .terminal-form-field {
  align-self: stretch;
  border: 1px solid rgba(56, 189, 248, 0.20);
  border-radius: 10px;
  padding: 12px;
  background: rgba(4, 14, 28, 0.48);
}

body[data-page="backtest"] .backtest-advanced-grid .cost-field {
  grid-column: auto;
  min-width: 0;
  max-width: none;
  width: 100%;
  display: grid;
  grid-template-rows: auto 1fr;
}

body[data-page="backtest"] .backtest-advanced-grid .small-field {
  max-width: none;
  width: 100%;
}

body[data-page="backtest"] .backtest-advanced-grid .cost-field .input-with-unit {
  width: 100%;
  max-width: none;
  align-self: end;
}

body[data-page="backtest"] .backtest-advanced-grid .cost-field .input-with-unit input {
  min-width: 0;
}

body[data-page="backtest"] .backtest-advanced-grid .cost-field .input-with-unit span {
  min-width: 58px;
  justify-content: center;
}

@media (max-width: 1300px) {
  .backtest-advanced-grid {
    grid-template-columns: repeat(2, minmax(220px, 1fr));
  }
  .backtest-adjusted-toggle.wide,
  body[data-page="backtest"] .backtest-advanced-grid .cost-field {
    grid-column: span 1;
  }
}

/* Trade strategy V2.2 draft page */
body[data-page="trade-strategies"] .trade-strategy-hero {
  align-items: flex-end;
}

.trade-strategy-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(240px, 1fr));
  gap: 16px;
  margin-bottom: 18px;
}

.trade-strategy-card {
  text-align: left;
  border: 1px solid rgba(56, 189, 248, .22);
  border-radius: 16px;
  padding: 16px;
  background: linear-gradient(180deg, rgba(15, 32, 54, .95), rgba(8, 18, 32, .94));
  color: #dbeafe;
  cursor: pointer;
  display: grid;
  gap: 9px;
  min-height: 150px;
}

.trade-strategy-card:hover,
.trade-strategy-card.active {
  border-color: rgba(56, 189, 248, .65);
  box-shadow: 0 18px 42px rgba(14, 165, 233, .18);
}

.trade-strategy-card strong {
  font-size: 18px;
}

.trade-strategy-card small {
  color: #9fb4cf;
  line-height: 1.55;
}

.trade-strategy-workbench {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(360px, .75fr);
  gap: 18px;
}

@media (max-width: 980px) {
  .trade-strategy-grid,
  .trade-strategy-workbench {
    grid-template-columns: 1fr;
  }
}

/* Backtest number inputs: make native spin buttons less visually loud on dark UI */
body[data-page="backtest"] .backtest-terminal-form input[type="number"] {
  color-scheme: dark;
}

body[data-page="backtest"] .backtest-terminal-form input[type="number"]::-webkit-inner-spin-button,
body[data-page="backtest"] .backtest-terminal-form input[type="number"]::-webkit-outer-spin-button {
  opacity: .82;
  filter: grayscale(1) invert(1) brightness(1.85) contrast(.92);
  background: rgba(2, 8, 18, .92);
  border-left: 1px solid rgba(56, 189, 248, .16);
  border-radius: 4px;
}

.backtest-horizon-row td {
  padding-top: 0;
  background: rgba(15, 23, 42, 0.42);
  border-top: 0;
}

.backtest-horizon-title {
  margin: 0 0 8px;
  color: var(--text-muted, #94a3b8);
  font-size: 12px;
  letter-spacing: 0.02em;
}

.backtest-horizon-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(150px, 1fr));
  gap: 10px;
}

.backtest-horizon-card {
  display: grid;
  gap: 10px;
  min-height: 118px;
  padding: 12px 14px;
  border: 1px solid rgba(96, 165, 250, 0.22);
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(15, 23, 42, 0.76), rgba(2, 6, 23, 0.48));
  color: var(--text-primary, #e5e7eb);
  font-size: 13px;
}

.backtest-horizon-card-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(148, 163, 184, 0.12);
}

.backtest-horizon-card strong {
  color: var(--accent, #60a5fa);
  font-size: 15px;
  line-height: 1;
}

.backtest-horizon-card-head span {
  color: var(--text-muted, #94a3b8);
  font-size: 13px;
  white-space: nowrap;
}

.backtest-horizon-metrics {
  display: grid;
  gap: 8px;
}

.backtest-horizon-metrics div {
  display: grid;
  grid-template-columns: minmax(56px, 0.8fr) minmax(64px, 1fr) minmax(50px, auto);
  align-items: baseline;
  column-gap: 8px;
}

.backtest-horizon-metrics span {
  color: var(--text-muted, #94a3b8);
  font-size: 12px;
}

.backtest-horizon-metrics b,
.backtest-horizon-metrics em {
  color: var(--text-primary, #e5e7eb);
  font-size: 13px;
  font-style: normal;
  font-weight: 700;
  text-align: right;
  white-space: nowrap;
}

.backtest-horizon-metrics div:not(:first-child) {
  grid-template-columns: minmax(64px, 1fr) minmax(72px, auto);
}

.backtest-horizon-metrics div:not(:first-child) b {
  grid-column: 2;
}

@media (max-width: 920px) {
  .backtest-horizon-grid {
    grid-template-columns: 1fr;
  }
}
