body.theme-dark  { --ec-bg:#0b0e11; --ec-panel:#131722; --ec-panel2:#0d1017; --ec-border:#1e2433; --ec-border2:#2a3350; --ec-text:#d1d5dc; --ec-muted:#9098a8; --ec-soft:#5c6680; --ec-accent:#2962ff; --ec-green:#26a69a; --ec-warn:#f59e0b; }
body.theme-white { --ec-bg:#f7f8fa; --ec-panel:#ffffff; --ec-panel2:#f0f2f5; --ec-border:#dde2ec; --ec-border2:#c8d0e0; --ec-text:#1a2035; --ec-muted:#5c6680; --ec-soft:#9098a8; --ec-accent:#2962ff; --ec-green:#188f83; --ec-warn:#b7791f; }
body.theme-trader{ --ec-bg:#020c02; --ec-panel:#050f05; --ec-panel2:#071207; --ec-border:#0d2b0d; --ec-border2:#164016; --ec-text:#00ff41; --ec-muted:#00d435; --ec-soft:#006820; --ec-accent:#00ff41; --ec-green:#00ff41; --ec-warn:#ffd166; }

.earnings-title { min-width: 0; display: flex; align-items: baseline; gap: 12px; }
.earnings-title h1 { margin: 0; color: var(--ec-text); font-size: 20px; line-height: 1.1; font-weight: 800; }
.earnings-title span { color: var(--ec-muted); font-size: 12px; font-weight: 650; }
.earnings-page { padding: 14px; }
.earnings-toolbar {
  display: grid;
  grid-template-columns: 150px 150px minmax(220px, 1fr) 38px;
  gap: 8px;
  align-items: end;
  margin-bottom: 10px;
}
.earnings-toolbar label { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.earnings-toolbar span { color: var(--ec-soft); font-size: 10px; font-weight: 800; text-transform: uppercase; }
.earnings-toolbar input,
.earnings-toolbar select {
  width: 100%;
  height: 34px;
  border: 1px solid var(--ec-border);
  border-radius: 4px;
  background: var(--ec-panel);
  color: var(--ec-text);
  padding: 0 10px;
  outline: none;
}
.earnings-toolbar input:focus,
.earnings-toolbar select:focus { border-color: var(--ec-accent); }
.earnings-toolbar button,
.earnings-pager button {
  width: 38px;
  height: 34px;
  border: 1px solid var(--ec-border);
  border-radius: 4px;
  background: var(--ec-panel2);
  color: var(--ec-muted);
  cursor: pointer;
}
.earnings-toolbar button:hover,
.earnings-pager button:hover { border-color: var(--ec-accent); color: var(--ec-text); }
.earnings-table-wrap {
  overflow: auto;
  border: 1px solid var(--ec-border);
  border-radius: 6px;
  background: var(--ec-panel);
}
.earnings-table { width: 100%; border-collapse: collapse; min-width: 920px; }
.earnings-table th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: var(--ec-panel2);
  color: var(--ec-soft);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .04em;
  text-align: left;
  padding: 9px 10px;
  border-bottom: 1px solid var(--ec-border);
}
.earnings-table td {
  padding: 10px;
  border-bottom: 1px solid var(--ec-border);
  color: var(--ec-muted);
  font-size: 12px;
  vertical-align: middle;
}
.earnings-table tr:hover td { background: rgba(41,98,255,.04); }
.earnings-date-cell { color: var(--ec-text); font-weight: 800; white-space: nowrap; }
.earnings-session { color: var(--ec-warn); font-weight: 800; margin-left: 6px; }
.earnings-company { display: flex; flex-direction: column; gap: 2px; min-width: 220px; }
.earnings-company strong { color: var(--ec-text); font-size: 13px; }
.earnings-company span { color: var(--ec-soft); font-size: 11px; }
.earnings-ticker { color: var(--ec-accent); font-weight: 900; text-decoration: none; font-family: "Roboto Mono", "Courier New", monospace; }
.earnings-ticker:hover { color: var(--ec-accent); text-decoration: underline; }
.earnings-ticker.muted { color: var(--ec-text); }
.earnings-metric { color: var(--ec-text); font-family: "Roboto Mono", "Courier New", monospace; white-space: nowrap; }
.earnings-sub { color: var(--ec-soft); font-size: 11px; margin-top: 2px; }
.earnings-empty { text-align: center; padding: 32px !important; color: var(--ec-soft) !important; }
.earnings-pager {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 10px;
}
.earnings-pager span { color: var(--ec-muted); font-size: 12px; font-weight: 700; }

@media (max-width: 900px) {
  .earnings-toolbar { grid-template-columns: 1fr 1fr; }
  .earnings-search { grid-column: 1 / -1; }
  .earnings-toolbar button { width: 100%; }
}
